Редактируем User-модель в Django с помощью класса AbstractUser | OTUS
⚡ Открываем подписку на курсы!
Проходите параллельно 3 онлайн-курса в месяц по цене одного.
Подробнее

Курсы

Программирование
iOS Разработчик. Продвинутый курс Программист 1С Реверс-инжиниринг. Продвинутый курс
-16%
Java Developer. Professional
-17%
JavaScript Developer. Professional
-18%
Flutter Mobile Developer
-15%
MS SQL Server Developer
-14%
Unity Game Developer. Basic
-19%
Супер-практикум по использованию и настройке GIT
-18%
Супер-интенсив "СУБД в высоконагруженных системах"
-18%
Web-разработчик на Python
-11%
Backend-разработчик на PHP
-8%
PostgreSQL
-10%
Базы данных
-19%
Android-разработчик. Базовый курс Разработчик Python. Продвинутый курс Разработчик на Spring Framework AWS для разработчиков Cloud Solution Architecture CI/CD Vue.js разработчик Разработчик Node.js Scala-разработчик Супер - интенсив по Kubernetes Symfony Framework Advanced Fullstack JavaScript developer
Специализации Курсы в разработке Подготовительные курсы
+7 499 938-92-02

Редактируем User-модель в Django с помощью класса AbstractUser

Python_Deep_14.08_SIte.png

При работе с Django часто приходят задачи по изменению стандартного поведения юзера. В большинстве случаев, это заканчивается расширением полей, которое все привыкли делать через 1-1 и отказываются реализовывать по-другому. Но начиная с версии 1.7, Django предоставляет новые механизмы по работе с этим. Их два – AbstractUser и AbstractBaseUser.

AbstractUser поможет быстро добавить поля в custom пользователя.

from django.contrib.auth.models import AbstractUser

class User(AbstractUser):
    bio = models.TextField(max_length=500, blank=True)
    location = models.CharField(max_length=30, blank=True)
    birth_date = models.DateField(null=True, blank=True)

А редактирование AbstractBaseUser поможет изменить пользователя полностью. Например, отказаться от полей или отредактировать уникальный идентификатор. В идеале, это решение должно быть принято на старте проекта, так как оно существенно повлияет на схему базы данных.

class User(AbstractBaseUser):
    identifier = models.CharField(max_length=40, unique=True)
    ...
    USERNAME_FIELD = "identifier"

Не забывайте добавить в настройки нового юзера:

AUTH_USER_MODEL = 'core.User'

А для изменения поведения при аутентификации можно использовать стандартные ручки.

AUTHENTICATION_BACKENDS = ['django.contrib.auth.backends.ModelBackend']

class MyBackend(object):
    def authenticate(self, request, username=None, password=None):
        # Проверим username/password и вернём user.
        ...

Вот такой простой способ изменения auth-работы с юзером.

Есть вопрос? Напишите в комментариях!

Не пропустите новые полезные статьи!

Спасибо за подписку!

Мы отправили вам письмо для подтверждения вашего email.
С уважением, OTUS!

Автор
2 комментария
2

Забыли упомянуть, что после первой миграции прийдется выкручиваться через UserProfile (one-to-one к User Model) или Proxy Model к User Model

0

Всегда можно извернуться с fake-миграциями

Для комментирования необходимо авторизоваться