Commit | Line | Data |
---|---|---|
e993f3dc | 1 | # -*- encoding: utf-8 -*- |
2 | """ | |
3 | Décorateurs AUF | |
4 | """ | |
5 | from django.contrib.auth.decorators import user_passes_test | |
6 | from django.core.urlresolvers import reverse | |
7 | from django.http import HttpResponseRedirect | |
e993f3dc | 8 | from permissions import is_employe, is_admin |
02c1b3dc JPC |
9 | from django.conf import settings |
10 | from django.contrib.auth import REDIRECT_FIELD_NAME | |
11 | from django.utils.http import urlquote | |
12 | from django.contrib import messages | |
e993f3dc | 13 | |
14 | # Décorateurs des fonctions dans views (pour tester permissions dans views) | |
15 | ||
16 | def admin_required(fn): | |
17 | def inner(request, *args, **kwargs): | |
18 | user = request.user | |
19 | if is_admin(user): | |
20 | return fn(request, *args, **kwargs) | |
21 | else : | |
02c1b3dc | 22 | return redirect_interdiction(request) |
e993f3dc | 23 | return inner |
02c1b3dc JPC |
24 | |
25 | def redirect_interdiction(request, msg=u"Vous n'avez pas accès à cette page"): | |
26 | """ | |
27 | Redirection du la page de login avec un message d'erreur. | |
28 | """ | |
29 | login_url = settings.LOGIN_URL | |
30 | path = urlquote(request.get_full_path()) | |
31 | tup = login_url, REDIRECT_FIELD_NAME, path | |
32 | messages.add_message(request, messages.ERROR, "Votre compte ne permet pas d'accéder à cette partie de l'application.") | |
33 | return HttpResponseRedirect('%s?%s=%s' % tup) | |
34 | ||
35 |