mirror of
https://github.com/django/django.git
synced 2025-08-03 18:38:50 +00:00
Fixed #26719 -- Normalized email in AbstractUser.clean().
This commit is contained in:
parent
7e303d15c3
commit
09119dff14
4 changed files with 27 additions and 1 deletions
|
@ -293,6 +293,11 @@ Miscellaneous
|
|||
<django.db.models.Model.validate_unique>` no longer checks empty strings for
|
||||
uniqueness as the database interprets the value as ``NULL``.
|
||||
|
||||
* If you subclass :class:`.AbstractUser` and override ``clean()``, be sure it
|
||||
calls ``super()``. :meth:`.BaseUserManager.normalize_email` is called in a
|
||||
new :meth:`.AbstractUser.clean` method so that normalization is applied in
|
||||
cases like model form validation.
|
||||
|
||||
.. _deprecated-features-1.11:
|
||||
|
||||
Features deprecated in 1.11
|
||||
|
|
|
@ -692,6 +692,18 @@ The following attributes and methods are available on any subclass of
|
|||
Returns an HMAC of the password field. Used for
|
||||
:ref:`session-invalidation-on-password-change`.
|
||||
|
||||
:class:`~models.AbstractUser` subclasses :class:`~models.AbstractBaseUser`:
|
||||
|
||||
.. class:: models.AbstractUser
|
||||
|
||||
.. method:: clean()
|
||||
|
||||
.. versionadded:: 1.11
|
||||
|
||||
Normalizes the email by calling
|
||||
:meth:`.BaseUserManager.normalize_email`. If you override this method,
|
||||
be sure to call ``super()`` to retain the normalization.
|
||||
|
||||
You should also define a custom manager for your ``User`` model. If your
|
||||
``User`` model defines ``username``, ``email``, ``is_staff``, ``is_active``,
|
||||
``is_superuser``, ``last_login``, and ``date_joined`` fields the same as
|
||||
|
@ -759,7 +771,7 @@ Extending Django's default ``User``
|
|||
|
||||
If you're entirely happy with Django's :class:`~django.contrib.auth.models.User`
|
||||
model and you just want to add some additional profile information, you could
|
||||
simply subclass ``django.contrib.auth.models.AbstractUser`` and add your
|
||||
simply subclass :class:`django.contrib.auth.models.AbstractUser` and add your
|
||||
custom profile fields, although we'd recommend a separate model as described in
|
||||
the "Model design considerations" note of :ref:`specifying-custom-user-model`.
|
||||
``AbstractUser`` provides the full implementation of the default
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue