diff options
| author | Tom Christie | 2012-10-05 10:23:47 +0100 | 
|---|---|---|
| committer | Tom Christie | 2012-10-05 10:23:47 +0100 | 
| commit | d07dc77e91c1f99b47915b3cef30b565f2618e82 (patch) | |
| tree | 9f68ca55f685090f1672a557ce985931ccee47b3 /rest_framework/response.py | |
| parent | ad5e6eb16f4db928e1fc8d0a6af4f9f4584f7b08 (diff) | |
| download | django-rest-framework-d07dc77e91c1f99b47915b3cef30b565f2618e82.tar.bz2 | |
Accepted media type uses most specific of client/renderer media types.
Diffstat (limited to 'rest_framework/response.py')
| -rw-r--r-- | rest_framework/response.py | 23 | 
1 files changed, 9 insertions, 14 deletions
| diff --git a/rest_framework/response.py b/rest_framework/response.py index db6bf3e2..fca631c3 100644 --- a/rest_framework/response.py +++ b/rest_framework/response.py @@ -20,26 +20,21 @@ class Response(SimpleTemplateResponse):          super(Response, self).__init__(None, status=status)          self.data = data          self.headers = headers and headers[:] or [] -        self.renderer = renderer - -        # Accepted media type is the portion of the request Accept header -        # that the renderer satisfied.  It could be '*/*', or somthing like -        # application/json; indent=4 -        # -        # This is NOT the value that will be returned in the 'Content-Type' -        # header, but we do need to know the value in case there are -        # any specific parameters which affect the rendering process. + +        self.accepted_renderer = renderer          self.accepted_media_type = accepted_media_type      @property      def rendered_content(self): -        assert self.renderer, "No renderer set on Response" +        renderer = self.accepted_renderer + +        assert renderer, "No renderer set on Response" -        self['Content-Type'] = self.renderer.media_type +        self['content-type'] = self.accepted_media_type          if self.data is None: -            return self.renderer.render() -        render_media_type = self.accepted_media_type or self.renderer.media_type -        return self.renderer.render(self.data, render_media_type) +            return renderer.render() + +        return renderer.render(self.data, self.accepted_media_type)      @property      def status_text(self): | 
