Я пытаюсь определить поле, которое вычисляется на основе user_type
, я выполнил следующий метод, но он не работает, если кто-нибудь может посоветовать мне правильный подход.
так что я пытаюсь здесь нужно создать такой метод, как <user>.book_limit
, чтобы вернуть максимальное количество разрешенных книг на основе user_type
#models.py
class UserProfile(models.Model):
class UserType(models.TextChoices):
FREE = 'FR', 'FREE'
BASIC = 'BS', 'BASIC'
PREMIUM = 'PR', 'PREMIUM'
user = models.OneToOneField(User, on_delete=models.CASCADE, related_name='profile')
bio = models.CharField(max_length=255)
created_on = models.DateTimeField(auto_now_add=True)
last_updated = models.DateTimeField(auto_now=True)
user_type = models.CharField(max_length=2, choices=UserType.choices, default=UserType.FREE)
def __str__(self):
return self.user.username
@property
def borrow_limit(self):
return UserProfile.objects.annotate(book_limit=Case(
When(user_type=UserProfile.UserType.FREE, then=Value('1')),
When(user_type=UserProfile.UserType.BASIC, then=Value('2')),
When(user_type=UserProfile.UserType.PREMIUM, then=Value('5')),
default=Value('1'), output_field=IntegerField))