| author | ymh <ymh.work@gmail.com> |
| Tue, 25 Jul 2017 19:11:26 +0200 | |
| changeset 128 | 34a75bd8d0b9 |
| permissions | -rw-r--r-- |
|
128
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
1 |
""" |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
2 |
Taken from https://gist.github.com/AndrewJHart/9bb9eaea2523cd2144cf959f48a14194 |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
3 |
and https://github.com/GetBlimp/django-rest-framework-jwt/issues/45#issuecomment-255383031 |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
4 |
""" |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
5 |
from django.contrib.auth.middleware import get_user |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
6 |
from django.contrib.auth.models import AnonymousUser |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
7 |
from django.utils.functional import SimpleLazyObject |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
8 |
from rest_framework_jwt.authentication import JSONWebTokenAuthentication |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
9 |
from rest_framework import exceptions |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
10 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
11 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
12 |
def get_user_jwt(request): |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
13 |
""" |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
14 |
Replacement for django session auth get_user & auth.get_user for |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
15 |
JSON Web Token authentication. Inspects the token for the user_id, |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
16 |
attempts to get that user from the DB & assigns the user on the |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
17 |
request object. Otherwise it defaults to AnonymousUser. |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
18 |
This will work with existing decorators like LoginRequired, whereas |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
19 |
the standard restframework_jwt auth only works at the view level |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
20 |
forcing all authenticated users to appear as AnonymousUser ;) |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
21 |
Returns: instance of user object or AnonymousUser object |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
22 |
""" |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
23 |
user = get_user(request) |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
24 |
if user.is_authenticated: |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
25 |
return user |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
26 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
27 |
jwt_authentication = JSONWebTokenAuthentication() |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
28 |
if jwt_authentication.get_jwt_value(request): |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
29 |
try: |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
30 |
user, _ = jwt_authentication.authenticate(request) |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
31 |
except exceptions.AuthenticationFailed: |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
32 |
user = None |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
33 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
34 |
return user or AnonymousUser() |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
35 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
36 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
37 |
class JWTAuthenticationMiddleware(object): |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
38 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
39 |
def __init__(self, get_response): |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
40 |
self.get_response = get_response |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
41 |
# One-time configuration and initialization. |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
42 |
|
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
43 |
def __call__(self, request): |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
44 |
request.user = SimpleLazyObject(lambda: get_user_jwt(request)) |
|
34a75bd8d0b9
add filter on session and node list to recover specific objects
ymh <ymh.work@gmail.com>
parents:
diff
changeset
|
45 |
return self.get_response(request) |