1
|
from django.http import HttpResponse
|
2
|
import json
|
3
|
|
4
|
from entrouvert.wsgi import middleware
|
5
|
|
6
|
'''Version middleware to retrieves Entr'ouvert packages versions'''
|
7
|
|
8
|
class VersionMiddleware:
|
9
|
def process_request(self, request):
|
10
|
if request.method == 'GET' and (request.path == '/__version__' or
|
11
|
request.path == '/__version__/'):
|
12
|
packages_version = middleware.VersionMiddleware.get_packages_version()
|
13
|
return HttpResponse(json.dumps(packages_version),
|
14
|
content_type='application/json')
|
15
|
return None
|
16
|
|
17
|
# copied from http://stackoverflow.com/questions/9294043/include-django-logged-user-in-django-traceback-error
|
18
|
|
19
|
class UserInTracebackMiddleware(object):
|
20
|
"""
|
21
|
Adds user details to request context during request processing, so that they
|
22
|
show up in the error emails. Add to settings.MIDDLEWARE_CLASSES and keep it
|
23
|
outermost(i.e. on top if possible). This allows it to catch exceptions in
|
24
|
other middlewares as well.
|
25
|
"""
|
26
|
|
27
|
def process_exception(self, request, exception):
|
28
|
"""
|
29
|
Process the request to add some variables to it.
|
30
|
"""
|
31
|
|
32
|
# Add other details about the user to the META CGI variables.
|
33
|
try:
|
34
|
if not request.user.is_authenticated():
|
35
|
return
|
36
|
if request.user.is_anonymous():
|
37
|
request.META['AUTH_NAME'] = "Anonymous User"
|
38
|
request.META['AUTH_USER'] = "Anonymous User"
|
39
|
request.META['AUTH_USER_EMAIL'] = ""
|
40
|
request.META['AUTH_USER_ID'] = 0
|
41
|
request.META['AUTH_USER_IS_ACTIVE'] = False
|
42
|
request.META['AUTH_USER_IS_SUPERUSER'] = False
|
43
|
request.META['AUTH_USER_IS_STAFF'] = False
|
44
|
request.META['AUTH_USER_LAST_LOGIN'] = ""
|
45
|
else:
|
46
|
request.META['AUTH_USER_ID'] = str(request.user.id)
|
47
|
request.META['AUTH_NAME'] = str(request.user.first_name) + " " + str(request.user.last_name)
|
48
|
request.META['AUTH_USER'] = str(request.user.username)
|
49
|
request.META['AUTH_USER_EMAIL'] = str(request.user.email)
|
50
|
request.META['AUTH_USER_IS_ACTIVE'] = str(request.user.is_active)
|
51
|
request.META['AUTH_USER_IS_SUPERUSER'] = str(request.user.is_superuser)
|
52
|
request.META['AUTH_USER_IS_STAFF'] = str(request.user.is_staff)
|
53
|
request.META['AUTH_USER_LAST_LOGIN'] = str(request.user.last_login)
|
54
|
except:
|
55
|
pass
|