diff options
| author | Tom Christie | 2012-10-05 05:11:17 -0700 |
|---|---|---|
| committer | Tom Christie | 2012-10-05 05:11:17 -0700 |
| commit | 2455bebd8733a11ba06dfbc33f9f2378025f538c (patch) | |
| tree | aeacef5a09d7bd815dd02fcb0baa5a81d777c9c5 /rest_framework/response.py | |
| parent | 5a14e3eff29c1c28ab1c217680d9f25b92405221 (diff) | |
| parent | 61a6d0c1094706db137b2fe57f117f263a61923d (diff) | |
| download | django-rest-framework-2455bebd8733a11ba06dfbc33f9f2378025f538c.tar.bz2 | |
Merge pull request #282 from tomchristie/html-template-responses
Html template responses
Diffstat (limited to 'rest_framework/response.py')
| -rw-r--r-- | rest_framework/response.py | 29 |
1 files changed, 12 insertions, 17 deletions
diff --git a/rest_framework/response.py b/rest_framework/response.py index db6bf3e2..9a633a8a 100644 --- a/rest_framework/response.py +++ b/rest_framework/response.py @@ -8,8 +8,8 @@ class Response(SimpleTemplateResponse): arbitrary media types. """ - def __init__(self, data=None, status=None, headers=None, - renderer=None, accepted_media_type=None): + def __init__(self, data=None, status=200, + template_name=None, headers=None): """ Alters the init arguments slightly. For example, drop 'template_name', and instead use 'data'. @@ -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_media_type = accepted_media_type + self.template_name = template_name @property def rendered_content(self): - assert self.renderer, "No renderer set on Response" + renderer = self.accepted_renderer + media_type = self.accepted_media_type + + assert renderer, "No accepted renderer set on Response" + assert media_type, "No accepted media type set on Response" - self['Content-Type'] = self.renderer.media_type + self['Content-Type'] = 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, media_type) @property def status_text(self): |
