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

101 lines
4.3 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
2014-09-29 14:45:51 +00:00
from . import settings
2014-05-08 16:59:35 +00:00
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')])
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)
email = models.EmailField(_("email address"), blank=True)
is_superuser = models.BooleanField(_("superuser status"), default=False,
help_text=_("Designates that this user has all permissions without "
"explicitly assigning them."))
is_main = models.BooleanField(_("is main"), default=False)
# system_password = models.CharField(_("system password"), max_length=128)
2014-09-29 14:45:51 +00:00
home = models.CharField(_("home"), max_length=256, blank=True,
help_text=_("Home directory relative to account's ~primary_user"))
shell = models.CharField(_("shell"), max_length=32,
choices=settings.USERS_SHELLS, default=settings.USERS_DEFAULT_SHELL)
groups = models.ManyToManyField('self', blank=True,
2014-09-29 14:45:51 +00:00
help_text=_("A new group will be created for the user. "
"Which additional groups would you like them to be a member of?"))
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'
REQUIRED_FIELDS = []
2014-09-29 14:45:51 +00:00
2014-07-09 16:17:43 +00:00
@property
def is_staff(self):
return self.is_superuser or self.is_main
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)
#
# def set_system_password(self, raw_password):
# self.system_password = make_password(raw_password)
2014-05-08 16:59:35 +00:00
services.register(User)