Django авторизирует только superuser
models.py
from django.db import models
from django.utils import timezone
from django.utils.translation import gettext_lazy as _
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin, BaseUserManager
class CustomAccountManager(BaseUserManager):
def create_superuser(self, email, password, **other_fields):
other_fields.setdefault('is_staff', True)
other_fields.setdefault('is_superuser', True)
other_fields.setdefault('is_active', True)
if other_fields.get('is_staff') is not True:
raise ValueError('Супер пользователь должен быть назначен is_staff=True')
if other_fields.get('is_superuser') is not True:
raise ValueError('Супер пользователь должен быть назначен is_superuser=True')
return self.create_user(email, password, **other_fields)
def create_user(self, email, password, **other_fields):
if not email:
raise ValueError(_('Вы должны предоставить почту.'))
email = self.normalize_email(email)
user = self.model(email=email, **other_fields)
user.set_password(password)
user.save()
return user
class NewUser(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(_('почта'), unique=True)
start_date = models.DateTimeField(default=timezone.now())
is_staff = models.BooleanField(_('staff'),default=False)
is_active = models.BooleanField(_('активный'),default=True)
objects = CustomAccountManager()
USERNAME_FIELD = 'email'
def __str__(self):
return self.email
class Meta:
verbose_name = 'Пользователь'
verbose_name_plural = 'Пользователи'
views.py
from django.shortcuts import render, redirect
from .forms import AuthForm
from django.contrib.auth import authenticate, login
def signup(request):
error = ''
if request.method == 'POST':
form = AuthForm(request.POST)
if form.is_valid():
form.save()
user=form.data['email'], form.data['password']
return redirect('login')
else:
error = ValueError('Такая почта уже зарегестрированна')
form = AuthForm()
context={
'form': form,
'error': error,
}
return render(request, 'main/signup.html', context)
def LoginForm(request):
error = ''
if request.method == 'POST':
form = AuthForm(request.POST)
email = form.data['email']
password = form.data['password']
user = authenticate(request, email=email, password=password)
if user is not None:
login(request, user)
return redirect('home')
else:
error = ValueError('Такого аккаунта не сущетсвует')
form = AuthForm()
context={
'form': form,
'error': error,
}
return render(request, 'main/login.html', context)
def profile(request):
return render(request, 'main/profile.html')