testutils.py 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. from copy import deepcopy
  2. from hashlib import md5
  3. from misago.core import threadstore
  4. from .forms import get_permissions_forms
  5. def fake_post_data(target, data_dict):
  6. """
  7. In order for form to don't fail submission, all permission fields need
  8. to receive values. This function populates data dict with default values
  9. for permissions, making form validation pass
  10. """
  11. for form in get_permissions_forms(target):
  12. for field in form:
  13. if field.value() is True:
  14. data_dict[field.html_name] = 1
  15. elif field.value() is False:
  16. data_dict[field.html_name] = 0
  17. else:
  18. data_dict[field.html_name] = field.value()
  19. return data_dict
  20. def override_acl(user, new_acl):
  21. """overrides user permissions with specified ones"""
  22. final_cache = deepcopy(user.acl_cache)
  23. final_cache.update(new_acl)
  24. if user.is_authenticated:
  25. user._acl_cache = final_cache
  26. user.acl_key = md5(str(user.pk).encode()).hexdigest()[:8]
  27. user.save(update_fields=['acl_key'])
  28. threadstore.set('acl_%s' % user.acl_key, final_cache)
  29. else:
  30. threadstore.set('acl_%s' % user.acl_key, final_cache)