rolemodel.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. from django.db import models
  2. from django.utils.translation import ugettext as _
  3. import base64
  4. try:
  5. import cPickle as pickle
  6. except ImportError:
  7. import pickle
  8. class Role(models.Model):
  9. """
  10. Misago User Role model
  11. """
  12. name = models.CharField(max_length=255)
  13. _special = models.CharField(db_column='special', max_length=255,null=True,blank=True)
  14. protected = models.BooleanField(default=False)
  15. _permissions = models.TextField(db_column='permissions', null=True, blank=True)
  16. permissions_cache = {}
  17. class Meta:
  18. app_label = 'misago'
  19. def __unicode__(self):
  20. return unicode(_(self.name))
  21. @property
  22. def special(self):
  23. return self._special
  24. @property
  25. def permissions(self):
  26. if self.permissions_cache:
  27. return self.permissions_cache
  28. try:
  29. self.permissions_cache = pickle.loads(base64.decodestring(self._permissions))
  30. except Exception:
  31. # ValueError, SuspiciousOperation, unpickling exceptions. If any of
  32. # these happen, just return an empty dictionary (an empty permissions list).
  33. self.permissions_cache = {}
  34. return self.permissions_cache
  35. @permissions.setter
  36. def permissions(self, permissions):
  37. self.permissions_cache = permissions
  38. self._permissions = base64.encodestring(pickle.dumps(permissions, pickle.HIGHEST_PROTOCOL))