diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-07 12:22:27 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-07 12:22:27 +0200 |
commit | 93364489ab4e6daf16f924b2d8212f7fcdc5e477 (patch) | |
tree | e0686c289c399330f414b50ff8ef58f642833db2 /ishtar_common/menu_base.py | |
parent | c788bef47de6bca5dda5dd1fa67dd6a2ac02e9b9 (diff) | |
parent | a8271676a0598594762cc53e4f577337eb275313 (diff) | |
download | Ishtar-93364489ab4e6daf16f924b2d8212f7fcdc5e477.tar.bz2 Ishtar-93364489ab4e6daf16f924b2d8212f7fcdc5e477.zip |
Merge branch 'v0.9' into wheezy
Diffstat (limited to 'ishtar_common/menu_base.py')
-rw-r--r-- | ishtar_common/menu_base.py | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/ishtar_common/menu_base.py b/ishtar_common/menu_base.py index 0117b375d..c6d02daa5 100644 --- a/ishtar_common/menu_base.py +++ b/ishtar_common/menu_base.py @@ -87,18 +87,22 @@ class MenuItem: return False if not self.access_controls: return True + if not hasattr(user, 'ishtaruser'): + return False + # manage by specific idx - person type + if user.ishtaruser.has_right(self.idx, session=session): + return True prefix = (self.model._meta.app_label + '.') if self.model else '' for access_control in self.access_controls: + # check by person type + if user.ishtaruser.has_right(access_control, session=session): + return True access_control = prefix + access_control - if hasattr(user, 'ishtaruser') and \ - user.ishtaruser.has_perm(access_control, self.model, - session=session) or \ + # check by specific access control + if user.ishtaruser.has_perm(access_control, self.model, + session=session) or \ access_control in user.get_group_permissions(): return True - # manage by person type - if hasattr(user, 'ishtaruser'): - if user.ishtaruser.has_right(self.idx, session=session): - return True return False def is_available(self, user, obj=None, session=None): |