Skip to content

Parsers

Setting the parsers

The default set of parsers may be set globally, using the DEFAULT_PARSER_CLASSES setting. For example, the following settings would allow requests with YAML content.

REST_FRAMEWORK = {
    'DEFAULT_PARSER_CLASSES': (
        'drf_yaml.parsers.YAMLParser',
    )
}

You can also set the parsers used for an individual view, or viewset, using the APIView class based views.

from rest_framework.response import Response
from rest_framework.views import APIView
from drf_yaml.parsers import YAMLParser

class ExampleView(APIView):
    """
    A view that can accept POST requests with YAML content.
    """
    parser_classes = (YAMLParser,)

    def post(self, request, format=None):
        return Response({'received data': request.DATA})

Or, if you're using the @api_view decorator with function based views.

@api_view(['POST'])
@parser_classes((YAMLParser,))
def example_view(request, format=None):
    """
    A view that can accept POST requests with YAML content.
    """
    return Response({'received data': request.DATA})

API Reference

YAMLParser

Parses YAML request content.

Requires the pyyaml package to be installed.

.media_type: application/yaml