diff options
| author | Christopher Paolini | 2013-08-17 17:44:51 -0400 | 
|---|---|---|
| committer | Christopher Paolini | 2013-08-17 17:44:51 -0400 | 
| commit | e6662d434f0214d21d38e4388a40fd63e1f9dcc6 (patch) | |
| tree | 9da7194df8987b9f1bf194089bfea5be8cac55a7 /rest_framework/views.py | |
| parent | a95984e4d4b034c196d40f74fbdc6345e6d4124c (diff) | |
| download | django-rest-framework-e6662d434f0214d21d38e4388a40fd63e1f9dcc6.tar.bz2 | |
Improved view/description function setting
Now supports each View having its own name and description function and
overriding the global default.
Diffstat (limited to 'rest_framework/views.py')
| -rw-r--r-- | rest_framework/views.py | 27 | 
1 files changed, 20 insertions, 7 deletions
| diff --git a/rest_framework/views.py b/rest_framework/views.py index d51233a9..4553714a 100644 --- a/rest_framework/views.py +++ b/rest_framework/views.py @@ -12,7 +12,6 @@ from rest_framework.compat import View, HttpResponseBase  from rest_framework.request import Request  from rest_framework.response import Response  from rest_framework.settings import api_settings -from rest_framework.utils.formatting import get_view_name, get_view_description  class APIView(View): @@ -25,6 +24,9 @@ class APIView(View):      permission_classes = api_settings.DEFAULT_PERMISSION_CLASSES      content_negotiation_class = api_settings.DEFAULT_CONTENT_NEGOTIATION_CLASS +    view_name_function = api_settings.VIEW_NAME_FUNCTION +    view_description_function = api_settings.VIEW_DESCRIPTION_FUNCTION +      @classmethod      def as_view(cls, **initkwargs):          """ @@ -157,6 +159,21 @@ class APIView(View):              self._negotiator = self.content_negotiation_class()          return self._negotiator +    def get_view_name(self): +        """ +        Get the view name +        """ +        # This is used by ViewSets to disambiguate instance vs list views +        view_name_suffix = getattr(self, 'suffix', None) + +        return self.view_name_function(self.__class__, view_name_suffix) + +    def get_view_description(self, html=False): +        """ +        Get the view description +        """ +        return self.view_description_function(self.__class__, html) +      # API policy implementation methods      def perform_content_negotiation(self, request, force=False): @@ -342,16 +359,12 @@ class APIView(View):          Return a dictionary of metadata about the view.          Used to return responses for OPTIONS requests.          """ - -        # This is used by ViewSets to disambiguate instance vs list views -        view_name_suffix = getattr(self, 'suffix', None) -          # By default we can't provide any form-like information, however the          # generic views override this implementation and add additional          # information for POST and PUT methods, based on the serializer.          ret = SortedDict() -        ret['name'] = get_view_name(self.__class__, view_name_suffix) -        ret['description'] = get_view_description(self.__class__) +        ret['name'] = self.get_view_name() +        ret['description'] = self.get_view_description()          ret['renders'] = [renderer.media_type for renderer in self.renderer_classes]          ret['parses'] = [parser.media_type for parser in self.parser_classes]          return ret | 
