A FastAPI web app that plans a research workflow, runs tool-using agents (Tavily, arXiv, Wikipedia), and stores task state/results in Postgres. This repo includes a Docker setup that runs Postgres + the API in one container (for local/dev).
- /serves a simple UI (Jinja2 template) to kick off a research task.
- /generate_reportkicks off a threaded, multi-step agent workflow (planner → research/writer/editor).
- /task_progress/{task_id}live status for each step/substep.
- /task_status/{task_id}final status + report.
.
├─ main.py                      # FastAPI app (your file shown above)
├─ src/
│  ├─ planning_agent.py         # planner_agent(), executor_agent_step()
│  ├─ agents.py                 # research_agent, writer_agent, editor_agent  (example)
│  └─ research_tools.py         # tavily_search_tool, arxiv_search_tool, wikipedia_search_tool
├─ templates/
│  └─ index.html                # UI page rendered by "/"
├─ static/                      # optional static assets (css/js)
├─ docker/
│  └─ entrypoint.sh             # starts Postgres, prepares DB, then launches Uvicorn
├─ requirements.txt
├─ Dockerfile
└─ README.md
Make sure
templates/index.htmland (optionally)static/exist and are copied into the image.
- 
Docker (Desktop on Windows/macOS, or engine on Linux). 
- 
API keys stored in a .envfile:OPENAI_API_KEY=your-open-api-key TAVILY_API_KEY=your-tavily-api-key
- 
Python deps are installed by Docker from requirements.txt:- fastapi,- uvicorn,- sqlalchemy,- python-dotenv,- jinja2,- requests,- wikipedia, etc.
- Plus any libs used by your aisuiteclient.
 
The app reads only DATABASE_URL at startup.
- 
The container’s entrypoint sets a sane default for local dev: postgresql://app:[email protected]:5432/appdb
- 
To use Tavily: - Provide TAVILY_API_KEY(via.envor-e).
 
- Provide 
Optional (if you want to override defaults done by the entrypoint):
- POSTGRES_USER(default- app)
- POSTGRES_PASSWORD(default- local)
- POSTGRES_DB(default- appdb)
docker build -t fastapi-postgres-service .docker run --rm -it  -p 8000:8000  -p 5432:5432  --name fpsvc  --env-file .env  fastapi-postgres-serviceYou should see logs like:
🚀 Starting Postgres cluster 17/main...
✅ Postgres is ready
CREATE ROLE
CREATE DATABASE
🔗 DATABASE_URL=postgresql://app:[email protected]:5432/appdb
INFO:     Uvicorn running on http://0.0.0.0:8000
curl -X POST http://localhost:8000/generate_report \
  -H "Content-Type: application/json" \
  -d '{"prompt": "Large Language Models for scientific discovery", "model":"openai:gpt-4o"}'
# -> {"task_id": "UUID..."}curl http://localhost:8000/task_progress/<TASK_ID>curl http://localhost:8000/task_status/<TASK_ID>I open http://localhost:8000 and see nothing / errors
- 
Confirm templates/index.htmlexists inside the container:docker exec -it fpsvc bash -lc "ls -l /app/templates && ls -l /app/static || true" 
- 
Watch logs while you load the page: docker logs -f fpsvc 
Container asks for a Postgres password on startup
- 
The entrypoint uses UNIX socket + peer auth for admin tasks (no password). Ensure you’re not calling psql -h 127.0.0.1 -U postgresin the script—use:su -s /bin/bash postgres -c "psql -c '...'"
DATABASE_URL not set error
- 
The entrypoint exports a default DSN. If you overrode it, ensure it’s valid: postgresql://<user>:<password>@<host>:<port>/<database>
Tables disappear on restart
- 
In your main.pyyou callBase.metadata.drop_all(...)on startup. Comment it out or guard with an env flag:if os.getenv("RESET_DB_ON_STARTUP") == "1": Base.metadata.drop_all(bind=engine) 
Tavily / arXiv / Wikipedia errors
- Provide TAVILY_API_KEYand ensure network access, provide in the root dir and.envfile as follows:
# OpenAI API Key
OPENAI_API_KEY=your-open-api-key
TAVILY_API_KEY=your-tavily-api-key
- Wikipedia rate limits sometimes; try later or handle exceptions gracefully.
- 
Hot reload (optional): For dev, you can run Uvicorn with --reloadif you mount your code:docker run --rm -it -p 8000:8000 -p 5432:5432 \ -v "$PWD":/app \ --name fpsvc fastapi-postgres-service \ bash -lc "pg_ctlcluster \$(psql -V | awk '{print \$3}' | cut -d. -f1) main start && uvicorn main:app --host 0.0.0.0 --port 8000 --reload" 
- 
Connect to DB from host: psql "postgresql://app:local@localhost:5432/appdb"