##// END OF EJS Templates
backported fixes for statistics from beta branch, try to fix issue #271...
backported fixes for statistics from beta branch, try to fix issue #271 - version bump

File last commit:

r1824:89efedac beta
r1887:3246fcce default
Show More
repo_permission.py
101 lines | 3.8 KiB | text/x-python | PythonLexer
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 # -*- coding: utf-8 -*-
"""
rhodecode.model.users_group
~~~~~~~~~~~~~~~~~~~~~~~~~~~
repository permission model for RhodeCode
:created_on: Oct 1, 2011
backporting #329 into stable
r1794 :author: nvinot, marcink
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 :copyright: (C) 2011-2011 Nicolas Vinot <aeris@imirhil.fr>
backporting #329 into stable
r1794 :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com>
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 :license: GPLv3, see COPYING for more details.
"""
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# 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 General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import logging
backporting #329 into stable
r1794 from rhodecode.model.db import BaseModel, RepoToPerm, Permission,\
UsersGroupRepoToPerm
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 from rhodecode.model.meta import Session
Nicolas VINOT
Correct code style
r1593 log = logging.getLogger(__name__)
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586
backporting #329 into stable
r1794
Nicolas VINOT
Correct code style
r1593 class RepositoryPermissionModel(BaseModel):
def get_user_permission(self, repository, user):
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 return RepoToPerm.query() \
Nicolas VINOT
Correct code style
r1593 .filter(RepoToPerm.user == user) \
.filter(RepoToPerm.repository == repository) \
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 .scalar()
Nicolas VINOT
Correct code style
r1593 def update_user_permission(self, repository, user, permission):
permission = Permission.get_by_key(permission)
current = self.get_user_permission(repository, user)
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 if current:
if not current.permission is permission:
current.permission = permission
else:
p = RepoToPerm()
p.user = user
p.repository = repository
p.permission = permission
Nicolas VINOT
Correct code style
r1593 Session.add(p)
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 Session.commit()
Nicolas VINOT
Correct code style
r1593 def delete_user_permission(self, repository, user):
current = self.get_user_permission(repository, user)
Nicolas VINOT
[API] Create groups needed when creating repo
r1589 if current:
Nicolas VINOT
Correct code style
r1593 Session.delete(current)
Nicolas VINOT
[API] Create groups needed when creating repo
r1589 Session.commit()
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586
backporting #329 into stable
r1794 def get_users_group_permission(self, repository, users_group):
return UsersGroupRepoToPerm.query() \
.filter(UsersGroupRepoToPerm.users_group == users_group) \
.filter(UsersGroupRepoToPerm.repository == repository) \
.scalar()
def update_users_group_permission(self, repository, users_group,
permission):
permission = Permission.get_by_key(permission)
current = self.get_users_group_permission(repository, users_group)
if current:
if not current.permission is permission:
current.permission = permission
else:
p = UsersGroupRepoToPerm()
p.users_group = users_group
p.repository = repository
p.permission = permission
self.sa.add(p)
Session.commit()
def delete_users_group_permission(self, repository, users_group):
current = self.get_users_group_permission(repository, users_group)
if current:
self.sa.delete(current)
Session.commit()
Nicolas VINOT
Correct code style
r1593 def update_or_delete_user_permission(self, repository, user, permission):
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 if permission:
Nicolas VINOT
Correct code style
r1593 self.update_user_permission(repository, user, permission)
Nicolas VINOT
Add API for repositories and groups (creation, permission)
r1586 else:
Nicolas VINOT
Correct code style
r1593 self.delete_user_permission(repository, user)
backporting #329 into stable
r1794
def update_or_delete_users_group_permission(self, repository, user_group,
permission):
if permission:
self.update_users_group_permission(repository, user_group,
permission)
else:
self.delete_users_group_permission(repository, user_group)