CRUD API в Django для модели пользователя наследуется с AbstractBaseUser и также имеет класс Manager

view.py
class User(APIView):

    def get(self, request):
        queryset = User.object.all()
        serializer = UserDetails(queryset, many=True)
        return Response(serializer.data)
serializer.py
class UserDetails(serializers.ModelSerializer):
class Meta:
    model = User
    fields = ['username', 'password', 'hardware_id', 'created_by']
Модель пользователя [отдельно созданная модель]
from django.db import models
from django.contrib.auth.models import AbstractBaseUser
from wijungleapp.Manager import UserManager


class User(AbstractBaseUser):
    username = models.CharField(max_length=100, verbose_name="username", unique=True)
    password = models.CharField(max_length=100)
    hardware_id = models.CharField(max_length=150, null=True)
    created_by = models.DateField(verbose_name="created_by", auto_now_add=True)

USERNAME_FIELD = "username"
REQUIRED_FIELDS = ['password', 'hardware_id']

is_active = models.BooleanField(default=True)
is_admin = models.BooleanField(default=False)
is_role_vendor = models.BooleanField(default=False)
is_role_customer = models.BooleanField(default=True)

def __str__(self):
    return self.username

def has_perm(self, perm, obj=None):
    "Does the user have a specific permission?"
    # Simplest possible answer: Yes, always
    return True

def has_module_perms(self, app_label):
    "Does the user have permissions to view the app `app_label`?"
    # Simplest possible answer: Yes, always
    return True

def is_staff(self):
    "Is the user a member of staff?"
    # Simplest possible answer: All admins are staff
    return self.is_admin

object = UserManager()
managers.py
from django.contrib.auth.models import BaseUserManager


class UserManager(BaseUserManager):
    def create_user(self, username, password=None, password2=None, hardware_id=None):
    if not username:
        raise ValueError("UserName is Required !!!")

    user = self.model(
        username=username,
    )
    user.set_password(password)
    user.save(using=self._db)
    return user

# Create Super User Here
def create_superuser(self, username, password, hardware_id):
    user = self.create_user(
        username=username,
        password=password,
        hardware_id=hardware_id,
    )
    user.is_admin = True
    user.save(using=self._db)
    return user
Вернуться на верх