Projet

Général

Profil

Télécharger (2,47 ko) Statistiques
| Branche: | Tag: | Révision:

root / entrouvert / djommon / middleware.py @ 698c4ef1

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
(2-2/4)