1 changed files with 22 additions and 0 deletions
@ -0,0 +1,22 @@ |
|||||
|
import time |
||||
|
|
||||
|
from fastapi import FastAPI, Request, Response |
||||
|
from starlette.middleware.base import BaseHTTPMiddleware |
||||
|
|
||||
|
|
||||
|
class ProcessTimeHeaderMiddleware(BaseHTTPMiddleware): |
||||
|
async def dispatch(self, request: Request, call_next): |
||||
|
start_time = time.perf_counter() |
||||
|
response: Response = await call_next(request) |
||||
|
process_time = time.perf_counter() - start_time |
||||
|
response.headers["X-Process-Time"] = str(process_time) |
||||
|
return response |
||||
|
|
||||
|
|
||||
|
app = FastAPI() |
||||
|
app.add_middleware(ProcessTimeHeaderMiddleware) |
||||
|
|
||||
|
|
||||
|
@app.get("/") |
||||
|
def hello(): |
||||
|
return {"hello": "world"} |
Loading…
Reference in new issue