| author | ymh <ymh.work@gmail.com> |
| Sat, 11 May 2013 23:09:05 +0200 | |
| changeset 1180 | 54ef33bb4065 |
| parent 1152 | 351782e601e7 |
| parent 1146 | 4491284e73bb |
| child 1191 | b6e0b1811723 |
| 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 |
|
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
|
2 |
from django.contrib.contenttypes.models import ContentType |
|
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.auth.models import User |
| 1152 | 4 |
from django.core.signals import request_started |
| 1146 | 5 |
from ldt.security.permissionchecker import check_object_perm_for_user |
|
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
|
6 |
|
|
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 |
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
|
8 |
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
|
9 |
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
|
10 |
from django.utils._threading_local 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
|
11 |
|
|
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
|
12 |
_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
|
13 |
|
|
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 |
# 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
|
15 |
# 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
|
16 |
# 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
|
17 |
# 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
|
18 |
# |
|
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 |
# 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
|
20 |
# 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
|
21 |
|
|
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 |
_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
|
23 |
|
|
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 |
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
|
25 |
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
|
26 |
|
|
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 |
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
|
28 |
_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
|
29 |
|
|
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 |
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
|
31 |
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
|
32 |
|
|
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 |
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
|
34 |
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
|
35 |
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
|
36 |
|
|
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 |
get_anonymous_user.anonymous_user = User.objects.get(id=settings.ANONYMOUS_USER_ID) |
|
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
|
38 |
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
|
39 |
|
| 384 | 40 |
def get_current_user_or_admin(): |
41 |
current = get_current_user() |
|
42 |
if current: |
|
43 |
return current |
|
|
652
cdbd6d1d8088
correct virtualenv creation + addcommand to reinitialize front projects
ymh <ymh.work@gmail.com>
parents:
517
diff
changeset
|
44 |
admin = User.objects.filter(is_superuser=True)[0] |
| 384 | 45 |
return admin |
46 |
||
|
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
|
47 |
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
|
48 |
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
|
49 |
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
|
50 |
for cls in get_models_to_protect(): |
| 503 | 51 |
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
|
52 |
|
|
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 |
_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
|
54 |
|
|
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 |
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
|
56 |
for cls in get_models_to_protect(): |
| 503 | 57 |
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
|
58 |
|
|
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 |
_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
|
60 |
|
|
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 |
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
|
62 |
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
|
63 |
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
|
64 |
|
|
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 |
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
|
66 |
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
|
67 |
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
|
68 |
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
|
69 |
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
|
70 |
|
|
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 |
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
|
72 |
|
| 384 | 73 |
def protect_model(cls): |
74 |
if not hasattr(cls, 'unsafe_save'): |
|
75 |
cls.unsafe_save = cls.save |
|
76 |
cls.unsafe_delete = cls.delete |
|
77 |
class_name = cls.__name__.lower() |
|
78 |
cls.save = change_security(class_name)(cls.save) |
|
| 503 | 79 |
cls.delete = change_security(class_name)(cls.delete) |
80 |
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
|
81 |
|
| 384 | 82 |
def unprotect_model(cls): |
83 |
if hasattr(cls, 'unsafe_save'): |
|
84 |
cls.save = cls.unsafe_save |
|
85 |
cls.delete = cls.unsafe_delete |
|
86 |
del cls.unsafe_save |
|
87 |
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
|
88 |
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
|
89 |
|
|
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 |
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
|
91 |
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
|
92 |
def wrapped(self, *args, **kwargs): |
| 384 | 93 |
|
|
517
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
94 |
user = get_current_user() |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
95 |
if not user: |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
96 |
user = get_anonymous_user() |
|
2ae1a476a69d
Medias with no annotations are not displayed on front home page
verrierj
parents:
503
diff
changeset
|
97 |
|
| 1146 | 98 |
# use our check_object_perm_for_user instead of not optimized guardian has_perm |
99 |
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
|
100 |
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
|
101 |
|
|
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 |
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
|
103 |
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
|
104 |
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
|
105 |
|
|
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 |
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
|
108 |
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
|
109 |
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
|
110 |
|
|
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 |
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
|
112 |