summaryrefslogtreecommitdiff
path: root/ishtar_common/models.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2018-04-10 17:55:23 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2018-06-12 08:39:42 +0200
commita434d1410714d2758636936cfac820179b710610 (patch)
treecff8bbeb899c5380a3a1c09bdee06c3ed0f94eac /ishtar_common/models.py
parent478bef4100f4b18553a74e79fbacc2ffec695d7c (diff)
downloadIshtar-a434d1410714d2758636936cfac820179b710610.tar.bz2
Ishtar-a434d1410714d2758636936cfac820179b710610.zip
Permission management is now done via profile (refs #4046)
Diffstat (limited to 'ishtar_common/models.py')
-rw-r--r--ishtar_common/models.py32
1 files changed, 23 insertions, 9 deletions
diff --git a/ishtar_common/models.py b/ishtar_common/models.py
index a6fc8722d..3eceb8df0 100644
--- a/ishtar_common/models.py
+++ b/ishtar_common/models.py
@@ -2558,28 +2558,42 @@ class Person(Address, Merge, OwnPerms, ValueGetter):
res = cache.get(cache_key)
if res in (True, False):
return res
+ # list all cache key in order to clean them on profiel change
+ cache_key_list = 'sessionlist-{}'.format(session.session_key)
+ key_list = cache.get(cache_key_list, [])
+ key_list.append(cache_key)
+ cache.set(cache_key_list, key_list, settings.CACHE_TIMEOUT)
if type(right_name) in (list, tuple):
- res = bool(self.person_types.filter(
- txt_idx__in=right_name).count()) or \
- bool(self.person_types.filter(
- groups__permissions__codename__in=right_name).count()) or\
+ res = bool(
+ self.profiles.filter(
+ current=True,
+ profile_type__txt_idx__in=right_name
+ ).count()) or \
+ bool(self.profiles.filter(
+ current=True,
+ profile_type__groups__permissions__codename__in=right_name
+ ).count()) or \
bool(self.ishtaruser.user_ptr.groups.filter(
permissions__codename__in=right_name
).count()) or\
bool(self.ishtaruser.user_ptr.user_permissions.filter(
codename__in=right_name).count())
- # or self.person_types.filter(wizard__url_name__in=right_name).count())
else:
- res = bool(self.person_types.filter(txt_idx=right_name).count()) or\
- bool(self.person_types.filter(
- groups__permissions__codename=right_name).count()) or \
+ res = bool(
+ self.profiles.filter(
+ current=True,
+ profile_type__txt_idx__in=right_name
+ ).count()) or \
+ bool(self.profiles.filter(
+ current=True,
+ profile_type__groups__permissions__codename=right_name
+ ).count()) or \
bool(self.ishtaruser.user_ptr.groups.filter(
permissions__codename__in=[right_name]
).count()) or \
bool(self.ishtaruser.user_ptr.user_permissions.filter(
codename__in=[right_name]).count())
- # or self.person_types.filter(wizard__url_name=right_name).count())
if session:
cache.set(cache_key, res, settings.CACHE_TIMEOUT)
return res