Révision 16caa784
Ajouté par Benjamin Dauvergne il y a plus de 10 ans
entrouvert/djommon/middleware.py | ||
---|---|---|
12 | 12 |
return HttpResponse(json.dumps(packages_version), |
13 | 13 |
content_type='application/json') |
14 | 14 |
return None |
15 |
|
|
16 |
# copied from http://stackoverflow.com/questions/9294043/include-django-logged-user-in-django-traceback-error |
|
17 |
|
|
18 |
class UserInTracebackMiddleware(object): |
|
19 |
""" |
|
20 |
Adds user details to request context during request processing, so that they |
|
21 |
show up in the error emails. Add to settings.MIDDLEWARE_CLASSES and keep it |
|
22 |
outermost(i.e. on top if possible). This allows it to catch exceptions in |
|
23 |
other middlewares as well. |
|
24 |
""" |
|
25 |
|
|
26 |
def process_exception(self, request, exception): |
|
27 |
""" |
|
28 |
Process the request to add some variables to it. |
|
29 |
""" |
|
30 |
|
|
31 |
# Add other details about the user to the META CGI variables. |
|
32 |
try: |
|
33 |
if not request.user.is_authenticated(): |
|
34 |
return |
|
35 |
if request.user.is_anonymous(): |
|
36 |
request.META['AUTH_NAME'] = "Anonymous User" |
|
37 |
request.META['AUTH_USER'] = "Anonymous User" |
|
38 |
request.META['AUTH_USER_EMAIL'] = "" |
|
39 |
request.META['AUTH_USER_ID'] = 0 |
|
40 |
request.META['AUTH_USER_IS_ACTIVE'] = False |
|
41 |
request.META['AUTH_USER_IS_SUPERUSER'] = False |
|
42 |
request.META['AUTH_USER_IS_STAFF'] = False |
|
43 |
request.META['AUTH_USER_LAST_LOGIN'] = "" |
|
44 |
else: |
|
45 |
request.META['AUTH_USER_ID'] = str(request.user.id) |
|
46 |
request.META['AUTH_NAME'] = str(request.user.first_name) + " " + str(request.user.last_name) |
|
47 |
request.META['AUTH_USER'] = str(request.user.username) |
|
48 |
request.META['AUTH_USER_EMAIL'] = str(request.user.email) |
|
49 |
request.META['AUTH_USER_IS_ACTIVE'] = str(request.user.is_active) |
|
50 |
request.META['AUTH_USER_IS_SUPERUSER'] = str(request.user.is_superuser) |
|
51 |
request.META['AUTH_USER_IS_STAFF'] = str(request.user.is_staff) |
|
52 |
request.META['AUTH_USER_LAST_LOGIN'] = str(request.user.last_login) |
|
53 |
except: |
|
54 |
pass |
Formats disponibles : Unified diff
djommon: add a UserInTracebackMiddleware
This middleware class add information on the currently logged in user to
request.META effectively logging them in the traceback.