Custom User Model | Authenticate with Email | Authenticate with Phone
from django.contrib.auth.models import AbstractUser, BaseUserManager
from django.db import models
from django.utils.translation import gettext_lazy as _
class CustomUserManager(BaseUserManager):
"""Define a model manager for User model with no username field."""
def _create_user(self, email, password=None, **extra_fields):
"""Create and save a User with the given email and password."""
if not email:
raise ValueError('The given email must be set')
email = self.normalize_email(email)
user = self.model(email=email, phone=phone, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, email, password=None, **extra_fields):
extra_fields.setdefault('is_staff', False)
extra_fields.setdefault('is_superuser', False)
return self._create_user(email, password, **extra_fields)
def create_superuser(self, email, password=None, **extra_fields):
"""Create and save a SuperUser with the given email and password."""
extra_fields.setdefault('is_staff', True)
extra_fields.setdefault('is_superuser', True)
if extra_fields.get('is_staff') is not True:
raise ValueError('Superuser must have is_staff=True.')
if extra_fields.get('is_superuser') is not True:
raise ValueError('Superuser must have is_superuser=True.')
return self._create_user(email, password, **extra_fields)
class CustomUser(AbstractUser):
username = None
email = models.EmailField(_('email address'), unique=True)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []
objects = CustomUserManager()
AUTH_USER_MODEL = 'accounts.CustomUser'
from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from django.utils.translation import gettext_lazy as _
from django.contrib.auth import get_user_model
class CustomUserAdmin(UserAdmin):
"""Define admin model for custom User model with no username field."""
fieldsets = (
(None, {'fields': ('email', 'password')}),
(_('Personal info'), {'fields': ('first_name', 'last_name')}),
(_('Permissions'), {'fields': ('is_active', 'is_staff', 'is_superuser',
'groups', 'user_permissions')}),
(_('Important dates'), {'fields': ('last_login', 'date_joined')}),
)
add_fieldsets = (
(None, {
'classes': ('wide',),
'fields': ('email', 'password1', 'password2'),
}),
)
list_display = ('email', 'first_name', 'last_name', 'is_staff')
search_fields = ('email', 'first_name', 'last_name')
ordering = ('email',)
admin.site.register(get_user_model(), CustomUserAdmin)
from django.contrib.auth import get_user_model
from django.contrib.auth.forms import UserCreationForm
class UserAdminCreationForm(UserCreationForm):
"""
A Custom form for creating new users.
"""
class Meta:
model = get_user_model()
fields = ['email']
from django.shortcuts import render, redirect
from accounts.forms import UserAdminCreationForm
def register(req):
form = UserAdminCreationForm()
if req.method == 'POST':
form = UserAdminCreationForm(req.POST)
if form.is_valid():
form.save()
return redirect('register')
return render(req, 'register.html', {'form': form})
from django.contrib import admin
from django.urls import path, include
from accounts import views
urlpatterns = [
path('admin/', admin.site.urls),
path('register/', views.register, name='register'),
path('accounts/', include('django.contrib.auth.urls')),
]
<form method="POST">
{% csrf_token %}
{{ form.as_p }}
<input type="submit" value="Submit">
</form>
(Best way to store phone number is using PhoneNumberField)
from django.contrib.auth.models import AbstractUser, BaseUserManager
from django.db import models
from django.utils.translation import gettext_lazy as _
class CustomUserManager(BaseUserManager):
"""Define a model manager for User model with no username field."""
def _create_user(self, phone, password=None, **extra_fields):
"""Create and save a User with the given phone and password."""
if not phone:
raise ValueError('The given phone must be set')
user = self.model(phone=phone, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, phone, password=None, **extra_fields):
extra_fields.setdefault('is_staff', False)
extra_fields.setdefault('is_superuser', False)
return self._create_user(phone, password, **extra_fields)
def create_superuser(self, phone, password=None, **extra_fields):
"""Create and save a SuperUser with the given phone and password."""
extra_fields.setdefault('is_staff', True)
extra_fields.setdefault('is_superuser', True)
if extra_fields.get('is_staff') is not True:
raise ValueError('Superuser must have is_staff=True.')
if extra_fields.get('is_superuser') is not True:
raise ValueError('Superuser must have is_superuser=True.')
return self._create_user(phone, password, **extra_fields)
class CustomUser(AbstractUser):
username = None
phone = IntegerField(max_length=10, unique=True, verbose_name='Phone Number', blank=False, help_text='Enter 10 digits phone number')
USERNAME_FIELD = 'phone'
REQUIRED_FIELDS = []
objects = CustomUserManager()
AUTH_USER_MODEL = 'accounts.CustomUser'
from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from django.utils.translation import gettext_lazy as _
from django.contrib.auth import get_user_model
class CustomUserAdmin(UserAdmin):
"""Define admin model for custom User model with no username field."""
fieldsets = (
(None, {'fields': ('phone', 'password')}),
(_('Personal info'), {'fields': ('first_name', 'last_name')}),
(_('Permissions'), {'fields': ('is_active', 'is_staff', 'is_superuser',
'groups', 'user_permissions')}),
(_('Important dates'), {'fields': ('last_login', 'date_joined')}),
)
add_fieldsets = (
(None, {
'classes': ('wide',),
'fields': ('phone', 'password1', 'password2'),
}),
)
list_display = ('phone', 'first_name', 'last_name', 'is_staff')
search_fields = ('phone', 'first_name', 'last_name')
ordering = ('phone',)
admin.site.register(get_user_model(), CustomUserAdmin)
from django.contrib.auth import get_user_model
from django.contrib.auth.forms import UserCreationForm
class UserAdminCreationForm(UserCreationForm):
"""
A Custom form for creating new users.
"""
class Meta:
model = get_user_model()
fields = ['phone']
from django.shortcuts import render, redirect
from accounts.forms import UserAdminCreationForm
def register(req):
form = UserAdminCreationForm()
if req.method == 'POST':
form = UserAdminCreationForm(req.POST)
if form.is_valid():
form.save()
return redirect('register')
return render(req, 'register.html', {'form': form})
from django.contrib import admin
from django.urls import path, include
from accounts import views
urlpatterns = [
path('admin/', admin.site.urls),
path('register/', views.register, name='register'),
path('accounts/', include('django.contrib.auth.urls')),
]
<form method="POST">
{% csrf_token %}
{{ form.as_p }}
<input type="submit" value="Submit">
</form>