mirror of
https://github.com/rjNemo/fastapi
synced 2026-06-06 02:26:46 +00:00
* ✨ Re-export main features used from Starlette to simplify developer's code * ♻️ Refactor Starlette exports * ♻️ Refactor tutorial examples to use re-exported utils from Starlette * 📝 Add examples for all middlewares * 📝 Add new docs for middlewares * 📝 Add examples for custom responses * 📝 Extend docs for custom responses * 📝 Update docs and add notes explaining re-exports from Starlette everywhere * 🍱 Update screenshot for HTTP status * 🔧 Update MkDocs config with new content * ♻️ Refactor tests to use re-exported utils from Starlette * ✨ Re-export WebSocketDisconnect from Starlette for tests * ✅ Add extra tests for extra re-exported middleware * ✅ Add tests for re-exported responses from Starlette * ✨ Add docs about mounting WSGI apps * ➕ Add Flask as a dependency to test WSGIMiddleware * ✅ Test WSGIMiddleware example
29 lines
935 B
Python
29 lines
935 B
Python
from typing import Callable, List
|
|
|
|
from fastapi import Body, FastAPI, HTTPException, Request, Response
|
|
from fastapi.exceptions import RequestValidationError
|
|
from fastapi.routing import APIRoute
|
|
|
|
|
|
class ValidationErrorLoggingRoute(APIRoute):
|
|
def get_route_handler(self) -> Callable:
|
|
original_route_handler = super().get_route_handler()
|
|
|
|
async def custom_route_handler(request: Request) -> Response:
|
|
try:
|
|
return await original_route_handler(request)
|
|
except RequestValidationError as exc:
|
|
body = await request.body()
|
|
detail = {"errors": exc.errors(), "body": body.decode()}
|
|
raise HTTPException(status_code=422, detail=detail)
|
|
|
|
return custom_route_handler
|
|
|
|
|
|
app = FastAPI()
|
|
app.router.route_class = ValidationErrorLoggingRoute
|
|
|
|
|
|
@app.post("/")
|
|
async def sum_numbers(numbers: List[int] = Body(...)):
|
|
return sum(numbers)
|