-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexceptions.py
54 lines (32 loc) · 1.4 KB
/
exceptions.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import logging
from fastapi import FastAPI, Request, Response
from fastapi.encoders import jsonable_encoder
from fastapi.exceptions import RequestValidationError
from fastapi.responses import JSONResponse
from sqlalchemy.exc import InvalidRequestError
from . import __name__ as mod_name
from .schemas import Error
logger = logging.getLogger(mod_name)
class ItemNotFound(Exception):
pass
ValidationFailed = RequestValidationError([])
response_400 = JSONResponse(status_code=400, content=jsonable_encoder(
Error(code=400, message="Validation Failed")))
response_404 = JSONResponse(status_code=404, content=jsonable_encoder(
Error(code=404, message="Item not found")))
def log_handler(request: Request, exc: Exception) -> None:
logger.error(f"Error handler: request={vars(request)}")
logger.error(f"Error handler: exception={exc!r} | {vars(exc)}")
async def handler_400(request: Request, exc: Exception) -> Response:
log_handler(request, exc)
return response_400
async def handler_404(request: Request, exc: Exception) -> Response:
log_handler(request, exc)
return response_404
def add_exception_handlers(app: FastAPI) -> None:
app.exception_handler(RequestValidationError)(handler_400)
app.exception_handler(ItemNotFound)(handler_404)
class NotEnoughResultsFound(InvalidRequestError):
"""
A database result was required to be specific length but was not.
"""