- Add app/db/ abstraction layer: Backend enum, DbConn wrapper, dialect helper (q() for ? vs %s paramstyle), get_conn(), tenant_id() - Auto-detect backend from DATABASE_URL; SQLite remains default when unset — no config change for local deployments - Add tenant_id column to all three logical DBs (main, context, incidents); idempotent ALTER TABLE migration runs before schema scripts on existing DBs - All INSERTs inject tenant_id; SELECTs use (tenant_id = ? OR tenant_id = '') for backward compat with pre-namespacing rows - Add docker-compose.yml with named volume turnstone_pgdata (survives rebuilds) and optional external Postgres support via DATABASE_URL override - Add scripts/migrate_sqlite_to_postgres.py — one-shot idempotent migration for existing SQLite data; ON CONFLICT DO NOTHING for safe re-runs - Fix SSH glean path in pipeline.py to use ensure_schema + get_conn (was still using raw sqlite3.connect + old _SCHEMA without tenant_id) - Fix FTS5 JOIN ambiguity: qualify repeat_count as f.repeat_count in search - Update all tests to use ensure_*_schema fixtures; add row_factory where needed - 394/394 tests passing Closes: #42 Closes: #50
20 lines
661 B
Text
20 lines
661 B
Text
fastapi>=0.110.0
|
|
uvicorn[standard]>=0.27.0
|
|
# Postgres backend — optional; SQLite is used when DATABASE_URL is unset
|
|
psycopg[binary,pool]>=3.1.0
|
|
pydantic>=2.0.0
|
|
pyyaml>=6.0
|
|
aiofiles>=23.0.0
|
|
python-multipart>=0.0.9
|
|
dateparser>=1.2.0
|
|
httpx>=0.27.0
|
|
paramiko
|
|
|
|
# Multi-agent diagnose pipeline — ML deps
|
|
# classifier.py and suppressor.py have ImportError guards and fall back gracefully,
|
|
# but these are included unconditionally so container images are fully capable.
|
|
# Install CPU-only torch to avoid pulling the ~2GB CUDA wheel into the image.
|
|
--extra-index-url https://download.pytorch.org/whl/cpu
|
|
torch>=2.2.0
|
|
transformers>=4.40.0
|
|
sentence-transformers>=3.0.0
|