Skip to content

Renderers

Setting the renderers

The default set of renderers may be set globally, using the DEFAULT_RENDERER_CLASSES setting. For example, the following settings would use YAML as the main media type and also include the self describing API.

REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES': (
        'drf_yaml.renderers.YAMLRenderer',
    )
}

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

from django.contrib.auth.models import User
from rest_framework.response import Response
from rest_framework.views import APIView
from drf_yaml.renderers import YAMLRenderer

class UserCountView(APIView):
    """
    A view that returns the count of active users in YAML.
    """
    renderer_classes = (YAMLRenderer,)

    def get(self, request, format=None):
        user_count = User.objects.filter(active=True).count()
        content = {'user_count': user_count}
        return Response(content)

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

@api_view(['GET'])
@renderer_classes((YAMLRenderer,))
def user_count_view(request, format=None):
    """
    A view that returns the count of active users in YAML.
    """
    user_count = User.objects.filter(active=True).count()
    content = {'user_count': user_count}
    return Response(content)

API Reference

YAMLRenderer

Renders the request data into YAML.

Requires the pyyaml package to be installed.

Note that non-ascii characters will be rendered using \uXXXX character escape. For example:

unicode black star: "\u2605"

.media_type: application/yaml

.format: '.yaml'

.charset: utf-8