Files
rag-ingestor/app/main.py

44 lines
1.2 KiB
Python

import logging
from contextlib import asynccontextmanager
from fastapi import FastAPI
from qdrant_client import QdrantClient
from app.config import get_settings
from app.ingest.embedder import embedding_dimension
from app.logging_setup import setup_logging
from app.qdrant_store import ensure_collection
from app.webhook.handler import router as webhook_router
from app.bulk import router as bulk_router
logger = logging.getLogger(__name__)
async def _startup_ensure_collection() -> None:
settings = get_settings()
dim = await embedding_dimension(settings.ollama_embed_model)
client = QdrantClient(url=settings.qdrant_url)
ensure_collection(client, settings.qdrant_collection, vector_size=dim)
logger.info(
"qdrant collection ready",
extra={"event": "startup", "collection": settings.qdrant_collection, "dim": dim},
)
@asynccontextmanager
async def lifespan(app: FastAPI):
setup_logging(get_settings().log_level)
await _startup_ensure_collection()
yield
app = FastAPI(title="rag-ingestor", lifespan=lifespan)
app.include_router(webhook_router)
app.include_router(bulk_router)
@app.get("/health")
async def health():
return {"status": "ok"}