У меня есть пользовательская модель со многими полями
class User(AbstractBaseUser, PermissionsMixin):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
email = models.EmailField(max_length=255, unique=True)
username = models.SlugField(max_length=255, unique=True)
first_name = models.CharField(max_length=255, blank=True, null=True)
last_name = models.CharField(max_length=255, blank=True, null=True)
avatar = models.ImageField(upload_to='users/avatar', default='users/avatar/avatar.png')
last_login = models.DateTimeField(blank=True, null=True)
member_since = models.DateTimeField(default=timezone.now, db_index=True)
is_active = models.BooleanField(default=True)
is_staff = models.BooleanField(default=False)
is_superuser = models.BooleanField(default=False)
В конкретном представлении меня интересует получение только имени пользователя и аватара пользователя, чтобы я мог вернуть ответ JSON, поэтому я делаю следующее:
users = User.objects.values('username', 'avatar')
Это вернет мне список словарей со следующими данными:
<QuerySet [
{'username': 'A', 'avatar': 'users/avatar/avatar.png'},
{'username': 'B', 'avatar': 'users/avatar/avatar.png'},
{'username': 'C', 'avatar': 'users/avatar/avatar.png'}
]>
Обратите внимание, что URL для аватара является относительным. Как я могу получить абсолютный URL без необходимости извлекать все поля пользователя?
Я бы хотел получить следующее:
<QuerySet [
{'username': 'A', 'avatar': 'http://example.com/media/users/avatar/avatar.png'},
{'username': 'B', 'avatar': 'http://example.com/media/users/avatar/avatar.png'},
{'username': 'C', 'avatar': 'http://example.com/media/users/avatar/avatar.png'}
]>