Spaces:
Running
Running
| from fastapi import FastAPI, Request, Response | |
| import httpx | |
| import os | |
| app = FastAPI() | |
| BACKEND_URL = os.environ.get("BACKEND_URL") | |
| AUTH_HEADER = os.environ.get("AUTH_HEADER") | |
| async def is_session_valid(session_token: str) -> bool: | |
| async with httpx.AsyncClient() as client: | |
| resp = await client.get( | |
| f"{BACKEND_URL}/user/session", | |
| params={"token": session_token}, | |
| headers={"Authorization": AUTH_HEADER} | |
| ) | |
| if resp.status_code != 200: | |
| return False | |
| result = resp.json() | |
| return result.get("valid", False) | |
| async def proxy(full_path: str, request: Request): | |
| url = f"{BACKEND_URL}/{full_path}" | |
| # Recebe o token de sessão no header 'token_session' | |
| session_token = request.headers.get("token_session") | |
| # Rotas públicas não exigem validação | |
| public_routes = ["user/login", "user/register", "user/session", "session/create"] | |
| if full_path not in public_routes: | |
| if not session_token or not await is_session_valid(session_token): | |
| return Response(content="Não autorizado", status_code=401) | |
| # Copia headers originais e sobrescreve Authorization com AUTH_HEADER | |
| headers = dict(request.headers) | |
| headers["Authorization"] = AUTH_HEADER | |
| # Remove headers que podem causar conflito | |
| for h in ["host", "content-length", "accept-encoding", "connection"]: | |
| headers.pop(h, None) | |
| # Remove o token_session do header antes de encaminhar ao backend | |
| headers.pop("token_session", None) | |
| body = await request.body() | |
| async with httpx.AsyncClient() as client: | |
| resp = await client.request( | |
| method=request.method, | |
| url=url, | |
| headers=headers, | |
| content=body if request.method != "GET" else None, | |
| params=dict(request.query_params) | |
| ) | |
| return Response( | |
| content=resp.content, | |
| status_code=resp.status_code, | |
| headers={k: v for k, v in resp.headers.items() if k.lower() not in ["content-encoding", "transfer-encoding", "connection"]} | |
| ) | |
| # Para rodar: | |
| # uvicorn proxy:app --reload --port 8000 |