Normalized casing of "custom user model".
This commit is contained in:
parent
d02a03d574
commit
93a081946d
|
@ -15,7 +15,7 @@ version >= 2.2 and mod_wsgi >= 2.0. For example, you could:
|
||||||
* Allow certain users to connect to a WebDAV share created with mod_dav_.
|
* Allow certain users to connect to a WebDAV share created with mod_dav_.
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
If you have installed a :ref:`custom User model <auth-custom-user>` and
|
If you have installed a :ref:`custom user model <auth-custom-user>` and
|
||||||
want to use this default auth handler, it must support an ``is_active``
|
want to use this default auth handler, it must support an ``is_active``
|
||||||
attribute. If you want to use group based authorization, your custom user
|
attribute. If you want to use group based authorization, your custom user
|
||||||
must have a relation named 'groups', referring to a related object that has
|
must have a relation named 'groups', referring to a related object that has
|
||||||
|
|
|
@ -183,9 +183,9 @@ Methods
|
||||||
|
|
||||||
.. method:: get_username()
|
.. method:: get_username()
|
||||||
|
|
||||||
Returns the username for the user. Since the User model can be swapped
|
Returns the username for the user. Since the ``User`` model can be
|
||||||
out, you should use this method instead of referencing the username
|
swapped out, you should use this method instead of referencing the
|
||||||
attribute directly.
|
username attribute directly.
|
||||||
|
|
||||||
.. method:: get_full_name()
|
.. method:: get_full_name()
|
||||||
|
|
||||||
|
@ -305,7 +305,7 @@ Manager methods
|
||||||
|
|
||||||
The ``extra_fields`` keyword arguments are passed through to the
|
The ``extra_fields`` keyword arguments are passed through to the
|
||||||
:class:`~django.contrib.auth.models.User`’s ``__init__`` method to
|
:class:`~django.contrib.auth.models.User`’s ``__init__`` method to
|
||||||
allow setting arbitrary fields on a :ref:`custom User model
|
allow setting arbitrary fields on a :ref:`custom user model
|
||||||
<auth-custom-user>`.
|
<auth-custom-user>`.
|
||||||
|
|
||||||
See :ref:`Creating users <topics-auth-creating-users>` for example usage.
|
See :ref:`Creating users <topics-auth-creating-users>` for example usage.
|
||||||
|
@ -615,16 +615,14 @@ The following backends are available in :mod:`django.contrib.auth.backends`:
|
||||||
|
|
||||||
.. attribute:: RemoteUserBackend.create_unknown_user
|
.. attribute:: RemoteUserBackend.create_unknown_user
|
||||||
|
|
||||||
``True`` or ``False``. Determines whether or not a
|
``True`` or ``False``. Determines whether or not a user object is created
|
||||||
:class:`~django.contrib.auth.models.User` object is created if not already
|
if not already in the database Defaults to ``True``.
|
||||||
in the database. Defaults to ``True``.
|
|
||||||
|
|
||||||
.. method:: RemoteUserBackend.authenticate(request, remote_user)
|
.. method:: RemoteUserBackend.authenticate(request, remote_user)
|
||||||
|
|
||||||
The username passed as ``remote_user`` is considered trusted. This method
|
The username passed as ``remote_user`` is considered trusted. This method
|
||||||
simply returns the ``User`` object with the given username, creating a new
|
simply returns the user object with the given username, creating a new
|
||||||
``User`` object if :attr:`~RemoteUserBackend.create_unknown_user` is
|
user object if :attr:`~RemoteUserBackend.create_unknown_user` is ``True``.
|
||||||
``True``.
|
|
||||||
|
|
||||||
Returns ``None`` if :attr:`~RemoteUserBackend.create_unknown_user` is
|
Returns ``None`` if :attr:`~RemoteUserBackend.create_unknown_user` is
|
||||||
``False`` and a ``User`` object with the given username is not found in the
|
``False`` and a ``User`` object with the given username is not found in the
|
||||||
|
@ -637,9 +635,8 @@ The following backends are available in :mod:`django.contrib.auth.backends`:
|
||||||
.. method:: RemoteUserBackend.clean_username(username)
|
.. method:: RemoteUserBackend.clean_username(username)
|
||||||
|
|
||||||
Performs any cleaning on the ``username`` (e.g. stripping LDAP DN
|
Performs any cleaning on the ``username`` (e.g. stripping LDAP DN
|
||||||
information) prior to using it to get or create a
|
information) prior to using it to get or create a user object. Returns the
|
||||||
:class:`~django.contrib.auth.models.User` object. Returns the cleaned
|
cleaned username.
|
||||||
username.
|
|
||||||
|
|
||||||
.. method:: RemoteUserBackend.configure_user(user)
|
.. method:: RemoteUserBackend.configure_user(user)
|
||||||
|
|
||||||
|
|
|
@ -133,7 +133,7 @@ you may need to make some changes to the way you reference User instances. You
|
||||||
should also document any specific features of the User model that your
|
should also document any specific features of the User model that your
|
||||||
application relies upon.
|
application relies upon.
|
||||||
|
|
||||||
See the :ref:`documentation on custom User models <auth-custom-user>` for
|
See the :ref:`documentation on custom user models <auth-custom-user>` for
|
||||||
more details.
|
more details.
|
||||||
|
|
||||||
Support for saving a subset of model's fields
|
Support for saving a subset of model's fields
|
||||||
|
@ -560,7 +560,7 @@ Prior to Django 1.5, if you attempted to log into the admin interface and
|
||||||
mistakenly used your email address instead of your username, the admin
|
mistakenly used your email address instead of your username, the admin
|
||||||
interface would provide a warning advising that your email address was
|
interface would provide a warning advising that your email address was
|
||||||
not your username. In Django 1.5, the introduction of
|
not your username. In Django 1.5, the introduction of
|
||||||
:ref:`custom User models <auth-custom-user>` has required the removal of this
|
:ref:`custom user models <auth-custom-user>` has required the removal of this
|
||||||
warning. This doesn't change the login behavior of the admin site; it only
|
warning. This doesn't change the login behavior of the admin site; it only
|
||||||
affects the warning message that is displayed under one particular mode of
|
affects the warning message that is displayed under one particular mode of
|
||||||
login failure.
|
login failure.
|
||||||
|
@ -741,7 +741,7 @@ framework.
|
||||||
``AUTH_PROFILE_MODULE``
|
``AUTH_PROFILE_MODULE``
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
With the introduction of :ref:`custom User models <auth-custom-user>`, there is
|
With the introduction of :ref:`custom user models <auth-custom-user>`, there is
|
||||||
no longer any need for a built-in mechanism to store user profile data.
|
no longer any need for a built-in mechanism to store user profile data.
|
||||||
|
|
||||||
You can still define user profiles models that have a one-to-one relation with
|
You can still define user profiles models that have a one-to-one relation with
|
||||||
|
|
|
@ -448,7 +448,7 @@ removed and the standalone GeoDjango tests execution setup it implemented isn't
|
||||||
supported anymore. To run the GeoDjango tests simply use the new
|
supported anymore. To run the GeoDjango tests simply use the new
|
||||||
``DiscoverRunner`` and specify the ``django.contrib.gis`` app.
|
``DiscoverRunner`` and specify the ``django.contrib.gis`` app.
|
||||||
|
|
||||||
Custom User models in tests
|
Custom user models in tests
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
The introduction of the new test runner has also slightly changed the way that
|
The introduction of the new test runner has also slightly changed the way that
|
||||||
|
|
|
@ -9,14 +9,14 @@ provided system are extensible or replaceable. This document provides details
|
||||||
about how the auth system can be customized.
|
about how the auth system can be customized.
|
||||||
|
|
||||||
:ref:`Authentication backends <authentication-backends>` provide an extensible
|
:ref:`Authentication backends <authentication-backends>` provide an extensible
|
||||||
system for when a username and password stored with the User model need
|
system for when a username and password stored with the user model need to be
|
||||||
to be authenticated against a different service than Django's default.
|
authenticated against a different service than Django's default.
|
||||||
|
|
||||||
You can give your models :ref:`custom permissions <custom-permissions>` that can be
|
You can give your models :ref:`custom permissions <custom-permissions>` that
|
||||||
checked through Django's authorization system.
|
can be checked through Django's authorization system.
|
||||||
|
|
||||||
You can :ref:`extend <extending-user>` the default User model, or :ref:`substitute
|
You can :ref:`extend <extending-user>` the default ``User`` model, or
|
||||||
<auth-custom-user>` a completely customized model.
|
:ref:`substitute <auth-custom-user>` a completely customized model.
|
||||||
|
|
||||||
.. _authentication-backends:
|
.. _authentication-backends:
|
||||||
|
|
||||||
|
@ -94,27 +94,27 @@ a set of optional permission related :ref:`authorization methods
|
||||||
<authorization_methods>`.
|
<authorization_methods>`.
|
||||||
|
|
||||||
The ``get_user`` method takes a ``user_id`` -- which could be a username,
|
The ``get_user`` method takes a ``user_id`` -- which could be a username,
|
||||||
database ID or whatever, but has to be the primary key of your ``User`` object
|
database ID or whatever, but has to be the primary key of your user object --
|
||||||
-- and returns a ``User`` object.
|
and returns a user object.
|
||||||
|
|
||||||
The ``authenticate`` method takes a ``request`` argument and credentials as
|
The ``authenticate`` method takes a ``request`` argument and credentials as
|
||||||
keyword arguments. Most of the time, it'll just look like this::
|
keyword arguments. Most of the time, it'll just look like this::
|
||||||
|
|
||||||
class MyBackend(object):
|
class MyBackend(object):
|
||||||
def authenticate(self, request, username=None, password=None):
|
def authenticate(self, request, username=None, password=None):
|
||||||
# Check the username/password and return a User.
|
# Check the username/password and return a user.
|
||||||
...
|
...
|
||||||
|
|
||||||
But it could also authenticate a token, like so::
|
But it could also authenticate a token, like so::
|
||||||
|
|
||||||
class MyBackend(object):
|
class MyBackend(object):
|
||||||
def authenticate(self, request, token=None):
|
def authenticate(self, request, token=None):
|
||||||
# Check the token and return a User.
|
# Check the token and return a user.
|
||||||
...
|
...
|
||||||
|
|
||||||
Either way, ``authenticate`` should check the credentials it gets, and it
|
Either way, ``authenticate()`` should check the credentials it gets and return
|
||||||
should return a ``User`` object that matches those credentials, if the
|
a user object that matches those credentials if the credentials are valid. If
|
||||||
credentials are valid. If they're not valid, it should return ``None``.
|
they're not valid, it should return ``None``.
|
||||||
|
|
||||||
``request`` is an :class:`~django.http.HttpRequest` and may be ``None`` if it
|
``request`` is an :class:`~django.http.HttpRequest` and may be ``None`` if it
|
||||||
wasn't provided to :func:`~django.contrib.auth.authenticate` (which passes it
|
wasn't provided to :func:`~django.contrib.auth.authenticate` (which passes it
|
||||||
|
@ -364,17 +364,17 @@ add it to a ``UserAdmin`` class which is registered with the
|
||||||
admin.site.unregister(User)
|
admin.site.unregister(User)
|
||||||
admin.site.register(User, UserAdmin)
|
admin.site.register(User, UserAdmin)
|
||||||
|
|
||||||
These profile models are not special in any way - they are just Django models that
|
These profile models are not special in any way - they are just Django models
|
||||||
happen to have a one-to-one link with a User model. As such, they do not get
|
that happen to have a one-to-one link with a user model. As such, they aren't
|
||||||
auto created when a user is created, but
|
auto created when a user is created, but
|
||||||
a :attr:`django.db.models.signals.post_save` could be used to create or update
|
a :attr:`django.db.models.signals.post_save` could be used to create or update
|
||||||
related models as appropriate.
|
related models as appropriate.
|
||||||
|
|
||||||
Note that using related models results in additional queries or joins to
|
Using related models results in additional queries or joins to retrieve the
|
||||||
retrieve the related data, and depending on your needs substituting the User
|
related data. Depending on your needs, a custom user model that includes the
|
||||||
model and adding the related fields may be your better option. However
|
related fields may be your better option, however, existing relations to the
|
||||||
existing links to the default User model within your project's apps may justify
|
default user model within your project's apps may justify the extra database
|
||||||
the extra database load.
|
load.
|
||||||
|
|
||||||
.. _auth-custom-user:
|
.. _auth-custom-user:
|
||||||
|
|
||||||
|
@ -386,14 +386,14 @@ built-in :class:`~django.contrib.auth.models.User` model is not always
|
||||||
appropriate. For instance, on some sites it makes more sense to use an email
|
appropriate. For instance, on some sites it makes more sense to use an email
|
||||||
address as your identification token instead of a username.
|
address as your identification token instead of a username.
|
||||||
|
|
||||||
Django allows you to override the default User model by providing a value for
|
Django allows you to override the default user model by providing a value for
|
||||||
the :setting:`AUTH_USER_MODEL` setting that references a custom model::
|
the :setting:`AUTH_USER_MODEL` setting that references a custom model::
|
||||||
|
|
||||||
AUTH_USER_MODEL = 'myapp.MyUser'
|
AUTH_USER_MODEL = 'myapp.MyUser'
|
||||||
|
|
||||||
This dotted pair describes the name of the Django app (which must be in your
|
This dotted pair describes the name of the Django app (which must be in your
|
||||||
:setting:`INSTALLED_APPS`), and the name of the Django model that you wish to
|
:setting:`INSTALLED_APPS`), and the name of the Django model that you wish to
|
||||||
use as your User model.
|
use as your user model.
|
||||||
|
|
||||||
Using a custom user model when starting a project
|
Using a custom user model when starting a project
|
||||||
-------------------------------------------------
|
-------------------------------------------------
|
||||||
|
@ -453,17 +453,17 @@ Referencing the ``User`` model
|
||||||
If you reference :class:`~django.contrib.auth.models.User` directly (for
|
If you reference :class:`~django.contrib.auth.models.User` directly (for
|
||||||
example, by referring to it in a foreign key), your code will not work in
|
example, by referring to it in a foreign key), your code will not work in
|
||||||
projects where the :setting:`AUTH_USER_MODEL` setting has been changed to a
|
projects where the :setting:`AUTH_USER_MODEL` setting has been changed to a
|
||||||
different User model.
|
different user model.
|
||||||
|
|
||||||
.. function:: get_user_model()
|
.. function:: get_user_model()
|
||||||
|
|
||||||
Instead of referring to :class:`~django.contrib.auth.models.User` directly,
|
Instead of referring to :class:`~django.contrib.auth.models.User` directly,
|
||||||
you should reference the user model using
|
you should reference the user model using
|
||||||
``django.contrib.auth.get_user_model()``. This method will return the
|
``django.contrib.auth.get_user_model()``. This method will return the
|
||||||
currently active User model -- the custom User model if one is specified, or
|
currently active user model -- the custom user model if one is specified, or
|
||||||
:class:`~django.contrib.auth.models.User` otherwise.
|
:class:`~django.contrib.auth.models.User` otherwise.
|
||||||
|
|
||||||
When you define a foreign key or many-to-many relations to the User model,
|
When you define a foreign key or many-to-many relations to the user model,
|
||||||
you should specify the custom model using the :setting:`AUTH_USER_MODEL`
|
you should specify the custom model using the :setting:`AUTH_USER_MODEL`
|
||||||
setting. For example::
|
setting. For example::
|
||||||
|
|
||||||
|
@ -476,7 +476,7 @@ different User model.
|
||||||
on_delete=models.CASCADE,
|
on_delete=models.CASCADE,
|
||||||
)
|
)
|
||||||
|
|
||||||
When connecting to signals sent by the ``User`` model, you should specify
|
When connecting to signals sent by the user model, you should specify
|
||||||
the custom model using the :setting:`AUTH_USER_MODEL` setting. For example::
|
the custom model using the :setting:`AUTH_USER_MODEL` setting. For example::
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
@ -487,27 +487,27 @@ different User model.
|
||||||
|
|
||||||
post_save.connect(post_save_receiver, sender=settings.AUTH_USER_MODEL)
|
post_save.connect(post_save_receiver, sender=settings.AUTH_USER_MODEL)
|
||||||
|
|
||||||
Generally speaking, you should reference the User model with the
|
Generally speaking, you should reference the user model with the
|
||||||
:setting:`AUTH_USER_MODEL` setting in code that is executed at import
|
:setting:`AUTH_USER_MODEL` setting in code that is executed at import
|
||||||
time. ``get_user_model()`` only works once Django has imported all models.
|
time. ``get_user_model()`` only works once Django has imported all models.
|
||||||
|
|
||||||
.. _specifying-custom-user-model:
|
.. _specifying-custom-user-model:
|
||||||
|
|
||||||
Specifying a custom ``User`` model
|
Specifying a custom user model
|
||||||
----------------------------------
|
------------------------------
|
||||||
|
|
||||||
.. admonition:: Model design considerations
|
.. admonition:: Model design considerations
|
||||||
|
|
||||||
Think carefully before handling information not directly related to
|
Think carefully before handling information not directly related to
|
||||||
authentication in your custom User Model.
|
authentication in your custom user model.
|
||||||
|
|
||||||
It may be better to store app-specific user information in a model
|
It may be better to store app-specific user information in a model
|
||||||
that has a relation with the User model. That allows each app to specify
|
that has a relation with the user model. That allows each app to specify
|
||||||
its own user data requirements without risking conflicts with other
|
its own user data requirements without risking conflicts with other
|
||||||
apps. On the other hand, queries to retrieve this related information
|
apps. On the other hand, queries to retrieve this related information
|
||||||
will involve a database join, which may have an effect on performance.
|
will involve a database join, which may have an effect on performance.
|
||||||
|
|
||||||
Django expects your custom User model to meet some minimum requirements.
|
Django expects your custom user model to meet some minimum requirements.
|
||||||
|
|
||||||
#. If you use the default authentication backend, then your model must have a
|
#. If you use the default authentication backend, then your model must have a
|
||||||
single unique field that can be used for identification purposes. This can
|
single unique field that can be used for identification purposes. This can
|
||||||
|
@ -522,10 +522,10 @@ Django expects your custom User model to meet some minimum requirements.
|
||||||
what these two methods return - if you want, they can return exactly
|
what these two methods return - if you want, they can return exactly
|
||||||
the same value.
|
the same value.
|
||||||
|
|
||||||
The easiest way to construct a compliant custom User model is to inherit from
|
The easiest way to construct a compliant custom user model is to inherit from
|
||||||
:class:`~django.contrib.auth.models.AbstractBaseUser`.
|
:class:`~django.contrib.auth.models.AbstractBaseUser`.
|
||||||
:class:`~django.contrib.auth.models.AbstractBaseUser` provides the core
|
:class:`~django.contrib.auth.models.AbstractBaseUser` provides the core
|
||||||
implementation of a ``User`` model, including hashed passwords and tokenized
|
implementation of a user model, including hashed passwords and tokenized
|
||||||
password resets. You must then provide some key implementation details:
|
password resets. You must then provide some key implementation details:
|
||||||
|
|
||||||
.. currentmodule:: django.contrib.auth
|
.. currentmodule:: django.contrib.auth
|
||||||
|
@ -534,7 +534,7 @@ password resets. You must then provide some key implementation details:
|
||||||
|
|
||||||
.. attribute:: USERNAME_FIELD
|
.. attribute:: USERNAME_FIELD
|
||||||
|
|
||||||
A string describing the name of the field on the User model that is
|
A string describing the name of the field on the user model that is
|
||||||
used as the unique identifier. This will usually be a username of some
|
used as the unique identifier. This will usually be a username of some
|
||||||
kind, but it can also be an email address, or any other unique
|
kind, but it can also be an email address, or any other unique
|
||||||
identifier. The field *must* be unique (i.e., have ``unique=True`` set
|
identifier. The field *must* be unique (i.e., have ``unique=True`` set
|
||||||
|
@ -575,7 +575,7 @@ password resets. You must then provide some key implementation details:
|
||||||
``REQUIRED_FIELDS`` has no effect in other parts of Django, like
|
``REQUIRED_FIELDS`` has no effect in other parts of Django, like
|
||||||
creating a user in the admin.
|
creating a user in the admin.
|
||||||
|
|
||||||
For example, here is the partial definition for a ``User`` model that
|
For example, here is the partial definition for a user model that
|
||||||
defines two required fields - a date of birth and height::
|
defines two required fields - a date of birth and height::
|
||||||
|
|
||||||
class MyUser(AbstractBaseUser):
|
class MyUser(AbstractBaseUser):
|
||||||
|
@ -587,8 +587,8 @@ password resets. You must then provide some key implementation details:
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
``REQUIRED_FIELDS`` must contain all required fields on your
|
``REQUIRED_FIELDS`` must contain all required fields on your user
|
||||||
``User`` model, but should *not* contain the ``USERNAME_FIELD`` or
|
model, but should *not* contain the ``USERNAME_FIELD`` or
|
||||||
``password`` as these fields will always be prompted for.
|
``password`` as these fields will always be prompted for.
|
||||||
|
|
||||||
:attr:`REQUIRED_FIELDS` now supports
|
:attr:`REQUIRED_FIELDS` now supports
|
||||||
|
@ -739,14 +739,13 @@ The following attributes and methods are available on any subclass of
|
||||||
:meth:`.BaseUserManager.normalize_email`. If you override this method,
|
:meth:`.BaseUserManager.normalize_email`. If you override this method,
|
||||||
be sure to call ``super()`` to retain the normalization.
|
be sure to call ``super()`` to retain the normalization.
|
||||||
|
|
||||||
You should also define a custom manager for your ``User`` model. If your
|
You should also define a custom manager for your user model. If your user model
|
||||||
``User`` model defines ``username``, ``email``, ``is_staff``, ``is_active``,
|
defines ``username``, ``email``, ``is_staff``, ``is_active``, ``is_superuser``,
|
||||||
``is_superuser``, ``last_login``, and ``date_joined`` fields the same as
|
``last_login``, and ``date_joined`` fields the same as Django's default user,
|
||||||
Django's default ``User``, you can just install Django's
|
you can just install Django's :class:`~django.contrib.auth.models.UserManager`;
|
||||||
:class:`~django.contrib.auth.models.UserManager`; however, if your ``User``
|
however, if your user model defines different fields, you'll need to define a
|
||||||
model defines different fields, you will need to define a custom manager that
|
custom manager that extends :class:`~django.contrib.auth.models.BaseUserManager`
|
||||||
extends :class:`~django.contrib.auth.models.BaseUserManager` providing two
|
providing two additional methods:
|
||||||
additional methods:
|
|
||||||
|
|
||||||
.. class:: models.CustomUserManager
|
.. class:: models.CustomUserManager
|
||||||
|
|
||||||
|
@ -862,9 +861,9 @@ can extend these forms in this manner::
|
||||||
Custom users and :mod:`django.contrib.admin`
|
Custom users and :mod:`django.contrib.admin`
|
||||||
--------------------------------------------
|
--------------------------------------------
|
||||||
|
|
||||||
If you want your custom User model to also work with Admin, your User model must
|
If you want your custom user model to also work with the admin, your user model
|
||||||
define some additional attributes and methods. These methods allow the admin to
|
must define some additional attributes and methods. These methods allow the
|
||||||
control access of the User to admin content:
|
admin to control access of the user to admin content:
|
||||||
|
|
||||||
.. class:: models.CustomUser
|
.. class:: models.CustomUser
|
||||||
|
|
||||||
|
@ -887,23 +886,23 @@ control access of the User to admin content:
|
||||||
Returns ``True`` if the user has permission to access models in
|
Returns ``True`` if the user has permission to access models in
|
||||||
the given app.
|
the given app.
|
||||||
|
|
||||||
You will also need to register your custom User model with the admin. If
|
You will also need to register your custom user model with the admin. If
|
||||||
your custom User model extends ``django.contrib.auth.models.AbstractUser``,
|
your custom user model extends ``django.contrib.auth.models.AbstractUser``,
|
||||||
you can use Django's existing ``django.contrib.auth.admin.UserAdmin``
|
you can use Django's existing ``django.contrib.auth.admin.UserAdmin``
|
||||||
class. However, if your User model extends
|
class. However, if your user model extends
|
||||||
:class:`~django.contrib.auth.models.AbstractBaseUser`, you'll need to define
|
:class:`~django.contrib.auth.models.AbstractBaseUser`, you'll need to define
|
||||||
a custom ``ModelAdmin`` class. It may be possible to subclass the default
|
a custom ``ModelAdmin`` class. It may be possible to subclass the default
|
||||||
``django.contrib.auth.admin.UserAdmin``; however, you'll need to
|
``django.contrib.auth.admin.UserAdmin``; however, you'll need to
|
||||||
override any of the definitions that refer to fields on
|
override any of the definitions that refer to fields on
|
||||||
``django.contrib.auth.models.AbstractUser`` that aren't on your
|
``django.contrib.auth.models.AbstractUser`` that aren't on your
|
||||||
custom User class.
|
custom user class.
|
||||||
|
|
||||||
Custom users and permissions
|
Custom users and permissions
|
||||||
----------------------------
|
----------------------------
|
||||||
|
|
||||||
To make it easy to include Django's permission framework into your own User
|
To make it easy to include Django's permission framework into your own user
|
||||||
class, Django provides :class:`~django.contrib.auth.models.PermissionsMixin`.
|
class, Django provides :class:`~django.contrib.auth.models.PermissionsMixin`.
|
||||||
This is an abstract model you can include in the class hierarchy for your User
|
This is an abstract model you can include in the class hierarchy for your user
|
||||||
model, giving you all the methods and database fields necessary to support
|
model, giving you all the methods and database fields necessary to support
|
||||||
Django's permission model.
|
Django's permission model.
|
||||||
|
|
||||||
|
@ -964,21 +963,21 @@ methods and attributes:
|
||||||
If you don't include the
|
If you don't include the
|
||||||
:class:`~django.contrib.auth.models.PermissionsMixin`, you must ensure you
|
:class:`~django.contrib.auth.models.PermissionsMixin`, you must ensure you
|
||||||
don't invoke the permissions methods on ``ModelBackend``. ``ModelBackend``
|
don't invoke the permissions methods on ``ModelBackend``. ``ModelBackend``
|
||||||
assumes that certain fields are available on your user model. If your
|
assumes that certain fields are available on your user model. If your user
|
||||||
``User`` model doesn't provide those fields, you will receive database
|
model doesn't provide those fields, you'll receive database errors when
|
||||||
errors when you check permissions.
|
you check permissions.
|
||||||
|
|
||||||
Custom users and proxy models
|
Custom users and proxy models
|
||||||
-----------------------------
|
-----------------------------
|
||||||
|
|
||||||
One limitation of custom User models is that installing a custom User model
|
One limitation of custom user models is that installing a custom user model
|
||||||
will break any proxy model extending :class:`~django.contrib.auth.models.User`.
|
will break any proxy model extending :class:`~django.contrib.auth.models.User`.
|
||||||
Proxy models must be based on a concrete base class; by defining a custom User
|
Proxy models must be based on a concrete base class; by defining a custom user
|
||||||
model, you remove the ability of Django to reliably identify the base class.
|
model, you remove the ability of Django to reliably identify the base class.
|
||||||
|
|
||||||
If your project uses proxy models, you must either modify the proxy to extend
|
If your project uses proxy models, you must either modify the proxy to extend
|
||||||
the User model that is currently in use in your project, or merge your proxy's
|
the user model that's in use in your project, or merge your proxy's behavior
|
||||||
behavior into your User subclass.
|
into your :class:`~django.contrib.auth.models.User` subclass.
|
||||||
|
|
||||||
A full example
|
A full example
|
||||||
--------------
|
--------------
|
||||||
|
@ -987,7 +986,7 @@ Here is an example of an admin-compliant custom user app. This user model uses
|
||||||
an email address as the username, and has a required date of birth; it
|
an email address as the username, and has a required date of birth; it
|
||||||
provides no permission checking, beyond a simple ``admin`` flag on the user
|
provides no permission checking, beyond a simple ``admin`` flag on the user
|
||||||
account. This model would be compatible with all the built-in auth forms and
|
account. This model would be compatible with all the built-in auth forms and
|
||||||
views, except for the User creation forms. This example illustrates how most of
|
views, except for the user creation forms. This example illustrates how most of
|
||||||
the components work together, but is not intended to be copied directly into
|
the components work together, but is not intended to be copied directly into
|
||||||
projects for production use.
|
projects for production use.
|
||||||
|
|
||||||
|
@ -1075,7 +1074,7 @@ authentication app::
|
||||||
# Simplest possible answer: All admins are staff
|
# Simplest possible answer: All admins are staff
|
||||||
return self.is_admin
|
return self.is_admin
|
||||||
|
|
||||||
Then, to register this custom User model with Django's admin, the following
|
Then, to register this custom user model with Django's admin, the following
|
||||||
code would be required in the app's ``admin.py`` file::
|
code would be required in the app's ``admin.py`` file::
|
||||||
|
|
||||||
from django import forms
|
from django import forms
|
||||||
|
|
|
@ -86,7 +86,7 @@ function is used when creating a user.
|
||||||
To change a user's password, you have several options:
|
To change a user's password, you have several options:
|
||||||
|
|
||||||
:djadmin:`manage.py changepassword *username* <changepassword>` offers a method
|
:djadmin:`manage.py changepassword *username* <changepassword>` offers a method
|
||||||
of changing a User's password from the command line. It prompts you to
|
of changing a user's password from the command line. It prompts you to
|
||||||
change the password of a given user which you must enter twice. If
|
change the password of a given user which you must enter twice. If
|
||||||
they both match, the new password will be changed immediately. If you
|
they both match, the new password will be changed immediately. If you
|
||||||
do not supply a user, the command will attempt to change the password
|
do not supply a user, the command will attempt to change the password
|
||||||
|
@ -267,12 +267,12 @@ Permission caching
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
The :class:`~django.contrib.auth.backends.ModelBackend` caches permissions on
|
The :class:`~django.contrib.auth.backends.ModelBackend` caches permissions on
|
||||||
the ``User`` object after the first time they need to be fetched for a
|
the user object after the first time they need to be fetched for a permissions
|
||||||
permissions check. This is typically fine for the request-response cycle since
|
check. This is typically fine for the request-response cycle since permissions
|
||||||
permissions are not typically checked immediately after they are added (in the
|
aren't typically checked immediately after they are added (in the admin, for
|
||||||
admin, for example). If you are adding permissions and checking them immediately
|
example). If you are adding permissions and checking them immediately
|
||||||
afterward, in a test or view for example, the easiest solution is to re-fetch
|
afterward, in a test or view for example, the easiest solution is to re-fetch
|
||||||
the ``User`` from the database. For example::
|
the user from the database. For example::
|
||||||
|
|
||||||
from django.contrib.auth.models import Permission, User
|
from django.contrib.auth.models import Permission, User
|
||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
|
@ -380,7 +380,7 @@ is selected as follows:
|
||||||
pairing :func:`~django.contrib.auth.authenticate()` and
|
pairing :func:`~django.contrib.auth.authenticate()` and
|
||||||
:func:`~django.contrib.auth.login()`:
|
:func:`~django.contrib.auth.login()`:
|
||||||
:func:`~django.contrib.auth.authenticate()`
|
:func:`~django.contrib.auth.authenticate()`
|
||||||
sets the ``user.backend`` attribute on the ``User`` object it returns.
|
sets the ``user.backend`` attribute on the user object it returns.
|
||||||
#. Use the ``backend`` in :setting:`AUTHENTICATION_BACKENDS`, if there is only
|
#. Use the ``backend`` in :setting:`AUTHENTICATION_BACKENDS`, if there is only
|
||||||
one.
|
one.
|
||||||
#. Otherwise, raise an exception.
|
#. Otherwise, raise an exception.
|
||||||
|
@ -1602,7 +1602,7 @@ provides several built-in forms located in :mod:`django.contrib.auth.forms`:
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
The built-in authentication forms make certain assumptions about the user
|
The built-in authentication forms make certain assumptions about the user
|
||||||
model that they are working with. If you're using a :ref:`custom User model
|
model that they are working with. If you're using a :ref:`custom user model
|
||||||
<auth-custom-user>`, it may be necessary to define your own forms for the
|
<auth-custom-user>`, it may be necessary to define your own forms for the
|
||||||
authentication system. For more information, refer to the documentation
|
authentication system. For more information, refer to the documentation
|
||||||
about :ref:`using the built-in authentication forms with custom user models
|
about :ref:`using the built-in authentication forms with custom user models
|
||||||
|
|
|
@ -6,7 +6,7 @@ from django.db import models
|
||||||
from django.utils.encoding import python_2_unicode_compatible
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
# The custom User uses email as the unique identifier, and requires
|
# The custom user uses email as the unique identifier, and requires
|
||||||
# that every user provide a date of birth. This lets us test
|
# that every user provide a date of birth. This lets us test
|
||||||
# changes in username datatype, and non-text required fields.
|
# changes in username datatype, and non-text required fields.
|
||||||
class CustomUserManager(BaseUserManager):
|
class CustomUserManager(BaseUserManager):
|
||||||
|
|
|
@ -263,7 +263,7 @@ class CreatesuperuserManagementCommandTestCase(TestCase):
|
||||||
|
|
||||||
@override_settings(AUTH_USER_MODEL='auth_tests.CustomUser')
|
@override_settings(AUTH_USER_MODEL='auth_tests.CustomUser')
|
||||||
def test_swappable_user(self):
|
def test_swappable_user(self):
|
||||||
"A superuser can be created when a custom User model is in use"
|
"A superuser can be created when a custom user model is in use"
|
||||||
# We can use the management command to create a superuser
|
# We can use the management command to create a superuser
|
||||||
# We skip validation because the temporary substitution of the
|
# We skip validation because the temporary substitution of the
|
||||||
# swappable User model messes with validation.
|
# swappable User model messes with validation.
|
||||||
|
|
Loading…
Reference in New Issue