'How to inherent from a class that is already inherited from AbstractBaseUser in Django

I am trying to make an inheritance from a User class that is already inherited from the AbstractBaseUser but I am receiving an error that is telling me AUTH_USER_MODEL refers to model 'authentication.User' that has not been installed and I am sure I added the AUTH_USER_MODEL = 'authentication.User' in settings.py, I wonder how can I superpass this error and successfully inherent from the User Class this is the code:

from time import timezone

from django.contrib.auth.base_user import BaseUserManager, AbstractBaseUser
from django.contrib.auth.models import PermissionsMixin
from django.db import models


class ResidentType(models.TextChoices):
    Family = ('FM', 'Family')
    Individual = ('IV', 'Individual')


class UserManager(BaseUserManager):
    def create_user(self, username, first_name, last_name, email, password=None):
        if username is None:
            raise TypeError('User must have a username')
        if email is None:
            raise TypeError('User must have an Email')
        if first_name is None:
            raise TypeError('User must have a first_name')
        if last_name is None:
            raise TypeError('User must have a last_name')
        user = self.model(username=username, first_name=first_name, last_name=last_name,
                          email=self.normalize_email(email), )
        user.set_password(password)
        user.save()
        return user

    def create_admin(self, username, first_name, last_name, email, password=None):
        if username is None:
            raise TypeError('User must have a username')
        if email is None:
            raise TypeError('User must have an Email')
        if first_name is None:
            raise TypeError('User must have a first_name')
        if last_name is None:
            raise TypeError('User must have a last_name')
        admin = self.model(username=username, first_name=first_name, last_name=last_name,
                          email=self.normalize_email(email), )
        admin.set_password(password)
        Admin.admin = True
        Admin.is_active = True
        admin.save()
        return admin

    def create_syndic(self, username, first_name, last_name, email):
        password = User.objects.make_random_password()
        if username is None:
            raise TypeError('User must have a username')
        if email is None:
            raise TypeError('User must have an Email')
        if first_name is None:
            raise TypeError('User must have a first_name')
        if last_name is None:
            raise TypeError('User must have a last_name')
        syndic = self.model(username=username, first_name=first_name, last_name=last_name,
                          email=self.normalize_email(email), )
        syndic.set_password(password)
        Syndic.admin = True
        Syndic.staff = True
        Syndic.is_active = True
        syndic.save()
        return

    def create_resident(self, username, first_name, last_name, email, password=None):
        if username is None:
            raise TypeError('User must have a username')
        if email is None:
            raise TypeError('User must have an Email')
        if first_name is None:
            raise TypeError('User must have a first_name')
        if last_name is None:
            raise TypeError('User must have a last_name')
        resident = self.model(username=username, first_name=first_name, last_name=last_name,
                          email=self.normalize_email(email), )
        resident.set_password(password)
        Resident.admin = False
        Resident.staff = False
        Resident.is_active = False
        resident.save()
        return resident


class User(AbstractBaseUser, PermissionsMixin):
    username = models.CharField(max_length=255, unique=True, db_index=True)
    first_name = models.CharField(max_length=255, db_index=True)
    last_name = models.CharField(max_length=255, db_index=True)
    email = models.EmailField(max_length=255, unique=True, db_index=True)
    password = models.CharField(max_length=255, db_index=True)
    is_active = models.BooleanField(default=False)
    staff = models.BooleanField(default=False)
    admin = models.BooleanField(default=False)
    objects = UserManager()

    def __str__(self):
        return self.email

    def has_module_perms(self, app_label):
        return True

    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = []

    def get_full_name(self):
        return self.email

    def get_short_name(self):
        return self.email

    def has_perm(self, perm, obj=None):
        return True

    @property
    def is_staff(self):
        return self.staff

    @property
    def is_admin(self):
        return self.admin


    class Meta:
        abstract = True



class Admin(User):
    pass


class Syndic(User):
    admin = models.ForeignKey(Admin, on_delete=models.CASCADE)


class Resident(User):
    pass
    type = models.CharField(max_length=2, choices=ResidentType, default=ResidentType.Family)
    syndic = models.ForeignKey(Syndic, on_delete=models.CASCADE)


Solution 1:[1]

For anyone who will encounter this later, I have solved this issue by using proxy models rather than using the abstract classes, you can also make a one to one field from the User class and use it for the other classes or you can simply create a role attribute in the User model rather than making other models for it and keep tracking for the roles in each view you make.

Solution 2:[2]

I believe the problem is with making your custom User model an abstract model.

Please recheck, verify and confirm.

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Ghassen JemaĆ®
Solution 2 Subhash Tulsyan