From e0a0cf1563524e2de884a65ae4d4388a2b7733f1 Mon Sep 17 00:00:00 2001 From: rohan-chaturvedi Date: Sun, 15 Oct 2023 19:50:46 +0530 Subject: [PATCH] feat: better exception handling in django --- backend/backend/exceptions.py | 36 +++++++++++++++++++++++++++++------ 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/backend/backend/exceptions.py b/backend/backend/exceptions.py index 61e138ce8..0aa38b7a9 100644 --- a/backend/backend/exceptions.py +++ b/backend/backend/exceptions.py @@ -1,18 +1,42 @@ from rest_framework.views import exception_handler from django.http import HttpResponse +from rest_framework import status def custom_exception_handler(exc, context): # Call REST framework's default exception handler first, # to get the standard error response. response = exception_handler(exc, context) - print("EXCEPTION", exc) - # set 404 as default response code - status_code = 404 - - # Now add the HTTP status code to the response. if response is not None: - status_code = response.status_code + return response # Return the default response if it's available + + # Define custom mappings of exception classes to HTTP status codes + exception_mappings = { + # Authentication exceptions + 'AuthenticationFailed': status.HTTP_401_UNAUTHORIZED, + + # Permission exceptions + 'PermissionDenied': status.HTTP_403_FORBIDDEN, + + # Validation exceptions + 'ValidationError': status.HTTP_400_BAD_REQUEST, + + # Not Found exception + 'ObjectDoesNotExist': status.HTTP_404_NOT_FOUND, + + # Any other unhandled exceptions + Exception: status.HTTP_500_INTERNAL_SERVER_ERROR, + } + + # Get the exception class of the raised exception + exception_class = exc.__class__ + + # Check if the exception class is in the mappings + if exception_class in exception_mappings: + status_code = exception_mappings[exception_class] + else: + # Default to 500 for unhandled exceptions + status_code = exception_mappings[Exception] return HttpResponse(status=status_code)