from django.contrib.auth.models import Group, AbstractUser, BaseUserManager from django.db import models from django.core.validators import MaxValueValidator class CustomUserManager(BaseUserManager): def create_user(self, email, password=None, **extra_fields): if not email: raise ValueError('El email es obligatorio') 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_superuser(self, email, password=None, **extra_fields): extra_fields.setdefault('is_staff', True) extra_fields.setdefault('is_superuser', True) #extra_fields.setdefault('groups', Group.objects.get(name='Super Administrador')) return self.create_user(email, password, **extra_fields) class CustomUser(AbstractUser): email = models.EmailField(unique=True) first_name = models.CharField(max_length=30, blank=True) last_name = models.CharField(max_length=30, blank=True) is_active = models.BooleanField(default=True) is_staff = models.BooleanField(default=False) groups = models.ForeignKey(Group, on_delete=models.CASCADE, null=True, blank=True, verbose_name='rol') USERNAME_FIELD = 'email' REQUIRED_FIELDS = [] objects = CustomUserManager() def __str__(self): if self.last_name and self.first_name: return f'{self.first_name} {self.last_name}' elif self.first_name: return self.first_name elif self.last_name: return self.last_name return self.email