mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-08-04 20:40:14 +03:00
Moved the logic to determine which handler for the view to use into a separate method outside of
dispatch.
This commit is contained in:
parent
93633c297c
commit
be3086b0e1
|
@ -376,6 +376,17 @@ class APIView(View):
|
|||
response.exception = True
|
||||
return response
|
||||
|
||||
def get_handler(self, request, *args, **kwargs):
|
||||
"""
|
||||
Return the appropriate handler method.
|
||||
"""
|
||||
if request.method.lower() in self.http_method_names:
|
||||
handler = getattr(self, request.method.lower(),
|
||||
self.http_method_not_allowed)
|
||||
else:
|
||||
handler = self.http_method_not_allowed
|
||||
return handler
|
||||
|
||||
# Note: Views are made CSRF exempt from within `as_view` as to prevent
|
||||
# accidental removal of this exemption in cases where `dispatch` needs to
|
||||
# be overridden.
|
||||
|
@ -392,16 +403,8 @@ class APIView(View):
|
|||
|
||||
try:
|
||||
self.initial(request, *args, **kwargs)
|
||||
|
||||
# Get the appropriate handler method
|
||||
if request.method.lower() in self.http_method_names:
|
||||
handler = getattr(self, request.method.lower(),
|
||||
self.http_method_not_allowed)
|
||||
else:
|
||||
handler = self.http_method_not_allowed
|
||||
|
||||
handler = self.get_handler(request, *args, **kwargs)
|
||||
response = handler(request, *args, **kwargs)
|
||||
|
||||
except Exception as exc:
|
||||
response = self.handle_exception(exc)
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user