types.py
105 lines
| 3.5 KiB
| text/x-python
|
PythonLexer
r523 | # -*- coding: utf-8 -*- | |||
# Copyright (C) 2016-2016 RhodeCode GmbH | ||||
# | ||||
# This program is free software: you can redistribute it and/or modify | ||||
# it under the terms of the GNU Affero General Public License, version 3 | ||||
# (only), as published by the Free Software Foundation. | ||||
# | ||||
# This program is distributed in the hope that it will be useful, | ||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
# | ||||
# You should have received a copy of the GNU Affero General Public License | ||||
# along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||
# | ||||
# This program is dual-licensed. If you wish to learn more about the | ||||
# RhodeCode Enterprise Edition, including its added features, Support services, | ||||
# and proprietary license terms, please see https://rhodecode.com/licenses/ | ||||
import colander | ||||
r740 | from rhodecode.model.db import User, UserGroup | |||
r523 | ||||
class GroupNameType(colander.String): | ||||
SEPARATOR = '/' | ||||
def deserialize(self, node, cstruct): | ||||
result = super(GroupNameType, self).deserialize(node, cstruct) | ||||
return self._replace_extra_slashes(result) | ||||
def _replace_extra_slashes(self, path): | ||||
path = path.split(self.SEPARATOR) | ||||
path = [item for item in path if item] | ||||
return self.SEPARATOR.join(path) | ||||
r740 | ||||
class UserOrUserGroupType(colander.SchemaType): | ||||
""" colander Schema type for valid rhodecode user and/or usergroup """ | ||||
scopes = ('user', 'usergroup') | ||||
def __init__(self): | ||||
self.users = 'user' in self.scopes | ||||
self.usergroups = 'usergroup' in self.scopes | ||||
def serialize(self, node, appstruct): | ||||
if appstruct is colander.null: | ||||
return colander.null | ||||
if self.users: | ||||
if isinstance(appstruct, User): | ||||
if self.usergroups: | ||||
return 'user:%s' % appstruct.username | ||||
return appstruct.username | ||||
if self.usergroups: | ||||
if isinstance(appstruct, UserGroup): | ||||
if self.users: | ||||
return 'usergroup:%s' % appstruct.users_group_name | ||||
return appstruct.users_group_name | ||||
raise colander.Invalid( | ||||
node, '%s is not a valid %s' % (appstruct, ' or '.join(self.scopes))) | ||||
def deserialize(self, node, cstruct): | ||||
if cstruct is colander.null: | ||||
return colander.null | ||||
user, usergroup = None, None | ||||
if self.users: | ||||
if cstruct.startswith('user:'): | ||||
user = User.get_by_username(cstruct.split(':')[1]) | ||||
else: | ||||
user = User.get_by_username(cstruct) | ||||
if self.usergroups: | ||||
if cstruct.startswith('usergroup:'): | ||||
usergroup = UserGroup.get_by_group_name(cstruct.split(':')[1]) | ||||
else: | ||||
usergroup = UserGroup.get_by_group_name(cstruct) | ||||
if self.users and self.usergroups: | ||||
if user and usergroup: | ||||
raise colander.Invalid(node, ( | ||||
'%s is both a user and usergroup, specify which ' | ||||
'one was wanted by prepending user: or usergroup: to the ' | ||||
'name') % cstruct) | ||||
if self.users and user: | ||||
return user | ||||
if self.usergroups and usergroup: | ||||
return usergroup | ||||
raise colander.Invalid( | ||||
node, '%s is not a valid %s' % (cstruct, ' or '.join(self.scopes))) | ||||
class UserType(UserOrUserGroupType): | ||||
scopes = ('user',) | ||||
class UserGroupType(UserOrUserGroupType): | ||||
scopes = ('usergroup',) | ||||