1 | from django.shortcuts import redirect
|
---|
2 | from django.urls import resolve
|
---|
3 | from django.conf import settings
|
---|
4 |
|
---|
5 |
|
---|
6 | class ReplaceAuthMiddleware:
|
---|
7 | def __init__(self, get_response):
|
---|
8 | self.get_response = get_response
|
---|
9 | self.unauthorized_urls_for_logged_user = settings.REPLACE_URL_IF_LOGGED["replace"]
|
---|
10 | self.unauthorized_urls_for_unlogged_user = settings.REPLACE_URL_IF_UNLOGGED["replace"]
|
---|
11 | self.redirect_url_for_unauthorized_logged_user = settings.REPLACE_URL_IF_LOGGED["by"]
|
---|
12 | self.redirect_url_for_unauthorized_unlogged_user = settings.REPLACE_URL_IF_UNLOGGED["by"]
|
---|
13 |
|
---|
14 | def __call__(self, request):
|
---|
15 |
|
---|
16 | # Before the response of the view changes, checks if the url is authorized or not.
|
---|
17 | if self.unauthorized_url_for_logged_user(request):
|
---|
18 | return redirect(self.redirect_url_for_unauthorized_logged_user)
|
---|
19 | elif self.unauthorized_url_for_unlogged_user(request):
|
---|
20 | return redirect(self.redirect_url_for_unauthorized_unlogged_user)
|
---|
21 |
|
---|
22 | # Get the response of the view.
|
---|
23 | response = self.get_response(request)
|
---|
24 |
|
---|
25 | # After the response of the view changes, checks if the url is authorized or not.
|
---|
26 | if self.unauthorized_url_for_logged_user(request):
|
---|
27 | return redirect(self.redirect_url_for_unauthorized_logged_user)
|
---|
28 | elif self.unauthorized_url_for_unlogged_user(request):
|
---|
29 | return redirect(self.redirect_url_for_unauthorized_unlogged_user)
|
---|
30 |
|
---|
31 | # Return the default response of the view if no redirection is needed.
|
---|
32 | return response
|
---|
33 |
|
---|
34 | @staticmethod
|
---|
35 | def user_is_logged(request):
|
---|
36 | return hasattr(request, 'user') and request.user.is_authenticated
|
---|
37 |
|
---|
38 | def unauthorized_url_for_unlogged_user(self, request):
|
---|
39 | return not self.user_is_logged(request) and resolve(
|
---|
40 | request.path_info).url_name in self.unauthorized_urls_for_unlogged_user
|
---|
41 |
|
---|
42 | def unauthorized_url_for_logged_user(self, request):
|
---|
43 | return self.user_is_logged(request) and resolve(
|
---|
44 | request.path_info).url_name in self.unauthorized_urls_for_logged_user
|
---|