Source code for core.security.roles

from __future__ import annotations

from onegov.core.framework import Framework
from onegov.core.security import Public, Personal, Private, Secret


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from .permissions import Intent


@Framework.setting_section(section='roles')
[docs] def get_roles_setting() -> dict[str, set[type[Intent]]]: """ Returns the default roles available to onegov.core applications. Applications building on onegov.core may add more roles and permissions, or replace the existing ones entirely, though it's not something that one should do carelessly. The default roles are: **admin** Has access to everything **editor** Has access to most things **member** Has access their own data. Be careful though, core doesn't know about personal data, so this is just a role to implement registered users. As with all permissions, making sure the right information is shown is up to the applications. **anonymous** Has access to public things """ return { # the admin role has access to everything 'admin': { Public, Private, Personal, Secret }, # the editor can do most things 'editor': { Public, Private, Personal, }, # registered users can do a few things 'member': { Public, Personal, }, # the public has some access 'anonymous': { Public, } }