| author | ymh <ymh.work@gmail.com> |
| Wed, 15 Jul 2015 15:43:52 +0200 | |
| changeset 1384 | c9f9dfa39005 |
| parent 1362 | df60d20f965c |
| child 1407 | fc9654218d53 |
| permissions | -rw-r--r-- |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
1 |
from django.conf import settings |
| 1191 | 2 |
from django.contrib.auth import get_user_model |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
3 |
from django.contrib.contenttypes.models import ContentType |
| 1152 | 4 |
from django.core.signals import request_started |
| 1191 | 5 |
from ldt.security.permissionchecker import check_object_perm_for_user |
6 |
||
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
7 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
8 |
try: |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
9 |
from threading import local |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
10 |
except ImportError: |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
11 |
from django.utils._threading_local import local |
|
1362
df60d20f965c
Starting upgrading to Django 1.7: removed module-level get_user_model() calls to adjust for new models loading flow + replaced WSFIHandler() with get_wsgi_application()
ndurand
parents:
1191
diff
changeset
|
12 |
|
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
13 |
_thread_locals = local() |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
14 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
15 |
# The function that protect models is called on the first |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
16 |
# HTTP request sent to the server (see function protect_models_request |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
17 |
# in this file), and can not be called in this file directly |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
18 |
# because of circular import. |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
19 |
# |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
20 |
# To protect models from command line, use set_current_user(my_user) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
21 |
# and protect_models(). |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
22 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
23 |
_models_are_protected = False |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
24 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
25 |
def get_current_user(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
26 |
return getattr(_thread_locals, 'user', None) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
27 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
28 |
def set_current_user(user): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
29 |
_thread_locals.user = user |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
30 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
31 |
def del_current_user(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
32 |
del _thread_locals.user |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
33 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
34 |
def get_anonymous_user(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
35 |
if hasattr(get_anonymous_user, 'anonymous_user'): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
36 |
return get_anonymous_user.anonymous_user |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
37 |
|
|
1362
df60d20f965c
Starting upgrading to Django 1.7: removed module-level get_user_model() calls to adjust for new models loading flow + replaced WSFIHandler() with get_wsgi_application()
ndurand
parents:
1191
diff
changeset
|
38 |
get_anonymous_user.anonymous_user = get_user_model().objects.get(id=settings.ANONYMOUS_USER_ID) |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
39 |
return get_anonymous_user.anonymous_user |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
40 |
|
| 384 | 41 |
def get_current_user_or_admin(): |
42 |
current = get_current_user() |
|
43 |
if current: |
|
44 |
return current |
|
|
1362
df60d20f965c
Starting upgrading to Django 1.7: removed module-level get_user_model() calls to adjust for new models loading flow + replaced WSFIHandler() with get_wsgi_application()
ndurand
parents:
1191
diff
changeset
|
45 |
admin = get_user_model().objects.filter(is_superuser=True)[0] |
| 384 | 46 |
return admin |
47 |
||
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
48 |
def protect_models(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
49 |
cls_list = get_models_to_protect() |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
50 |
if cls_list: |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
51 |
for cls in get_models_to_protect(): |
| 503 | 52 |
protect_model(cls) |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
53 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
54 |
_models_are_protected = True |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
55 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
56 |
def unprotect_models(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
57 |
for cls in get_models_to_protect(): |
| 503 | 58 |
unprotect_model(cls) |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
59 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
60 |
_models_are_protected = False |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
61 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
62 |
def get_models_to_protect(): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
63 |
if hasattr(get_models_to_protect, 'cls_list'): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
64 |
return get_models_to_protect.cls_list |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
65 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
66 |
cls_list = [] |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
67 |
for cls_name in settings.USE_GROUP_PERMISSIONS: |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
68 |
cls_type = ContentType.objects.get(model=cls_name.lower()) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
69 |
cls_list.append(cls_type.model_class()) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
70 |
get_models_to_protect.cls_list = cls_list |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
71 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
72 |
return cls_list |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
73 |
|
| 384 | 74 |
def protect_model(cls): |
75 |
if not hasattr(cls, 'unsafe_save'): |
|
76 |
cls.unsafe_save = cls.save |
|
77 |
cls.unsafe_delete = cls.delete |
|
78 |
class_name = cls.__name__.lower() |
|
79 |
cls.save = change_security(class_name)(cls.save) |
|
| 503 | 80 |
cls.delete = change_security(class_name)(cls.delete) |
81 |
cls.safe_objects.check_perm = True |
|
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
82 |
|
| 384 | 83 |
def unprotect_model(cls): |
84 |
if hasattr(cls, 'unsafe_save'): |
|
85 |
cls.save = cls.unsafe_save |
|
86 |
cls.delete = cls.unsafe_delete |
|
87 |
del cls.unsafe_save |
|
88 |
del cls.unsafe_delete |
|
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
89 |
cls.safe_objects.check_perm = False |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
90 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
91 |
def change_security(cls_name): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
92 |
def wrapper(func): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
93 |
def wrapped(self, *args, **kwargs): |
| 384 | 94 |
|
|
517
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
95 |
user = get_current_user() |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
96 |
if not user: |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
97 |
user = get_anonymous_user() |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
98 |
|
| 1146 | 99 |
# use our check_object_perm_for_user instead of not optimized guardian has_perm |
100 |
if self.pk and not check_object_perm_for_user(self, 'change_%s' % cls_name, user): |
|
|
517
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
101 |
raise AttributeError('User %s is not allowed to change object %s' % (user, self)) |
|
350
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
102 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
103 |
return func(self, *args, **kwargs) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
104 |
return wrapped |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
105 |
return wrapper |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
106 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
107 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
108 |
def protect_models_request(sender, **kwargs): |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
109 |
if not _models_are_protected: |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
110 |
protect_models() |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
111 |
|
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
112 |
request_started.connect(protect_models_request) |
|
c6953232099f
Anonymous users can see pages even if they are not logged in + factor code to decrease number of SQL requests
verrierj
parents:
239
diff
changeset
|
113 |