linp / main.py
ka1kuk's picture
Update main.py
f196a8a
raw
history blame
No virus
1.13 kB
from fastapi import FastAPI, HTTPException, Request
from fastapi.middleware.cors import CORSMiddleware
from fastapi.responses import Response
import requests
app = FastAPI()
# Add CORS middleware to allow all origins. Adjust this in production!
app.add_middleware(
CORSMiddleware,
allow_origins=["*"],
allow_credentials=True,
allow_methods=["*"],
allow_headers=["*"],
)
@app.get("/")
@app.post("/")
async def proxy(request: Request, url: str):
headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36"
}
if request.method == "GET":
response = requests.get(url, headers=headers)
elif request.method == "POST":
data = await request.json() if request.headers.get("Content-Type") == "application/json" else None
response = requests.post(url, json=data, headers=headers)
return Response(content=response.content, status_code=response.status_code, headers=dict(response.headers))
if __name__ == "__main__":
import uvicorn
uvicorn.run(app, host="0.0.0.0", port=8000)