在我的应用程序中,我有以下模型:
class Zone(models.Model):
name = models.SlugField()
class ZonePermission(models.Model):
zone = models.ForeignKey('Zone')
user = models.ForeignKey(User)
is_administrator = models.BooleanField()
is_active = models.BooleanField()
我正在使用 Django REST 框架来创建一个资源,该资源返回区域详细信息以及显示经过身份验证的用户对该区域的权限的嵌套资源。输出应该是这样的:
{
"name": "test",
"current_user_zone_permission": {
"is_administrator": true,
"is_active": true
}
}
我已经创建了这样的序列化程序:
class ZonePermissionSerializer(serializers.ModelSerializer):
class Meta:
model = ZonePermission
fields = ('is_administrator', 'is_active')
class ZoneSerializer(serializers.HyperlinkedModelSerializer):
current_user_zone_permission = ZonePermissionSerializer(source='zonepermission_set')
class Meta:
model = Zone
fields = ('name', 'current_user_zone_permission')
这样做的问题是,当我请求特定区域时,嵌套资源会返回具有该区域权限的所有用户的 ZonePermission 记录。有没有办法对request.user
嵌套资源应用过滤器?
顺便说一句,我不想为此使用 a HyperlinkedIdentityField
(以尽量减少 http 请求)。
解决方案
这是我根据以下答案实施的解决方案。我将以下代码添加到我的序列化程序类中:
current_user_zone_permission = serializers.SerializerMethodField('get_user_zone_permission')
def get_user_zone_permission(self, obj):
user = self.context['request'].user
zone_permission = ZonePermission.objects.get(zone=obj, user=user)
serializer = ZonePermissionSerializer(zone_permission)
return serializer.data
非常感谢您的解决方案!