acl.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. from django import forms
  2. from django.utils.translation import ugettext_lazy as _
  3. from misago.acl.builder import BaseACL
  4. from misago.acl.utils import ACLError404
  5. from misago.forms import YesNoSwitch
  6. def make_form(request, role, form):
  7. form.base_fields['can_search_users'] = forms.BooleanField(widget=YesNoSwitch, initial=False, required=False)
  8. form.base_fields['can_see_users_emails'] = forms.BooleanField(widget=YesNoSwitch, initial=False, required=False)
  9. form.base_fields['can_see_users_trails'] = forms.BooleanField(widget=YesNoSwitch, initial=False, required=False)
  10. form.base_fields['can_see_hidden_users'] = forms.BooleanField(widget=YesNoSwitch, initial=False, required=False)
  11. form.layout.append((
  12. _("User Profiles"),
  13. (
  14. ('can_search_users', {'label': _("Can search user profiles")}),
  15. ('can_see_users_emails', {'label': _("Can see members e-mail's")}),
  16. ('can_see_users_trails', {'label': _("Can see members ip's and user-agents")}),
  17. ('can_see_hidden_users', {'label': _("Can see mebers that hide their presence")}),
  18. ),
  19. ))
  20. class UsersACL(BaseACL):
  21. def can_search_users(self):
  22. return self.acl['can_search_users']
  23. def can_see_users_emails(self):
  24. return self.acl['can_see_users_emails']
  25. def can_see_users_trails(self):
  26. return self.acl['can_see_users_trails']
  27. def can_see_hidden_users(self):
  28. return self.acl['can_see_hidden_users']
  29. def allow_details_view(self):
  30. if not self.acl['can_see_users_trails']:
  31. raise ACLError404()
  32. def build(acl, roles):
  33. acl.users = UsersACL()
  34. acl.users.acl['can_search_users'] = False
  35. acl.users.acl['can_see_users_emails'] = False
  36. acl.users.acl['can_see_users_trails'] = False
  37. acl.users.acl['can_see_hidden_users'] = False
  38. for role in roles:
  39. if 'can_search_users' in role and role['can_search_users']:
  40. acl.users.acl['can_search_users'] = True
  41. if 'can_see_users_emails' in role and role['can_see_users_emails']:
  42. acl.users.acl['can_see_users_emails'] = True
  43. if 'can_see_users_trails' in role and role['can_see_users_trails']:
  44. acl.users.acl['can_see_users_trails'] = True
  45. if 'can_see_hidden_users' in role and role['can_see_hidden_users']:
  46. acl.users.acl['can_see_hidden_users'] = True