File size: 1,434 Bytes
b9a8526
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
from fastapi import FastAPI
from pydantic import BaseModel
from typing import List
from langchain_community.tools.tavily_search import TavilySearchResults
import os
from langgraph.prebuilt import create_react_agent
from langchain_openai import AzureChatOpenAI
from dotenv import load_dotenv
load_dotenv()
os.environ['AZURE_OPENAI_API_KEY'] = os.getenv('AZURE_OPENAI_API_KEY')
os.environ['OPENAI_API_VERSION'] = os.getenv('OPENAI_API_VERSION')
os.environ['AZURE_OPENAI_ENDPOINT'] = os.getenv('AZURE_OPENAI_ENDPOINT')
os.environ['TAVILY_API_KEY'] = os.getenv('TAVILY_API_KEY')

MODEL_NAME = [
   "gpt-4o"
]

tool = TavilySearchResults(max_results=5)

tools = [tool, ]

app = FastAPI()

class RequestState(BaseModel):
    model_name: str
    system_prompt: str
    messages: List[str]

@app.post("/chat")
def chat_endpoint(request: RequestState):
    """API Endpoint to chat with bot"""
    if request.model_name not in MODEL_NAME:
        return {"error": "Model not found"}
    
    llm = AzureChatOpenAI(
    azure_deployment="gpt-4o", 
    temperature=0,
    max_tokens=None,
    timeout=None,
    max_retries=2,
)
    agent = create_react_agent(llm, tools=tools, prompt=request.system_prompt)
    state = {"messages": request.messages}
    result = agent.invoke(state)
    return result

if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="0.0.0.0", port=8000)