Custom User Model создает дополнительные группы и таблицу разрешений - PullRequest
0 голосов
/ 13 апреля 2019

Я использую Django 2.2

Я создал модель Custom User, унаследовав от AbstractUser.Наряду с этим я также создаю UserManager.

# ./settings.py

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django_extensions',
    'rest_framework',
    'core.apps.AuthConfig'
]
AUTH_USER_MODEL = 'core.User'

# ./core/models.py

class User(AbstractUser):
    email = models.EmailField(_('email address'), unique=True)

    REQUIRED_FIELDS = ['first_name', 'last_name']
    USERNAME_FIELD = 'email'

    objects = UserManager()

# ./core/managers.py
class UserManager(BaseUserManager):
    def create_user(self, email, password=None, **kwargs):
        if not email:
            raise ValueError('Email field is required')
        email = self.normalize_email(email)
        user = self.model(email=email, **kwargs)
        user.set_password(password)
        user.save()
        return user

    def create_superuser(self, email, password, **extra_fields):
        extra_fields.setdefault('is_staff', True)
        extra_fields.setdefault('is_superuser', True)
        extra_fields.setdefault('is_active', True)
        return self.create_user(email, password, **extra_fields)

Когда я запускаю:

  • ./manage.py makemigrations
  • ./manage.py migrate

Я получаю дополнительные таблицы, созданные в моей базе данных, связанные с группами и разрешениями.

enter image description here

Какова цель этого?Я делаю что-то неправильно?

Я попытался создать группу в админке Django и назначил ей несколько разрешений.Используются только таблицы auth_group и auth_group_permissions.

1 Ответ

1 голос
/ 13 апреля 2019

Эти модели получены из полей ManyToMany, определенных в PermissionsMixin , который наследуется AbstractUser , который наследуется вашей пользовательской Пользовательской моделью.

groups = models.ManyToManyField(
    Group,
    verbose_name=_('groups'),
    blank=True,
    help_text=_(
        'The groups this user belongs to. A user will get all permissions '
        'granted to each of their groups.'
    ),
    related_name="user_set",
    related_query_name="user",
)
user_permissions = models.ManyToManyField(
    Permission,
    verbose_name=_('user permissions'),
    blank=True,
    help_text=_('Specific permissions for this user.'),
    related_name="user_set",
    related_query_name="user",
)

Как можно видеть здесь, groups сохраняют отношения между пользователем и группой, а user_permissions сохраняют определенные разрешения для пользователя, непосредственно связанные с пользователем (не через группы) ,

Если они вам не нужны, вы можете определить свою модель пользователя на основе AbstractBaseUser class.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...