You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
EVAL/api/main.py

129 lines
3.3 KiB
Python

from typing import Dict, List, TypedDict
1 year ago
import re
import uvicorn
1 year ago
import torch
1 year ago
from fastapi import FastAPI
from fastapi.staticfiles import StaticFiles
1 year ago
from pydantic import BaseModel
from env import settings
1 year ago
from core.prompts.error import ERROR_PROMPT
from core.agents.manager import AgentManager
from core.tools.base import BaseToolSet
from core.tools.terminal import Terminal
from core.tools.editor import CodeEditor
from core.tools.cpu import (
RequestsGet,
WineDB,
ExitConversation,
)
from core.tools.gpu import (
ImageEditing,
InstructPix2Pix,
Text2Image,
VisualQuestionAnswering,
)
from core.handlers.base import BaseHandler, FileHandler, FileType
from core.handlers.image import ImageCaptioning
from core.handlers.dataframe import CsvToDataframe
from core.upload import StaticUploader
from logger import logger
1 year ago
app = FastAPI()
app.mount("/static", StaticFiles(directory=StaticUploader.STATIC_DIR), name="static")
uploader = StaticUploader.from_settings(settings)
use_gpu = settings["USE_GPU"] and torch.cuda.is_available()
toolsets: List[BaseToolSet] = [
Terminal(),
CodeEditor(),
RequestsGet(),
ExitConversation(),
]
if use_gpu:
toolsets.extend(
[
Text2Image("cuda"),
ImageEditing("cuda"),
InstructPix2Pix("cuda"),
VisualQuestionAnswering("cuda"),
]
)
handlers: Dict[FileType, BaseHandler] = {}
handlers[FileType.DATAFRAME] = CsvToDataframe()
if use_gpu:
handlers[FileType.IMAGE] = ImageCaptioning("cuda")
if settings["WINEDB_HOST"] and settings["WINEDB_PASSWORD"]:
toolsets.append(WineDB())
agent_manager = AgentManager.create(toolsets=toolsets)
file_handler = FileHandler(handlers=handlers)
1 year ago
class Request(BaseModel):
key: str
query: str
files: List[str]
1 year ago
class Response(TypedDict):
response: str
files: List[str]
1 year ago
@app.get("/")
async def index():
return {"message": f"Hello World. I'm {settings['BOT_NAME']}."}
1 year ago
@app.post("/command")
async def command(request: Request) -> Response:
query = request.query
1 year ago
files = request.files
session = request.key
1 year ago
logger.info("=============== Running =============")
logger.info(f"Query: {query}, Files: {files}")
executor = agent_manager.get_or_create_executor(session)
logger.info(f"======> Previous memory:\n\t{executor.memory}")
1 year ago
promptedQuery = "\n".join([file_handler.handle(file) for file in files])
promptedQuery += query
logger.info(f"======> Prompted Text:\n\t{promptedQuery}")
1 year ago
try:
res = executor({"input": promptedQuery})
1 year ago
except Exception as e:
logger.error(f"error while processing request: {str(e)}")
1 year ago
try:
res = executor(
1 year ago
{
"input": ERROR_PROMPT.format(promptedQuery=promptedQuery, e=str(e)),
1 year ago
}
)
except Exception as e:
return {"response": str(e), "files": []}
1 year ago
images = re.findall("(image/\S*png)", res["output"])
dataframes = re.findall("(dataframe/\S*csv)", res["output"])
1 year ago
return {
"response": res["output"],
"files": [uploader.upload(image) for image in images]
+ [uploader.upload(dataframe) for dataframe in dataframes],
1 year ago
}
def serve():
uvicorn.run("api.main:app", host="0.0.0.0", port=settings["PORT"])