Files @ 7e5f8c12a3fc
Branch filter:

Location: kallithea/rhodecode/model/permission.py - annotation

Bradley M. Kuhn
First step in two-part process to rename directories to kallithea.
This first step is to change all references in the files where they refer
to the old directory name.
a7f50911a945
a671db5bdd58
a671db5bdd58
a671db5bdd58
a671db5bdd58
6832ef664673
cb0d9ce6ac5c
cb0d9ce6ac5c
cb0d9ce6ac5c
cb0d9ce6ac5c
6832ef664673
cb0d9ce6ac5c
a671db5bdd58
ffd45b185016
7e5f8c12a3fc
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
a7f50911a945
a7f50911a945
a7f50911a945
a7f50911a945
a7f50911a945
cb0d9ce6ac5c
7e5f8c12a3fc
7e5f8c12a3fc
8a40028eaf73
7e5f8c12a3fc
f522f4d3bf93
cb0d9ce6ac5c
cb0d9ce6ac5c
cb0d9ce6ac5c
89b9037d68b7
7d1fc253549e
7d1fc253549e
bb35ad076e2f
cb0d9ce6ac5c
17893d61792a
17893d61792a
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
a8f520540ab0
ffd45b185016
af049a957506
ffd45b185016
ffd45b185016
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
ffd45b185016
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
af049a957506
cb0d9ce6ac5c
e42e1d4e1c47
cb0d9ce6ac5c
cb0d9ce6ac5c
af049a957506
ffd45b185016
af049a957506
af049a957506
af049a957506
af049a957506
e42e1d4e1c47
a8f520540ab0
e42e1d4e1c47
e42e1d4e1c47
e42e1d4e1c47
e42e1d4e1c47
e42e1d4e1c47
e42e1d4e1c47
e42e1d4e1c47
af049a957506
af049a957506
af049a957506
cb0d9ce6ac5c
e42e1d4e1c47
e42e1d4e1c47
ffd45b185016
ffd45b185016
a8f520540ab0
a8f520540ab0
ffd45b185016
a8f520540ab0
a8f520540ab0
ffd45b185016
ffd45b185016
222e6769e7b5
e42e1d4e1c47
e42e1d4e1c47
d2d35cf2b351
af049a957506
7aa0ff5b4e09
d3200c58764e
e42e1d4e1c47
a970b6e7c5a2
2c0d35e336b5
a970b6e7c5a2
a970b6e7c5a2
9e76876a0690
9e76876a0690
260a7a01b054
9e76876a0690
9e76876a0690
d3200c58764e
7aa0ff5b4e09
d3200c58764e
a970b6e7c5a2
e42e1d4e1c47
a970b6e7c5a2
a970b6e7c5a2
a970b6e7c5a2
a970b6e7c5a2
a970b6e7c5a2
cb0d9ce6ac5c
7aa0ff5b4e09
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
8a40028eaf73
e42e1d4e1c47
a7f50911a945
cb0d9ce6ac5c
e42e1d4e1c47
cb0d9ce6ac5c
# -*- coding: utf-8 -*-
# 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/>.
"""
kallithea.model.permission
~~~~~~~~~~~~~~~~~~~~~~~~~~

permissions model for RhodeCode

:created_on: Aug 20, 2010
:author: marcink
:copyright: (c) 2013 RhodeCode GmbH.
:license: GPLv3, see LICENSE for more details.
"""


import logging
import traceback

from sqlalchemy.exc import DatabaseError

from kallithea.model import BaseModel
from kallithea.model.db import User, Permission, UserToPerm, UserRepoToPerm,\
    UserRepoGroupToPerm, UserUserGroupToPerm
from kallithea.lib.utils2 import str2bool

log = logging.getLogger(__name__)


