69 lines
2.1 KiB
Python
69 lines
2.1 KiB
Python
from __future__ import unicode_literals
|
|
|
|
from django.apps import apps
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from acls import ModelPermission
|
|
from acls.links import link_acl_list
|
|
from acls.permissions import permission_acl_edit, permission_acl_view
|
|
|
|
from common import (
|
|
MayanAppConfig, menu_multi_item, menu_object, menu_secondary, menu_setup
|
|
)
|
|
from common.signals import perform_upgrade
|
|
|
|
from .handlers import purge_permissions
|
|
from .links import (
|
|
link_group_roles, link_permission_grant, link_permission_revoke,
|
|
link_role_create, link_role_delete, link_role_edit, link_role_groups,
|
|
link_role_list, link_role_permissions
|
|
)
|
|
from .permissions import (
|
|
permission_role_delete, permission_role_edit, permission_role_view
|
|
)
|
|
from .search import * # NOQA
|
|
|
|
|
|
class PermissionsApp(MayanAppConfig):
|
|
has_rest_api = True
|
|
has_tests = True
|
|
name = 'permissions'
|
|
verbose_name = _('Permissions')
|
|
|
|
def ready(self):
|
|
super(PermissionsApp, self).ready()
|
|
|
|
Role = self.get_model('Role')
|
|
Group = apps.get_model(app_label='auth', model_name='Group')
|
|
|
|
ModelPermission.register(
|
|
model=Role, permissions=(
|
|
permission_acl_edit, permission_acl_view,
|
|
permission_role_delete, permission_role_edit,
|
|
permission_role_view
|
|
)
|
|
)
|
|
|
|
menu_object.bind_links(
|
|
links=(link_group_roles,), position=98, sources=(Group,)
|
|
)
|
|
menu_object.bind_links(
|
|
links=(
|
|
link_role_edit, link_role_groups, link_role_permissions,
|
|
link_acl_list, link_role_delete
|
|
), sources=(Role,)
|
|
)
|
|
menu_multi_item.bind_links(
|
|
links=(link_permission_grant, link_permission_revoke),
|
|
sources=('permissions:role_permissions',)
|
|
)
|
|
menu_secondary.bind_links(
|
|
links=(link_role_list, link_role_create),
|
|
sources=(Role, 'permissions:role_create', 'permissions:role_list')
|
|
)
|
|
menu_setup.bind_links(links=(link_role_list,))
|
|
|
|
perform_upgrade.connect(
|
|
purge_permissions, dispatch_uid='purge_permissions'
|
|
)
|