security: CORS + headers de seguridad para 3d.consultoria-as.com
- CORSMiddleware con dominio de produccion y localhost - SecurityHeadersMiddleware: X-Frame-Options, CSP, nosniff, referrer-policy - Titulo de app actualizado a PrintForge v2.2.0
This commit is contained in:
36
app/main.py
36
app/main.py
@@ -1,6 +1,8 @@
|
|||||||
from fastapi import FastAPI
|
from fastapi import FastAPI
|
||||||
from fastapi.staticfiles import StaticFiles
|
from fastapi.staticfiles import StaticFiles
|
||||||
from fastapi.responses import FileResponse
|
from fastapi.responses import FileResponse
|
||||||
|
from fastapi.middleware.cors import CORSMiddleware
|
||||||
|
from starlette.middleware.base import BaseHTTPMiddleware
|
||||||
from app.database import engine, Base
|
from app.database import engine, Base
|
||||||
from app.routers import models
|
from app.routers import models
|
||||||
from app.migrate import run_migrations
|
from app.migrate import run_migrations
|
||||||
@@ -10,7 +12,39 @@ import os
|
|||||||
Base.metadata.create_all(bind=engine)
|
Base.metadata.create_all(bind=engine)
|
||||||
run_migrations()
|
run_migrations()
|
||||||
|
|
||||||
app = FastAPI(title="STL Repository", version="2.1.0")
|
app = FastAPI(title="PrintForge", version="2.2.0")
|
||||||
|
|
||||||
|
# CORS — allow production domain and local development
|
||||||
|
app.add_middleware(
|
||||||
|
CORSMiddleware,
|
||||||
|
allow_origins=[
|
||||||
|
"https://3d.consultoria-as.com",
|
||||||
|
"http://localhost:8000",
|
||||||
|
"http://127.0.0.1:8000",
|
||||||
|
],
|
||||||
|
allow_credentials=True,
|
||||||
|
allow_methods=["*"],
|
||||||
|
allow_headers=["*"],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Security headers middleware
|
||||||
|
class SecurityHeadersMiddleware(BaseHTTPMiddleware):
|
||||||
|
async def dispatch(self, request, call_next):
|
||||||
|
response = await call_next(request)
|
||||||
|
response.headers["X-Frame-Options"] = "SAMEORIGIN"
|
||||||
|
response.headers["X-Content-Type-Options"] = "nosniff"
|
||||||
|
response.headers["Referrer-Policy"] = "strict-origin-when-cross-origin"
|
||||||
|
response.headers["Content-Security-Policy"] = (
|
||||||
|
"default-src 'self'; "
|
||||||
|
"script-src 'self' 'unsafe-inline' https://cdn.tailwindcss.com https://cdnjs.cloudflare.com https://cdn.jsdelivr.net; "
|
||||||
|
"style-src 'self' 'unsafe-inline'; "
|
||||||
|
"img-src 'self' data: blob:; "
|
||||||
|
"font-src 'self'; "
|
||||||
|
"connect-src 'self';"
|
||||||
|
)
|
||||||
|
return response
|
||||||
|
|
||||||
|
app.add_middleware(SecurityHeadersMiddleware)
|
||||||
|
|
||||||
app.include_router(models.router)
|
app.include_router(models.router)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user