diff options
| author | Tom Christie | 2012-09-20 13:06:27 +0100 | 
|---|---|---|
| committer | Tom Christie | 2012-09-20 13:06:27 +0100 | 
| commit | 4b691c402707775c3048a90531024f3bc5be6f91 (patch) | |
| tree | 3adfc54b0d8b70e4ea78edf7091f7827fa68f47b /rest_framework/response.py | |
| parent | a1bcfbfe926621820832e32b0427601e1140b4f7 (diff) | |
| download | django-rest-framework-4b691c402707775c3048a90531024f3bc5be6f91.tar.bz2 | |
Change package name: djangorestframework -> rest_framework
Diffstat (limited to 'rest_framework/response.py')
| -rw-r--r-- | rest_framework/response.py | 39 | 
1 files changed, 39 insertions, 0 deletions
| diff --git a/rest_framework/response.py b/rest_framework/response.py new file mode 100644 index 00000000..29034e25 --- /dev/null +++ b/rest_framework/response.py @@ -0,0 +1,39 @@ +from django.template.response import SimpleTemplateResponse +from django.core.handlers.wsgi import STATUS_CODE_TEXT + + +class Response(SimpleTemplateResponse): +    """ +    An HttpResponse that allows it's data to be rendered into +    arbitrary media types. +    """ + +    def __init__(self, data=None, status=None, headers=None, +                 renderer=None, media_type=None): +        """ +        Alters the init arguments slightly. +        For example, drop 'template_name', and instead use 'data'. + +        Setting 'renderer' and 'media_type' will typically be defered, +        For example being set automatically by the `APIView`. +        """ +        super(Response, self).__init__(None, status=status) +        self.data = data +        self.headers = headers and headers[:] or [] +        self.renderer = renderer +        self.media_type = media_type + +    @property +    def rendered_content(self): +        self['Content-Type'] = self.renderer.media_type +        if self.data is None: +            return self.renderer.render() +        return self.renderer.render(self.data, self.media_type) + +    @property +    def status_text(self): +        """ +        Returns reason text corresponding to our HTTP response status code. +        Provided for convenience. +        """ +        return STATUS_CODE_TEXT.get(self.status_code, '') | 
