suna/backend/api.py

87 lines
2.5 KiB
Python
Raw Normal View History

2025-04-11 10:45:32 +08:00
from fastapi import FastAPI
2025-03-30 14:48:57 +08:00
from fastapi.middleware.cors import CORSMiddleware
from contextlib import asynccontextmanager
from agentpress.thread_manager import ThreadManager
from services.supabase import DBConnection
from datetime import datetime, timezone
from dotenv import load_dotenv
import asyncio
2025-04-02 02:49:35 +08:00
from utils.logger import logger
import uuid
2025-03-30 14:48:57 +08:00
# Import the agent API module
from agent import api as agent_api
2025-04-18 22:04:11 +08:00
from sandbox import api as sandbox_api
2025-03-30 14:48:57 +08:00
# Load environment variables
load_dotenv()
# Initialize managers
db = DBConnection()
thread_manager = None
instance_id = str(uuid.uuid4())[:8] # Generate instance ID at module load time
2025-03-30 14:48:57 +08:00
@asynccontextmanager
async def lifespan(app: FastAPI):
# Startup
global thread_manager
logger.info(f"Starting up FastAPI application with instance ID: {instance_id}")
2025-03-30 14:48:57 +08:00
await db.initialize()
thread_manager = ThreadManager()
# Initialize the agent API with shared resources
agent_api.initialize(
thread_manager,
db,
instance_id # Pass the instance_id to agent_api
2025-03-30 14:48:57 +08:00
)
2025-04-18 22:04:11 +08:00
# Initialize the sandbox API with shared resources
sandbox_api.initialize(db)
2025-03-30 14:48:57 +08:00
# Initialize Redis before restoring agent runs
from services import redis
await redis.initialize_async()
asyncio.create_task(agent_api.restore_running_agent_runs())
yield
# Clean up agent resources (including Redis)
2025-04-01 10:36:26 +08:00
logger.info("Cleaning up agent resources")
2025-03-30 14:48:57 +08:00
await agent_api.cleanup()
# Clean up database connection
2025-04-01 10:36:26 +08:00
logger.info("Disconnecting from database")
2025-03-30 14:48:57 +08:00
await db.disconnect()
app = FastAPI(lifespan=lifespan)
app.add_middleware(
CORSMiddleware,
2025-04-21 08:29:57 +08:00
allow_origins=["https://www.suna.so", "https://suna.so", "https://staging.suna.so", "http://localhost:3000"],
2025-03-30 14:48:57 +08:00
allow_credentials=True,
allow_methods=["GET", "POST", "PUT", "DELETE", "OPTIONS"],
allow_headers=["Content-Type", "Authorization"],
2025-03-30 14:48:57 +08:00
)
# Include the agent router with a prefix
app.include_router(agent_api.router, prefix="/api")
2025-04-11 09:35:29 +08:00
# Include the sandbox router with a prefix
2025-04-18 22:04:11 +08:00
app.include_router(sandbox_api.router, prefix="/api")
2025-04-11 09:35:29 +08:00
2025-03-30 14:48:57 +08:00
@app.get("/api/health-check")
async def health_check():
"""Health check endpoint to verify API is working."""
2025-04-01 10:36:26 +08:00
logger.info("Health check endpoint called")
return {
"status": "ok",
"timestamp": datetime.now(timezone.utc).isoformat(),
"instance_id": instance_id
}
2025-03-30 14:48:57 +08:00
if __name__ == "__main__":
import uvicorn
2025-04-01 10:36:26 +08:00
logger.info("Starting server on 0.0.0.0:8000")
2025-03-30 14:48:57 +08:00
uvicorn.run(app, host="0.0.0.0", port=8000)