Mercurial > kallithea
view rhodecode/model/repo_permission.py @ 1632:5b2cf21b1947 beta
Synced with latest sqlalchemy-migrate, added new upcomming migration for 1.3
author | Marcin Kuzminski <marcin@python-works.com> |
---|---|
date | Wed, 02 Nov 2011 03:04:54 +0200 |
parents | 92a4f7c496a5 |
children | 2c0d35e336b5 702e29ce1e9b |
line wrap: on
line source
# -*- coding: utf-8 -*- """ rhodecode.model.users_group ~~~~~~~~~~~~~~~~~~~~~~~~~~~ repository permission model for RhodeCode :created_on: Oct 1, 2011 :author: nvinot :copyright: (C) 2011-2011 Nicolas Vinot <aeris@imirhil.fr> :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 from rhodecode.model.db import BaseModel, RepoToPerm, Permission from rhodecode.model.meta import Session log = logging.getLogger(__name__) class RepositoryPermissionModel(BaseModel): def get_user_permission(self, repository, user): return RepoToPerm.query() \ .filter(RepoToPerm.user == user) \ .filter(RepoToPerm.repository == repository) \ .scalar() def update_user_permission(self, repository, user, permission): permission = Permission.get_by_key(permission) current = self.get_user_permission(repository, user) if current: if not current.permission is permission: current.permission = permission else: p = RepoToPerm() p.user = user p.repository = repository p.permission = permission Session.add(p) Session.commit() def delete_user_permission(self, repository, user): current = self.get_user_permission(repository, user) if current: Session.delete(current) Session.commit() def update_or_delete_user_permission(self, repository, user, permission): if permission: self.update_user_permission(repository, user, permission) else: self.delete_user_permission(repository, user)