Files
mayan-edms/mayan/apps/permissions/apps.py
Roberto Rosario 8e69178e07 Project: Switch to full app paths
Instead of inserting the path of the apps into the Python app,
the apps are now referenced by their full import path.

This app name claves with external or native Python libraries.
Example: Mayan statistics app vs. Python new statistics library.

Every app reference is now prepended with 'mayan.apps'.

Existing config.yml files need to be updated manually.

Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
2018-12-05 02:04:20 -04:00

77 lines
2.5 KiB
Python

from __future__ import unicode_literals
from django.apps import apps
from django.utils.translation import ugettext_lazy as _
from mayan.apps.acls import ModelPermission
from mayan.apps.acls.links import link_acl_list
from mayan.apps.acls.permissions import permission_acl_edit, permission_acl_view
from mayan.apps.common import (
MayanAppConfig, menu_list_facet, menu_multi_item, menu_object,
menu_secondary, menu_setup
)
from mayan.apps.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_permission_grant, permission_permission_revoke,
permission_role_delete, permission_role_edit, permission_role_view
)
from .search import * # NOQA
class PermissionsApp(MayanAppConfig):
app_namespace = 'permissions'
app_url = 'permissions'
has_rest_api = True
has_tests = True
name = 'mayan.apps.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_permission_grant, permission_permission_revoke,
permission_role_delete, permission_role_edit,
permission_role_view
)
)
menu_list_facet.bind_links(
links=(
link_acl_list, link_role_groups, link_role_permissions,
), sources=(Role,)
)
menu_list_facet.bind_links(
links=(link_group_roles,), sources=(Group,)
)
menu_object.bind_links(
links=(
link_role_edit, 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'
)