django-orchestra/orchestra/apps/users/models.py

93 lines
3.8 KiB
Python
Raw Normal View History

from django.contrib.auth import models as auth
2014-05-08 16:59:35 +00:00
from django.core import validators
2014-09-26 15:05:20 +00:00
from django.core.mail import send_mail
2014-05-08 16:59:35 +00:00
from django.db import models
from django.utils import timezone
2014-05-08 16:59:35 +00:00
from django.utils.translation import ugettext_lazy as _
from orchestra.core import services
class User(auth.AbstractBaseUser):
2014-05-08 16:59:35 +00:00
username = models.CharField(_("username"), max_length=64, unique=True,
help_text=_("Required. 30 characters or fewer. Letters, digits and "
"./-/_ only."),
2014-08-22 15:31:44 +00:00
validators=[validators.RegexValidator(r'^[\w.-]+$',
2014-05-08 16:59:35 +00:00
_("Enter a valid username."), 'invalid')])
2014-09-30 10:20:11 +00:00
account = models.ForeignKey('accounts.Account', verbose_name=_("Account"),
related_name='users')
first_name = models.CharField(_("first name"), max_length=30, blank=True)
last_name = models.CharField(_("last name"), max_length=30, blank=True)
2014-09-30 10:20:11 +00:00
email = models.EmailField(_('email address'), blank=True)
is_superuser = models.BooleanField(_("superuser status"), default=False,
2014-09-30 10:20:11 +00:00
help_text=_("Designates that this user has all permissions without "
"explicitly assigning them."))
is_staff = models.BooleanField(_("staff status"), default=False,
help_text=_("Designates whether the user can log into this admin "
"site."))
is_admin = models.BooleanField(_("admin status"), default=False,
help_text=_("Designates whether the user can administrate its account."))
2014-05-08 16:59:35 +00:00
is_active = models.BooleanField(_("active"), default=True,
help_text=_("Designates whether this user should be treated as "
"active. Unselect this instead of deleting accounts."))
date_joined = models.DateTimeField(_("date joined"), default=timezone.now)
2014-05-08 16:59:35 +00:00
objects = auth.UserManager()
USERNAME_FIELD = 'username'
2014-09-30 10:20:11 +00:00
REQUIRED_FIELDS = ['email']
2014-09-29 14:45:51 +00:00
2014-07-09 16:17:43 +00:00
@property
2014-09-30 10:20:11 +00:00
def is_main(self):
return self.account.user == self
def get_full_name(self):
full_name = '%s %s' % (self.first_name, self.last_name)
return full_name.strip() or self.username
def get_short_name(self):
""" Returns the short name for the user """
return self.first_name
def email_user(self, subject, message, from_email=None, **kwargs):
""" Sends an email to this User """
send_mail(subject, message, from_email, [self.email], **kwargs)
2014-07-09 16:17:43 +00:00
def has_perm(self, perm, obj=None):
"""
Returns True if the user has the specified permission. This method
queries all available auth backends, but returns immediately if any
backend returns True. Thus, a user who has permission from a single
auth backend is assumed to have permission in general. If an object is
provided, permissions for this specific object are checked.
"""
# Active superusers have all permissions.
if self.is_active and self.is_superuser:
return True
# Otherwise we need to check the backends.
return auth._user_has_perm(self, perm, obj)
2014-05-08 16:59:35 +00:00
def has_perms(self, perm_list, obj=None):
2014-05-08 16:59:35 +00:00
"""
Returns True if the user has each of the specified permissions. If
object is passed, it checks if the user has all required perms for this
object.
2014-05-08 16:59:35 +00:00
"""
for perm in perm_list:
if not self.has_perm(perm, obj):
return False
return True
2014-09-29 14:45:51 +00:00
def has_module_perms(self, app_label):
"""
Returns True if the user has any permissions in the given app label.
Uses pretty much the same logic as has_perm, above.
"""
# Active superusers have all permissions.
if self.is_active and self.is_superuser:
return True
return auth._user_has_module_perms(self, app_label)
2014-05-08 16:59:35 +00:00
2014-09-30 10:20:11 +00:00
services.register(User, menu=False)