class PermissionModel(BaseModel):
    """
    Permissions model for RhodeCode
    """

    cls = Permission

    def create_permissions(self):
        """
        Create permissions for whole system
        """
        for p in Permission.PERMS:
            if not Permission.get_by_key(p[0]):
                new_perm = Permission()
                new_perm.permission_name = p[0]
                new_perm.permission_longname = p[0]  #translation err with p[1]
                self.sa.add(new_perm)

    def create_default_permissions(self, user, force=False):
        """
        Creates only missing default permissions for user, if force is set it
        resets the default permissions for that user

        :param user:
        """
        user = self._get_user(user)

        def _make_perm(perm):
            new_perm = UserToPerm()
            new_perm.user = user
            new_perm.permission = Permission.get_by_key(perm)
            return new_perm

        def _get_group(perm_name):
            return '.'.join(perm_name.split('.')[:1])

        perms = UserToPerm.query().filter(UserToPerm.user == user).all()
        defined_perms_groups = map(_get_group,
                                (x.permission.permission_name for x in perms))
        log.debug('GOT ALREADY DEFINED:%s' % perms)
        DEFAULT_PERMS = Permission.DEFAULT_USER_PERMISSIONS

        if force:
            for perm in perms:
                self.sa.delete(perm)
            self.sa.commit()
            defined_perms_groups = []
        # for every default permission that needs to be created, we check if
        # it's group is already defined, if it's not we create default perm
        for perm_name in DEFAULT_PERMS:
            gr = _get_group(perm_name)
            if gr not in defined_perms_groups:
                log.debug('GR:%s not found, creating permission %s'
                          % (gr, perm_name))
                new_perm = _make_perm(perm_name)
                self.sa.add(new_perm)

    def update(self, form_result):
        perm_user = User.get_by_username(username=form_result['perm_user_name'])

        try:
            # stage 1 set anonymous access
            if perm_user.username == User.DEFAULT_USER:
                perm_user.active = str2bool(form_result['anonymous'])
                self.sa.add(perm_user)

            # stage 2 reset defaults and set them from form data
            def _make_new(usr, perm_name):
                log.debug('Creating new permission:%s' % (perm_name))
                new = UserToPerm()
                new.user = usr
                new.permission = Permission.get_by_key(perm_name)
                return new
            # clear current entries, to make this function idempotent
            # it will fix even if we define more permissions or permissions
            # are somehow missing
            u2p = self.sa.query(UserToPerm)\
                .filter(UserToPerm.user == perm_user)\
                .all()
            for p in u2p:
                self.sa.delete(p)
            #create fresh set of permissions
            for def_perm_key in ['default_repo_perm',
                                 'default_group_perm',
                                 'default_user_group_perm',
                                 'default_repo_create',
                                 'create_on_write', # special case for create repos on write access to group
                                 #'default_repo_group_create', #not implemented yet
                                 'default_user_group_create',
                                 'default_fork',
                                 'default_register',
                                 'default_extern_activate']:
                p = _make_new(perm_user, form_result[def_perm_key])
                self.sa.add(p)

            #stage 3 update all default permissions for repos if checked
            if form_result['overwrite_default_repo']:
                _def_name = form_result['default_repo_perm'].split('repository.')[-1]
                _def = Permission.get_by_key('repository.' + _def_name)
                # repos
                for r2p in self.sa.query(UserRepoToPerm)\
                               .filter(UserRepoToPerm.user == perm_user)\
                               .all():

                    #don't reset PRIVATE repositories
                    if not r2p.repository.private:
                        r2p.permission = _def
                        self.sa.add(r2p)

            if form_result['overwrite_default_group']:
                _def_name = form_result['default_group_perm'].split('group.')[-1]
                # groups
                _def = Permission.get_by_key('group.' + _def_name)
                for g2p in self.sa.query(UserRepoGroupToPerm)\
                               .filter(UserRepoGroupToPerm.user == perm_user)\
                               .all():
                    g2p.permission = _def
                    self.sa.add(g2p)

            if form_result['overwrite_default_user_group']:
                _def_name = form_result['default_user_group_perm'].split('usergroup.')[-1]
                # groups
                _def = Permission.get_by_key('usergroup.' + _def_name)
                for g2p in self.sa.query(UserUserGroupToPerm)\
                               .filter(UserUserGroupToPerm.user == perm_user)\
                               .all():
                    g2p.permission = _def
                    self.sa.add(g2p)

            self.sa.commit()
        except (DatabaseError,):
            log.error(traceback.format_exc())
            self.sa.rollback()
            raise