Неправильная конфигурация в /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...

Вернуться на верх