Code source de geonature.core.gn_permissions.decorators
"""Decorators to protects routes with permissions"""fromfunctoolsimportwrapsfromwarningsimportwarnfromflaskimportrequest,gfromwerkzeug.exceptionsimportUnauthorized,Forbiddenfromgeonature.core.gn_permissions.toolsimportget_permissions,get_scopes_by_action# use login_required from flask_loginfromflask_loginimportlogin_required
[docs]def_forbidden_message(action,module_code,object_code):message=f"User {g.current_user.id_role} has no permissions to {action}"ifmodule_code:message+=f" in {module_code}"ifobject_code:message+=f" on {object_code}"returnmessage
[docs]defcheck_cruved_scope(action,module_code=None,object_code=None,*,get_scope=False,):""" Decorator to protect routes with SCOPE CRUVED The decorator first check if the user is connected and then return the max user SCOPE permission for the action in parameter The decorator manages herited CRUVED from user's group and parent module (GeoNature) Parameters ---------- action : str the requested action of the route <'C', 'R', 'U', 'V', 'E', 'D'> module_code : str, optional the code of the module (gn_commons.t_modules) (e.g. 'OCCTAX') for the requested permission, by default None object_code : str, optional the code of the object (gn_permissions.t_object) for the requested permission (e.g. 'PERMISSIONS'), by default None get_scope : bool, optional does the decorator should add the scope to view kwargs, by default False """def_check_cruved_scope(view_func):@wraps(view_func)defdecorated_view(*args,**kwargs):ifnotg.current_user.is_authenticated:raiseUnauthorizedscope=get_scopes_by_action(module_code=module_code,object_code=object_code)[action]ifnotscope:raiseForbidden(description=_forbidden_message(action,module_code,object_code))ifget_scope:kwargs["scope"]=scopereturnview_func(*args,**kwargs)returndecorated_viewreturn_check_cruved_scope