| import os |
| from pydantic import BaseModel |
| from fastapi import FastAPI, HTTPException, Query |
| from fastapi.responses import FileResponse |
| from fastapi.middleware.cors import CORSMiddleware |
|
|
| from langchain.chains import LLMChain |
| from langchain.prompts import PromptTemplate |
| from langchain_google_genai import ( |
| ChatGoogleGenerativeAI, |
| HarmBlockThreshold, |
| HarmCategory, |
| ) |
| from TextGen import app |
| from gradio_client import Client |
|
|
|
|
| my_hf_token=os.environ["HF_TOKEN"] |
|
|
| tts_client = Client("https://jofthomas-xtts.hf.space/--replicas/sxv98/",hf_token=my_hf_token) |
|
|
|
|
|
|
| class Generate(BaseModel): |
| text:str |
|
|
| def generate_text(prompt: str): |
| if prompt == "": |
| return {"detail": "Please provide a prompt."} |
| else: |
| prompt = PromptTemplate(template=prompt, input_variables=['Prompt']) |
|
|
| |
| llm = ChatGoogleGenerativeAI( |
| model="gemini-pro", |
| safety_settings={ |
| HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT: HarmBlockThreshold.BLOCK_NONE, |
| }, |
| ) |
|
|
| llmchain = LLMChain( |
| prompt=prompt, |
| llm=llm |
| ) |
|
|
| llm_response = llmchain.run({"Prompt": prompt}) |
| return Generate(text=llm_response) |
|
|
| |
|
|
| app.add_middleware( |
| CORSMiddleware, |
| allow_origins=["*"], |
| allow_credentials=True, |
| allow_methods=["*"], |
| allow_headers=["*"], |
| ) |
|
|
| @app.get("/", tags=["Home"]) |
| def api_home(): |
| return {'detail': 'Welcome to FastAPI TextGen Tutorial!'} |
|
|
| @app.post("/api/generate", summary="Generate text from prompt", tags=["Generate"], response_model=Generate) |
| def inference(input_prompt: str): |
| return generate_text(prompt=input_prompt) |
|
|
| @app.get("/generate_wav") |
| async def generate_wav(text: str, language: str = "en"): |
| try: |
| |
| result = tts_client.predict( |
| text, |
| language, |
| "./narator_out.wav", |
| "./narator_out.wav", |
| False, |
| False, |
| False, |
| True, |
| fn_index=1 |
| ) |
|
|
| |
| wav_file_path = result[1] |
|
|
| |
| return FileResponse(wav_file_path, media_type="audio/wav", filename="output.wav") |
|
|
| except Exception as e: |
| raise HTTPException(status_code=500, detail=str(e)) |