# Dockerfile for Smithery stateless deployment # ADR-016: Stateless mode for multi-user public Nextcloud instances # # This image excludes: # - Vector database dependencies (qdrant-client) # - Background sync workers # - Admin UI routes (/app) # - Semantic search tools # # Features included: # - Core Nextcloud tools (notes, calendar, contacts, files, deck, tables, cookbook) # - Per-session app password authentication # - Multi-user support via Smithery session config FROM docker.io/library/python:3.12-slim-trixie@sha256:87b49ee9d18db77b0afc7e3adbd994acb9544695217f6e8b4ff352a076a9e6a6 WORKDIR /app # Install uv for fast dependency management COPY --from=ghcr.io/astral-sh/uv:0.9.26@sha256:9a23023be68b2ed09750ae636228e903a54a05ea56ed03a934d00fe9fbeded4b /uv /uvx /bin/ # Install dependencies # 1. git (required for caldav dependency from git) # 2. sqlite for development with token db RUN apt update && apt install --no-install-recommends --no-install-suggests -y \ git # Copy project files COPY . . RUN uv sync --locked --no-dev --no-editable --no-cache # Set Smithery mode environment variables ENV SMITHERY_DEPLOYMENT=true ENV VECTOR_SYNC_ENABLED=false # Smithery sets PORT=8081 by default EXPOSE 8081 # Health check endpoint HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ CMD uv run python -c "import httpx; httpx.get('http://localhost:${PORT:-8081}/health/live').raise_for_status()" CMD ["/app/.venv/bin/smithery-main"]