From 54fcdf168ab1f53fbdb7cd63f916bd44845a78d3 Mon Sep 17 00:00:00 2001 From: Tobias Kunze Date: Sat, 27 Apr 2019 18:32:27 +0200 Subject: [PATCH] [2.2.x] Fixed #20629 -- Rephrased custom user models admonition. Backport of eb16c7260e573ec513d84cb586d96bdf508f3173 from master --- docs/topics/auth/customizing.txt | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/docs/topics/auth/customizing.txt b/docs/topics/auth/customizing.txt index 5c01067a75..fd723cbb94 100644 --- a/docs/topics/auth/customizing.txt +++ b/docs/topics/auth/customizing.txt @@ -511,18 +511,17 @@ different user model. Specifying a custom user model ------------------------------ -.. admonition:: Model design considerations +When you start your project with a custom user model, stop to consider if this +is the right choice for your project. - Think carefully before handling information not directly related to - authentication in your custom user 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 - its own user data requirements without risking conflicts with other - apps. On the other hand, queries to retrieve this related information - will involve a database join, which may have an effect on performance. - -Django expects your custom user model to meet some minimum requirements. +Keeping all user related information in one model removes the need for +additional or more complex database queries to retrieve related models. On the +other hand, it may be more suitable to store app-specific user information in a +model that has a relation with your custom user model. That allows each app to +specify its own user data requirements without potentially conflicting or +breaking assumptions by other apps. It also means that you would keep your user +model as simple as possible, focused on authentication, and following the +minimum requirements Django expects custom user models to meet. 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