1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- import typing
- from enum import Enum
-
- from tracim_backend.exceptions import RoleDoesNotExist
-
-
- class WorkspaceRoles(Enum):
- """
- Available role for workspace.
- All roles should have a unique level and unique slug.
- level is role value store in database and is also use for
- permission check.
- slug is for http endpoints and other place where readability is
- needed.
- """
- NOT_APPLICABLE = (0, 'not-applicable')
- READER = (1, 'reader')
- CONTRIBUTOR = (2, 'contributor')
- CONTENT_MANAGER = (4, 'content-manager')
- WORKSPACE_MANAGER = (8, 'workspace-manager')
-
- def __init__(self, level, slug):
- self.level = level
- self.slug = slug
-
- @property
- def label(self):
- """ Return valid label associated to role"""
-
- return self.slug
-
- @classmethod
- def get_all_valid_role(cls) -> typing.List['WorkspaceRoles']:
- """
- Return all valid role value
- """
- return [item for item in list(WorkspaceRoles) if item.level > 0]
-
- @classmethod
- def get_role_from_level(cls, level: int) -> 'WorkspaceRoles':
- """
- Obtain Workspace role from a level value
- :param level: level value as int
- :return: correct workspace role related
- """
- roles = [item for item in list(WorkspaceRoles) if item.level == level]
- if len(roles) != 1:
- raise RoleDoesNotExist()
- return roles[0]
-
- @classmethod
- def get_role_from_slug(cls, slug: str) -> 'WorkspaceRoles':
- """
- Obtain Workspace role from a slug value
- :param slug: slug value as str
- :return: correct workspace role related
- """
- roles = [item for item in list(WorkspaceRoles) if item.slug == slug]
- if len(roles) != 1:
- raise RoleDoesNotExist()
- return roles[0]
|