Source code for org.security

from __future__ import annotations

from onegov.org.app import OrgApp
from onegov.org.models import Export
from onegov.ticket import Ticket


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from morepath.authentication import Identity


@OrgApp.permission_rule(model=Export, permission=object, identity=None)
[docs] def has_export_permission_not_logged_in( app: OrgApp, identity: None, model: Export, permission: object ) -> bool: return model.permission in app.settings.roles.anonymous
@OrgApp.permission_rule(model=Export, permission=object)
[docs] def has_export_permissions_logged_in( app: OrgApp, identity: Identity, model: Export, permission: object ) -> bool: return model.permission in getattr(app.settings.roles, identity.role)
@OrgApp.permission_rule(model=Ticket, permission=object)
[docs] def has_permission_ticket( app: OrgApp, identity: Identity, model: Ticket, permission: object ) -> bool: role = identity.role # Downgrade the role if role not in ('admin', 'anonymous'): groups = app.ticket_permissions.get(model.handler_code, {}) if model.group in groups: if identity.groupid not in groups[model.group]: role = 'member' elif None in groups: if identity.groupid not in groups[None]: role = 'member' if role == 'member': if getattr(model, 'access', None) == 'private': return False return permission in getattr(app.settings.roles, role)