Mam pytanie dotyczące obsługi modeli m2m / through i ich prezentacji w frameworku django rest. Weźmy klasyczny przykład:
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
UZYSKUJĄC instancję członka pomyślnie otrzymuję wszystkie pola członka, a także jego grupy - jednak otrzymuję tylko szczegóły grup, bez dodatkowych szczegółów pochodzących z modelu członkostwa.
Innymi słowy, oczekuję, że otrzymam:
{
'id' : 2,
'name' : 'some member',
'groups' : [
{
'id' : 55,
'name' : 'group 1'
'join_date' : 34151564
},
{
'id' : 56,
'name' : 'group 2'
'join_date' : 11200299
}
]
}
Zwróć uwagę na join_date .
Wypróbowałem tak wiele rozwiązań, w tym oczywiście oficjalną stronę Django Rest-Framework na ten temat i nikt nie wydaje się udzielić właściwej, prostej odpowiedzi na ten temat - co mam zrobić, aby uwzględnić te dodatkowe pola? Wydało mi się to prostsze dzięki django-tastypie, ale miałem kilka innych problemów i wolę rest-framework.