Администратор Django, не может создать суперпользователя и войти в систему с пользовательской моделью пользователя - PullRequest
0 голосов
/ 21 декабря 2018

Я создал пользовательскую модель по имени Shop в django, и когда я создаю суперпользователя с помощью этой команды python manage.py createuperuser, он создает суперпользователя, но все еще устанавливает is_staff в False, is_superuser в False и также is_admin в false.Когда я пытаюсь войти в административную панель с помощью пользователя, я получаю сообщение об ошибке, что мои учетные данные неверны. Я перепробовал все и исследовал столько, сколько смог, но безрезультатно.Мне нужна помощь, это мой код

from django.db import models
from django.contrib.auth.models import AbstractBaseUser, BaseUserManager, 
PermissionsMixin
from django.utils.text import slugify
from django.utils.crypto import get_random_string # generates a random string 
from django.db import IntegrityError






class UserManager(BaseUserManager):

def create_user(self, email, shop_name='', mall_name='', password=None, **kwargs):
    if not email:
        raise ValueError('You must enter an email address')

    user = self.model(email=self.normalize_email(email), shop_name=shop_name, mall_name=mall_name)
    user.set_password(password)
    user.save(using=self._db)
    return user 


def create_superuser(self,email, password):

    user = self.create_user(
        email,
        password=password,
        is_admin=True,
        is_superuser=True,
        is_staff=True
    )
    user.save(using=self._db)
    return user


list_of_malls = [('Dubai mall', 'Dubai mall'),
             ('Dubai Festival City Mall','Dubai Festival City Mall'),
             ('Ibn Battuta Mall', 'Ibn Battuta Mall')

            ]

class Shop(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(unique=True, blank=False)
date_joined = models.DateTimeField(auto_now_add=True)
is_active = models.BooleanField(default=True)
is_superuser = models.BooleanField(default=False)
is_admin = models.BooleanField(default=False)
shop_name = models.CharField(max_length=50, null=True)
mall_name = models.CharField(choices=list_of_malls, max_length=50, null=True)
slug = models.SlugField(max_length=50, unique=True) 
is_staff = models.BooleanField(default=False)


objects = UserManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []

def save(self, *args, **kwargs):
    if not self.slug:
        try:
            self.slug = slugify(self.shop_name + " shop " + get_random_string(20) )
            super(Shop, self).save(*args, **kwargs)
            #add shop_name with 10 randomly generated characters to create slug

        except IntegrityError:
            pass 

def __str__(self):
    return self.email

Ответы [ 2 ]

0 голосов
/ 21 декабря 2018

Есть пара проблем с кодом, который вы опубликовали.

Во-первых, вы не передаете is_admin, is_superuser и is_staff пользовательской модели при ее создании в create_user().Эти аргументы фиксируются в kwargs и должны передаваться так:

def create_user(self, email, shop_name='', mall_name='', password=None, **kwargs):
    if not email:
        raise ValueError('You must enter an email address')

    user = self.model(
        email=self.normalize_email(email), 
        shop_name=shop_name, 
        mall_name=mall_name,
        **kwargs  # Pass the additional keyword arguments 
    )
    ...

Во-вторых, в save() методе Shop вы вызываете save() в суперклассе только когдане слизнякВызов super(Shop, self).save(), вероятно, должен всегда происходить - например,

def save(self, *args, **kwargs):
    try:
        if not self.slug:
            self.slug = slugify(self.shop_name + " shop " + get_random_string(20) )
        super(Shop, self).save(*args, **kwargs)  # Always call the save in the superclass
        #add shop_name with 10 randomly generated characters to create slug

    except IntegrityError:
        pass  # Bad idea to swallow exceptions.

Это также плохая идея, чтобы молча игнорировать IntegrityError.Лучше отказаться от попытки / исключить полностью, или хотя бы зарегистрировать ошибку.

0 голосов
/ 21 декабря 2018

Я думаю, это потому, что вы используете create_user в своей функции create_superuser, а в create_user вы не устанавливаете is_staff или is_superuser в True, как и вы.Попробуйте использовать вместо этого функцию create_superuser:

def create_superuser(self, email, password, **kwargs):
    user = self.model(
        email=email,
        is_staff=True,
        is_superuser=True,
        is_active=True,
        **kwargs
    )
    user.set_password(password)
    user.save(using=self._db)
    return user
...