Mercurial > kallithea
view rhodecode/model/repo_permission.py @ 1589:307ec693bdf2 beta
[API] Create groups needed when creating repo
author | Nicolas VINOT <aeris@imirhil.fr> |
---|---|
date | Fri, 07 Oct 2011 21:49:28 +0200 |
parents | 2ccb32ddcfd7 |
children | 92a4f7c496a5 |
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 getUserPermission( self, repository, user ): return RepoToPerm.query() \ .filter( RepoToPerm.user == user ) \ .filter( RepoToPerm.repository == repository ) \ .scalar() def updateUserPermission( self, repository, user, permission ): permission = Permission.get_by_key( permission ) current = self.getUserPermission( 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 deleteUserPermission( self, repository, user ): current = self.getUserPermission( repository, user ) if current: Session.delete( current ) Session.commit() def updateOrDeleteUserPermission( self, repository, user, permission ): if permission: self.updateUserPermission( repository, user, permission ) else: self.deleteUserPermission( repository, user )