Source code for python_template_server.middleware.security_headers_middleware

"""Middleware to add security headers to all responses."""

from collections.abc import Awaitable, Callable

from fastapi import Request, Response
from starlette.middleware.base import BaseHTTPMiddleware
from starlette.types import ASGIApp


[docs] class SecurityHeadersMiddleware(BaseHTTPMiddleware): """Middleware to add security headers to all responses."""
[docs] def __init__(self, app: ASGIApp, hsts_max_age: int, csp: str) -> None: """Initialize the SecurityHeadersMiddleware.""" super().__init__(app) self.hsts_max_age = hsts_max_age self.csp = csp
[docs] async def dispatch(self, request: Request, call_next: Callable[[Request], Awaitable[Response]]) -> Response: """Add security headers to the response.""" response = await call_next(request) response.headers["Strict-Transport-Security"] = f"max-age={self.hsts_max_age}; includeSubDomains" response.headers["X-Content-Type-Options"] = "nosniff" response.headers["X-Frame-Options"] = "DENY" response.headers["Content-Security-Policy"] = self.csp response.headers["X-XSS-Protection"] = "1; mode=block" response.headers["Referrer-Policy"] = "strict-origin-when-cross-origin" return response