1MR's picture
Update app.py
8e70d15 verified
raw
history blame
1.09 kB
from fastapi import FastAPI
from fastapi.responses import JSONResponse
from transformers import pipeline
from fastapi.requests import Request
app = FastAPI()
# Initialize the text generation pipeline
pipe = pipeline("text-generation", model="microsoft/Phi-3-mini-4k-instruct")
@app.middleware("http")
async def log_requests(request: Request, call_next):
print(f"Incoming request: {request.method} {request.url}")
response = await call_next(request)
return response
@app.get("/")
def read_root():
return {
"message": "Welcome to the FastAPI text generation API! Use the /generate endpoint with a 'text' query parameter."
}
@app.post("/generate")
def generate(payload: dict):
text = payload.get("text", "")
if not text:
raise HTTPException(status_code=400, detail="Text input is required.")
try:
output = pipe(text)
return {"output": output[0]["generated_text"]}
except Exception as e:
return JSONResponse(
status_code=500,
content={"error": f"An error occurred: {str(e)}"}
)