Acabo de veure un article que parla un moment d'extendre l'usuari propi de Django, i en les definicions de create_user i create_superuser pren un enfocament quasi igual que el nostre però afegint-li un petit refactor que crec que deixaria el codi més maco.
El codi en qüestió que fa servir és aquest:
from django.db import models
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin, UserManager
from django.utils import timezone
class CustomUserManager(UserManager):
def _create_user(self, email, password, **extra_fields):
"""
Create and save a User with the provided email and password.
"""
if not email:
raise ValueError("The given email address must be set")
email = self.normalize_email(email)
user = self.model(email=email, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, email=None, password=None, **extra_fields):
extra_fields.setdefault("is_staff", False)
extra_fields.setdefault("is_superuser", False)
return self._create_user(email, password, **extra_fields)
def create_superuser(self, email, password, **extra_fields):
extra_fields.setdefault("is_staff", True)
extra_fields.setdefault("is_superuser", True)
if extra_fields.get("is_staff") is not True:
raise ValueError("Superuser must have is_staff=True.")
if extra_fields.get("is_superuser") is not True:
raise ValueError("Superuser must have is_superuser=True.")
return self._create_user(email, password, **extra_fields)
class User(AbstractBaseUser, PermissionsMixin):
"""
User model that uses email addresses instead of usernames, and
name instead of first / last name fields.
All other fields from the Django auth.User model are kept to
ensure compatibility with the built in management commands.
"""
email = models.EmailField(blank=True, default="", unique=True)
name = models.CharField(max_length=200, blank=True, default="")
is_active = models.BooleanField(default=True)
is_staff = models.BooleanField(default=False)
is_superuser = models.BooleanField(default=False)
last_login = models.DateTimeField(blank=True, null=True)
date_joined = models.DateTimeField(default=timezone.now)
objects = CustomUserManager()
USERNAME_FIELD = "email"
EMAIL_FIELD = "email"
REQUIRED_FIELDS = []
class Meta:
verbose_name = "User"
verbose_name_plural = "Users"
def get_full_name(self):
return self.name
def get_short_name(self):
return self.name or self.email.split("@")[0]
Ho deixo per aquí per quan fem la pròxima actualització del boilerplate, i també per discutir si us interessa incorporar idees que venen d'aquí o no.
Acabo de veure un article que parla un moment d'extendre l'usuari propi de Django, i en les definicions de
create_user
icreate_superuser
pren un enfocament quasi igual que el nostre però afegint-li un petit refactor que crec que deixaria el codi més maco.El codi en qüestió que fa servir és aquest:
Ho deixo per aquí per quan fem la pròxima actualització del boilerplate, i també per discutir si us interessa incorporar idees que venen d'aquí o no.