Commit 941bd506d6ba1e610a850b4ea987469bee12e92a
Exists in
master
and in
39 other branches
Merge branch 'middleware' into 'master'
Middleware
Showing
1 changed file
with
33 additions
and
0 deletions
Show diff stats
... | ... | @@ -0,0 +1,33 @@ |
1 | +from json import dumps as json_dumps | |
2 | + | |
3 | +from colab.accounts.models import User | |
4 | +from colab.proxy.utils.views import ColabProxyView | |
5 | + | |
6 | + | |
7 | +class RemoteUserMiddleware(object): | |
8 | + | |
9 | + def process_view(self, request, view_func, view_args, view_kwargs): | |
10 | + if not request.user.is_authenticated(): | |
11 | + return | |
12 | + | |
13 | + if not hasattr(view_func, 'im_class'): | |
14 | + return | |
15 | + | |
16 | + if not issubclass(view_func.im_class, ColabProxyView): | |
17 | + return | |
18 | + | |
19 | + user = User.objects.get( | |
20 | + username=request.user.get_username() | |
21 | + ) | |
22 | + | |
23 | + remote_user_data = {} | |
24 | + | |
25 | + remote_user_data['EMAIL'] = user.email | |
26 | + remote_user_data['NAME'] = user.username | |
27 | + | |
28 | + request.META['REMOTE_USER_DATA'] = json_dumps( | |
29 | + remote_user_data, | |
30 | + sort_keys=True, | |
31 | + ) | |
32 | + | |
33 | + return None | ... | ... |