Неправильная конфигурация в /admin/auth/group/
Я пытаюсь создать несколько баз данных в Django и использовать Djoser для аутентификации пользователей. Я смог создать суперпользователя и войти на сайт администратора. Однако, когда я пытаюсь перейти на http://127.0.0.1:8000/admin/auth/group/, я получаю следующую ошибку: "ImproperlyConfigured at /admin/auth/group/" Это также происходит, когда я использую postman для тестирования конечной точки Djoser User Create:
ImproperlyConfigured at /auth/users/
settings.DATABASES is improperly configured. Please supply the ENGINE value
Это мой settings.py:
DATABASES = {
'default': {},
'users': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'sapienslevel_users',
'USER': 'postgres',
'HOST': 'localhost',
'PASSWORD': get_secret('DB_PASSWORD')
},
'questions': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'sapienslevel_questions',
'USER': 'postgres',
'HOST': 'localhost',
'PASSWORD': get_secret('DB_PASSWORD')
}
}
DATABASE_ROUTERS = ['users.router.AuthRouter', 'questions.router.QuestionRouter']
Это мой AuthRouter:
class AuthRouter:
route_app_labels = {'users', 'admin', 'contenttypes', 'sessions', }
def db_for_read(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'users'
return None
def db_for_write(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'users'
return None
def allow_relation(self, obj1, obj2, **hints):
if (
obj1._meta.app_label in self.route_app_labels or
obj2._meta.app_label in self.route_app_labels
):
return True
return None
def allow_migrate(self, db, app_label, model_name=None, **hints):
if app_label in self.route_app_labels:
return db == 'users'
return None
И моя пользовательская модель пользователя:
from django.db import models
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin, BaseUserManager
class UserAccountManager(BaseUserManager):
def create_user(self, email, name, password=None):
if not email:
raise ValueError('Los usuarios deben tener email')
email = self.normalize_email(email)
email = email.lower()
user = self.model(
email=email,
name=name
)
user.set_password(password)
user.save(using=self._db)
return user
def create_teacher(self, email, name, password=None):
user = self.create_user(email, name, password)
user.is_teacher = True
user.save(using=self._db)
return user
def create_student(self, email, name, password=None):
user = self.create_user(email, name, password)
user.is_student = True
user.save(using=self._db)
return user
def create_superuser(self, email, name, password=None):
user = self.create_user(email, name, password)
user.is_superuser = True
user.is_staff = True
user.save(using=self._db)
return user
class UserAccount(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(max_length=254, unique=True)
name = models.CharField(max_length=255)
is_active = models.BooleanField(default=False)
is_staff = models.BooleanField(default=False)
is_teacher = models.BooleanField(default=True)
is_student = models.BooleanField(default=False)
objects = UserAccountManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['name']
def __str__(self):
return self.email
Я смог создать суперпользователя, а также запустить makemigrations и migrate...