Fixed users permisions
parent
3555c49441
commit
e9e117cdba
|
@ -10,23 +10,28 @@ from greenmine.base.notifications.models import WatcherMixin
|
||||||
|
|
||||||
class User(AbstractUser, WatcherMixin):
|
class User(AbstractUser, WatcherMixin):
|
||||||
color = models.CharField(max_length=9, null=False, blank=True, default="#669933",
|
color = models.CharField(max_length=9, null=False, blank=True, default="#669933",
|
||||||
verbose_name=_('color'))
|
verbose_name=_("color"))
|
||||||
description = models.TextField(null=False, blank=True,
|
description = models.TextField(null=False, blank=True,
|
||||||
verbose_name=_('description'))
|
verbose_name=_("description"))
|
||||||
photo = models.FileField(upload_to='files/msg', max_length=500, null=True, blank=True,
|
photo = models.FileField(upload_to="files/msg", max_length=500, null=True, blank=True,
|
||||||
verbose_name=_('photo'))
|
verbose_name=_("photo"))
|
||||||
default_language = models.CharField(max_length=20, null=False, blank=True, default='',
|
default_language = models.CharField(max_length=20, null=False, blank=True, default="",
|
||||||
verbose_name=_('default language'))
|
verbose_name=_("default language"))
|
||||||
default_timezone = models.CharField(max_length=20, null=False, blank=True, default='',
|
default_timezone = models.CharField(max_length=20, null=False, blank=True, default="",
|
||||||
verbose_name=_('default timezone'))
|
verbose_name=_("default timezone"))
|
||||||
token = models.CharField(max_length=200, null=True, blank=True, default=None,
|
token = models.CharField(max_length=200, null=True, blank=True, default=None,
|
||||||
verbose_name=_('token'))
|
verbose_name=_("token"))
|
||||||
colorize_tags = models.BooleanField(null=False, blank=True, default=False,
|
colorize_tags = models.BooleanField(null=False, blank=True, default=False,
|
||||||
verbose_name=_('colorize tags'))
|
verbose_name=_("colorize tags"))
|
||||||
objects = UserManager()
|
objects = UserManager()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
verbose_name = "user"
|
||||||
|
verbose_name_plural = "users"
|
||||||
ordering = ["username"]
|
ordering = ["username"]
|
||||||
|
permissions = (
|
||||||
|
("view_user", "Can view user"),
|
||||||
|
)
|
||||||
|
|
||||||
def get_full_name(self):
|
def get_full_name(self):
|
||||||
return super().get_full_name() or self.username or self.email
|
return super().get_full_name() or self.username or self.email
|
||||||
|
@ -34,19 +39,22 @@ class User(AbstractUser, WatcherMixin):
|
||||||
|
|
||||||
class Role(models.Model):
|
class Role(models.Model):
|
||||||
name = models.CharField(max_length=200, null=False, blank=False,
|
name = models.CharField(max_length=200, null=False, blank=False,
|
||||||
verbose_name=_('name'))
|
verbose_name=_("name"))
|
||||||
slug = models.SlugField(max_length=250, unique=True, null=False, blank=True,
|
slug = models.SlugField(max_length=250, unique=True, null=False, blank=True,
|
||||||
verbose_name=_('slug'))
|
verbose_name=_("slug"))
|
||||||
permissions = models.ManyToManyField('auth.Permission', related_name='roles',
|
permissions = models.ManyToManyField("auth.Permission", related_name="roles",
|
||||||
verbose_name=_('permissions'))
|
verbose_name=_("permissions"))
|
||||||
order = models.IntegerField(default=10, null=False, blank=False,
|
order = models.IntegerField(default=10, null=False, blank=False,
|
||||||
verbose_name=_("order"))
|
verbose_name=_("order"))
|
||||||
computable = models.BooleanField(default=True)
|
computable = models.BooleanField(default=True)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name = 'role'
|
verbose_name = "role"
|
||||||
verbose_name_plural = 'roles'
|
verbose_name_plural = "roles"
|
||||||
ordering = ['order', 'slug']
|
ordering = ["order", "slug"]
|
||||||
|
permissions = (
|
||||||
|
("view_role", "Can view role"),
|
||||||
|
)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
@ -55,7 +63,7 @@ class Role(models.Model):
|
||||||
# On Role object is changed, update all membership
|
# On Role object is changed, update all membership
|
||||||
# related to current role.
|
# related to current role.
|
||||||
@receiver(models.signals.post_save, sender=Role,
|
@receiver(models.signals.post_save, sender=Role,
|
||||||
dispatch_uid='role_post_save')
|
dispatch_uid="role_post_save")
|
||||||
def role_post_save(sender, instance, created, **kwargs):
|
def role_post_save(sender, instance, created, **kwargs):
|
||||||
# ignore if object is just created
|
# ignore if object is just created
|
||||||
if created:
|
if created:
|
||||||
|
|
Loading…
Reference in New Issue