繁体   English   中英

如何在django-rest-swagger中指定查询参数序列化程序?

[英]How to specify a query parameter serializer in django-rest-swagger?

我正在使用Django REST Framework和django-rest-swagger为我的API创建可浏览的界面。 我可以使用YAML docstring指定请求正文序列化程序,但我还没有找到为请求查询参数指定序列化程序的方法。 我使用的视图很像:

class ListBans(BaseBanView):

    def get(self, request):
        """
        List all profile bans
        ---
        response_serializer: backend_serializers.BanSerializer
        request_serializer: moderator_serializers.ListBansSerializer
        """
        serializer = moderator_serializers.ListBansSerializer(data=request.query_params)
        if serializer.is_valid(raise_exception=True):
            # query profile bans
            data = []
            return APIResponse(status=status.HTTP_200_OK, data=data)

class ListBansSerializer(serializers.Serializer):
    limit = serializers.IntegerField(default=10, help_text='query limit')
    offset = serializers.IntegerField(default=0, help_text='query offset')

我想要实现的是让django-rest-swaggerListBansSerializer查询参数创建表单字段,这样我就不必在docstring中手动指定parameters部分。 有没有办法做到这一点?

我创建了一个简单的装饰器,它自动将查询参数附加到docstring。 该源可在github上获得 这是一个用法示例:

class ListBansSerializer(serializers.Serializer):
    limit = serializers.IntegerField(default=10, help_text='query limit')
    offset = serializers.IntegerField(default=0, help_text='query offset')


class ListBans(BaseBanView):
    @add_query_parameters(ListBansSerializer)
    def get(self, request):
        """
        List all profile bans
        ---
        response_serializer: backend_serializers.BanSerializer
        """
        serializer = moderator_serializers.ListBansSerializer(data=request.query_params)
        if serializer.is_valid(raise_exception=True):
            # query profile bans
            data = []
            return APIResponse(status=status.HTTP_200_OK, data=data)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM