У меня есть вопрос о работе с моделями m2m/through и их представлении в рамках django rest. Возьмем классический пример:
models.py:
from django.db import models
class Member(models.Model):
name = models.CharField(max_length = 20)
groups = models.ManyToManyField('Group', through = 'Membership')
class Group(models.Model):
name = models.CharField(max_length = 20)
class Membership(models.Model):
member = models.ForeignKey('Member')
group = models.ForeignKey('Group')
join_date = models.DateTimeField()
serializers.py:
imports...
class MemberSerializer(ModelSerializer):
class Meta:
model = Member
class GroupSerializer(ModelSerializer):
class Meta:
model = Group
views.py:
imports...
class MemberViewSet(ModelViewSet):
queryset = Member.objects.all()
serializer_class = MemberSerializer
class GroupViewSet(ModelViewSet):
queryset = Group.objects.all()
serializer_class = GroupSerializer
Когда GETing экземпляра Member, я успешно получаю все поля членов, а также его группы, но я получаю только данные групп, без дополнительных деталей, которые поступают из модели Membership.
Другими словами, я ожидаю:
{
'id' : 2,
'name' : 'some member',
'groups' : [
{
'id' : 55,
'name' : 'group 1'
'join_date' : 34151564
},
{
'id' : 56,
'name' : 'group 2'
'join_date' : 11200299
}
]
}
Обратите внимание на join_date.
Я пробовал так много решений, в том числе, конечно, официальная страница Django Rest-Framework об этом, и никто, кажется, не дает правильной простой ответьте на это - что мне нужно сделать, чтобы включить эти дополнительные поля? Я нашел это более прямолинейным с django-tastypie, но имел некоторые другие проблемы и предпочел отдых-рамки.