init: initialized project struct

This commit is contained in:
ITQ
2025-01-19 19:02:41 +03:00
parent b76ad1afe8
commit a65fac7c9f
30 changed files with 1633 additions and 27 deletions
+77
View File
@@ -0,0 +1,77 @@
import logging
from http import HTTPStatus as status
import django.core.exceptions
import django.http
from django.http import HttpRequest, HttpResponse
from ninja import NinjaAPI, errors
logger = logging.getLogger("django")
def handle_django_validation_error(
request: HttpRequest,
exc: django.core.exceptions.ValidationError,
router: NinjaAPI,
) -> HttpResponse:
detail = list(exc)
if hasattr(exc, "error_dict"):
detail = dict(exc)
return router.create_response(
request,
{"detail": detail},
status=status.UNPROCESSABLE_ENTITY,
)
def handle_authentication_error(
request: HttpRequest, exc: errors.AuthenticationError, router: NinjaAPI
) -> HttpResponse:
return router.create_response(
request,
{"detail": status.UNAUTHORIZED.phrase},
status=status.UNAUTHORIZED,
)
def handle_validation_error(
request: HttpRequest, exc: errors.ValidationError, router: NinjaAPI
) -> HttpResponse:
return router.create_response(
request,
{"detail": exc.errors},
status=status.UNPROCESSABLE_ENTITY,
)
def handle_not_found_error(
request: HttpRequest, exc: Exception, router: NinjaAPI
) -> HttpResponse:
return router.create_response(
request,
{"detail": status.NOT_FOUND.phrase},
status=status.NOT_FOUND,
)
def handle_unknown_exception(
request: HttpRequest, exc: Exception, router: NinjaAPI
) -> HttpResponse:
logger.exception(exc)
return router.create_response(
request,
{"detail": status.INTERNAL_SERVER_ERROR.phrase},
status=status.INTERNAL_SERVER_ERROR,
)
exception_handlers = [
(django.core.exceptions.ValidationError, handle_django_validation_error),
(errors.AuthenticationError, handle_authentication_error),
(errors.ValidationError, handle_validation_error),
(django.http.Http404, handle_not_found_error),
(Exception, handle_unknown_exception),
]