# Stage 1: Builder FROM python:3.14-slim@sha256:584e89d31009a79ae4d9e3ab2fba078524a6c0921cb2711d05e8bb5f628fc9b9 AS builder # Install uv COPY --from=ghcr.io/astral-sh/uv:latest@sha256:3472e43b4e738cf911c99d41bb34331280efad54c73b1def654a6227bb59b2b4 /uv /usr/local/bin/uv WORKDIR /app # Copy dependency files COPY pyproject.toml uv.lock ./ # Install dependencies RUN uv sync --frozen --no-dev --no-install-project # Copy source code COPY src ./src # Install the project RUN uv sync --frozen --no-dev # Stage 2: Runtime FROM python:3.14-slim@sha256:584e89d31009a79ae4d9e3ab2fba078524a6c0921cb2711d05e8bb5f628fc9b9 # Create non-root user RUN useradd --create-home --shell /bin/bash appuser WORKDIR /app # Copy virtual environment from builder COPY --from=builder --chown=appuser:appuser /app/.venv /app/.venv # Copy source code COPY --from=builder --chown=appuser:appuser /app/src ./src # Set environment ENV PATH="/app/.venv/bin:$PATH" ENV PORT=3000 # Switch to non-root user USER appuser EXPOSE 3000 CMD ["python", "-m", "grist_mcp.main"]