# 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:a75662dfec8d90bd7161c91050be2e0a9b21d284f3b7a7253d5db25f7d583fb3 WORKDIR /app # Install uv for fast dependency management COPY --from=ghcr.io/astral-sh/uv:0.9.22@sha256:2320e6c239737dc73cccce393a8bb89eba2383d17018ee91a59773df802c20e6 /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"]