У меня проблема с моим любимым приложением на django
Я разрабатываю сайт блога, и на моем сайте блога будет модуль избранного. Однако проблема в том, что я разработал пользовательскую модель пользователя с использованием JWT, но когда я пытаюсь получить доступ к разделу избранного с помощью этих пользователей, я получаю следующую ошибку. Когда я удаляю функцию qet_queryset
, все работает нормально, но мне нужно использовать ее, чтобы любимые посты пользователей отображались уникально для каждого из них, но я не смог найти альтернативный код, который я могу написать вместо нее. Вы можете помочь?
эта ошибка
TypeError at /api/favourites/list-create
Field 'id' expected a number but got <django.contrib.auth.models.AnonymousUser object at 0x000001E01402CA00>.
это мой любимый код/api/views.py
from favourite.api.seralizers import FavouriteListCreateSerializer
from favourite.models import Favourite
from rest_framework.generics import ListCreateAPIView
from rest_framework.permissions import IsAuthenticated
class FavouriteListCreateAPIView(ListCreateAPIView):
queryset = Favourite.objects.all()
serializer_class = FavouriteListCreateSerializer
permissions_classes = [IsAuthenticated]
def get_queryset(self):
return Favourite.objects.filter(user=self.request.user)
def perform_create(self, serializer):
serializer.save(user=self.request.user)
файл favoruites/api/serializers.py
from favourite.models import Favourite
from rest_framework.serializers import ModelSerializer
class FavouriteListCreateSerializer(ModelSerializer):
class Meta:
model = Favourite
fields = "__all__"
и, наконец, это моя пользовательская модель счета
from django.db import models
from django.utils import timezone
from django.utils.translation import gettext_lazy as _
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin, BaseUserManager
from django.utils.text import slugify
class CustomAccountManager(BaseUserManager):
def create_superuser(self, email, user_name, password, **other_fields):
other_fields.setdefault('is_staff', True)
other_fields.setdefault('is_superuser', True)
other_fields.setdefault('is_active', True)
if other_fields.get('is_staff') is not True:
raise ValueError(
'Superuser must be assigned to is_staff=True.')
if other_fields.get('is_superuser') is not True:
raise ValueError(
'Superuser must be assigned to is_superuser=True.')
return self.create_user(email, user_name, password, **other_fields)
def create_user(self, email, user_name, password, **other_fields):
if not email:
raise ValueError(_('You must provide an email address'))
email = self.normalize_email(email)
user = self.model(email=email, user_name=user_name,**other_fields)
user.set_password(password)
user.save()
return user
class Account(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(_('Email Adresi'), unique=True)
user_name = models.CharField(max_length=150, unique=True)
firstName = models.CharField(max_length=150, blank=True)
lastName = models.CharField(max_length=150, blank=True)
displayName = models.CharField(max_length=255)
avatar = models.ImageField(upload_to="avatar")
bgImage = models.ImageField(upload_to="background")
href = models.SlugField(editable=False, unique=True)
start_date = models.DateTimeField(default=timezone.now)
about = models.TextField(_(
'about'), max_length=500, blank=True)
jobName = models.CharField(max_length=100)
is_staff = models.BooleanField(default=False)
is_active = models.BooleanField(default=True)
objects = CustomAccountManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['user_name']
def __str__(self):
return self.user_name
def save(self, *args, **kwargs):
if not self.id:
self.href = slugify(self.displayName)
super(Account, self).save(*args, **kwargs)