Commit f7d7a415 authored by Hugo LEVY-FALK's avatar Hugo LEVY-FALK

Autorise plusieurs apps dans can_view_app

parent 84a901e3
......@@ -248,9 +248,10 @@ def can_view_all(*targets):
return acl_base_decorator('can_view_all', *targets, on_instance=False)
def can_view_app(app_name):
"""Decorator to check if an user can view an application.
def can_view_app(*apps_name):
"""Decorator to check if an user can view the applications.
for app_name in apps_name:
assert app_name in sys.modules.keys()
def decorator(view):
......@@ -259,15 +260,16 @@ def can_view_app(app_name):
def wrapper(request, *args, **kwargs):
"""The wrapper used for a specific request
for app_name in apps_name:
app = sys.modules[app_name]
can, msg = app.can_view(request.user)
if can:
return view(request, *args, **kwargs)
if not can:
messages.error(request, msg)
return redirect(reverse(
kwargs={'userid': str(}
return view(request, *args, **kwargs)
return wrapper
return decorator
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment