Clawith/backend/app/core/middleware.py

55 lines
1.6 KiB
Python

"""FastAPI middleware for request tracing and logging."""
import uuid
import time
from fastapi import Request, Response
from starlette.middleware.base import BaseHTTPMiddleware
from app.core.logging_config import set_trace_id, get_trace_id
from loguru import logger
class TraceIdMiddleware(BaseHTTPMiddleware):
"""Middleware to inject trace ID into request context and log requests."""
async def dispatch(self, request: Request, call_next) -> Response:
# Generate or extract trace ID from header
trace_id = request.headers.get("X-Trace-Id") or str(uuid.uuid4())[:12]
set_trace_id(trace_id)
# Add trace ID to request state for access in endpoints
request.state.trace_id = trace_id
start_time = time.time()
# Log request
client_host = request.client.host if request.client else "-"
logger.info(
f"--> {request.method} {request.url.path} "
f"[client: {client_host}]"
)
try:
response = await call_next(request)
duration = time.time() - start_time
# Add trace ID to response headers
response.headers["X-Trace-Id"] = trace_id
# Log response
logger.info(
f"<-- {request.method} {request.url.path} "
f"{response.status_code} {duration:.3f}s"
)
return response
except Exception as exc:
duration = time.time() - start_time
logger.error(
f"<-- {request.method} {request.url.path} "
f"ERROR {duration:.3f}s - {exc}"
)
raise