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/views.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/views.py')
| -rw-r--r-- | rest_framework/views.py | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/rest_framework/views.py b/rest_framework/views.py index 2bbdbe17..0359c225 100644 --- a/rest_framework/views.py +++ b/rest_framework/views.py @@ -199,20 +199,26 @@ class APIView(View): Runs anything that needs to occur prior to calling the method handlers. """ self.format = self.get_format_suffix(**kwargs) + if not self.has_permission(request): self.permission_denied(request) self.check_throttles(request) - self.renderer, self.accepted_media_type = self.perform_content_negotiation(request) + + # Perform content negotiation and store the accepted info on the request + neg = self.perform_content_negotiation(request) + request.accepted_renderer, request.accepted_media_type = neg def finalize_response(self, request, response, *args, **kwargs): """ Returns the final response object. """ if isinstance(response, Response): - if not getattr(self, 'renderer', None): - self.renderer, self.accepted_media_type = self.perform_content_negotiation(request, force=True) - response.renderer = self.renderer - response.accepted_media_type = self.accepted_media_type + if not getattr(request, 'accepted_renderer', None): + neg = self.perform_content_negotiation(request, force=True) + request.accepted_renderer, request.accepted_media_type = neg + + response.accepted_renderer = request.accepted_renderer + response.accepted_media_type = request.accepted_media_type for key, value in self.headers.items(): response[key] = value |
