-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapi.py
More file actions
91 lines (76 loc) · 3.2 KB
/
api.py
File metadata and controls
91 lines (76 loc) · 3.2 KB
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import os
from fastapi import FastAPI, HTTPException
from fastapi_mcp import FastApiMCP
from manageyourdata.data_manager import DataManager
from manageyourdata.utils import constants
dm = DataManager()
# Create MCP server from FastApi app.
app = FastAPI(title="ManageYourData")
mcp = FastApiMCP(app, name="ManageYourData")
mcp.mount()
@app.get("/")
def read_root():
return {"message": "¡Bienvenido a ManageYourData!"}
@app.get("/files/")
def list_files():
"""Lista los archivos disponibles en el directorio /data."""
try:
files = os.listdir("./data")
return {"files": files}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))
@app.post("/load-data/")
def load_data(file_name: str):
"""Carga un archivo de datos desde el directorio /data."""
try:
file_path = f"./data/{file_name}"
dm.load_data(file_path)
return {"message": f"Archivo {file_name} cargado correctamente."}
except FileNotFoundError:
raise HTTPException(status_code=404, detail="Archivo no encontrado.")
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))
@app.post("/generate-report/")
def generate_report():
"""Genera un informe PDF del archivo cargado."""
try:
if not dm.file_name:
raise HTTPException(status_code=400, detail="No se ha cargado ningún archivo.")
report_path = f"./reports/{dm.file_name}-report.pdf"
dm.report_pdf(report_path)
return {"message": f"Informe generado correctamente en {report_path}."}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))
@app.post("/export-data/")
def export_data(format: str):
"""Exporta los datos cargados en el formato especificado."""
try:
if not dm.file_name:
raise HTTPException(status_code=400, detail="No se ha cargado ningún archivo.")
if format not in constants.FORMAT:
raise HTTPException(status_code=400, detail="Formato no soportado.")
file_extension = constants.FORMAT[format]
dm.export_data(file_extension)
return {"message": f"Datos exportados correctamente."}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))
@app.post("/create-assistant/")
def create_assistant(provider: str, model: str, api_key: str = None):
"""Crea un asistente de IA para interactuar con los datos cargados."""
try:
if not dm.file_name:
raise HTTPException(status_code=400, detail="No se ha cargado ningún archivo.")
dm.create_assistant(provider, model, api_key)
return {"message": "Asistente de IA creado correctamente."}
except ValueError as e:
raise HTTPException(status_code=500, detail=str(e))
@app.post("/chat_with_assistant/")
def chat_with_assistant(prompt: str):
"""Interactúa con el asistente de IA utilizando el prompt proporcionado."""
try:
if not dm.agent:
raise HTTPException(status_code=400, detail="No se ha creado ningún asistente de IA.")
response = dm.chat_with_assistant(prompt)
return {"response": response}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))