feat: fastapi app mit lifespan, webhook handler und /health

This commit is contained in:
2026-05-04 22:37:23 +02:00
parent 61e00028e8
commit 4792f0277f
3 changed files with 140 additions and 0 deletions

41
app/main.py Normal file
View File

@@ -0,0 +1,41 @@
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
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.get("/health")
async def health():
return {"status": "ok"}

20
app/webhook/handler.py Normal file
View File

@@ -0,0 +1,20 @@
from fastapi import APIRouter, BackgroundTasks, Header, status
from app.config import get_settings
from app.ingest.pipeline import process_file
from app.webhook.auth import verify_secret
from app.webhook.models import NextcloudEvent
router = APIRouter()
@router.post("/webhook", status_code=status.HTTP_202_ACCEPTED)
async def webhook(
event: NextcloudEvent,
background: BackgroundTasks,
x_webhook_secret: str | None = Header(default=None),
):
verify_secret(x_webhook_secret, get_settings().webhook_secret)
background.add_task(process_file, event.file_path, event.event_type)
return {"status": "accepted"}