diff options
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 |
commit | a434d1410714d2758636936cfac820179b710610 (patch) | |
tree | cff8bbeb899c5380a3a1c09bdee06c3ed0f94eac /ishtar_common/models.py | |
parent | 478bef4100f4b18553a74e79fbacc2ffec695d7c (diff) | |
download | Ishtar-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.py | 32 |
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 |