FROM python:3.11-slim-bookworm AS base ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ UV_COMPILE_BYTECODE=1 \ UV_LINK_MODE=copy \ UV_PYTHON_DOWNLOADS=never \ UV_PROJECT_ENVIRONMENT=/app/.venv WORKDIR /app RUN groupadd -r appgroup && useradd -r -g appgroup -m appuser # Install uv binary. COPY --from=ghcr.io/astral-sh/uv:0.7.2 /uv /uvx /usr/local/bin/ FROM base AS builder ARG INSTALL_DEV=false # hadolint ignore=DL3008 RUN apt-get update \ && apt-get install -y --no-install-recommends \ build-essential \ gcc \ libpq-dev \ libffi-dev \ libxml2-dev \ libxslt1-dev \ zlib1g-dev \ pkg-config \ && rm -rf /var/lib/apt/lists/* COPY pyproject.toml uv.lock ./ RUN if [ "${INSTALL_DEV}" = "true" ]; then \ uv sync --frozen --no-install-project --dev; \ else \ uv sync --frozen --no-install-project; \ fi FROM base AS runtime-base # hadolint ignore=DL3008 RUN apt-get update \ && apt-get install -y --no-install-recommends \ curl \ libpq5 \ libffi8 \ libxml2 \ libxslt1.1 \ zlib1g \ && rm -rf /var/lib/apt/lists/* COPY --from=builder /app/.venv /app/.venv COPY src/ ./src/ COPY docker/scripts/ ./docker/scripts/ RUN mkdir -p logs media staticfiles input src/static \ && chmod +x /app/docker/scripts/*.sh \ && chown -R appuser:appgroup /app ENV PATH="/app/.venv/bin:${PATH}" \ PYTHONPATH=/app/src USER appuser ENTRYPOINT ["/app/docker/scripts/entrypoint.sh"] FROM runtime-base AS runtime-web EXPOSE 8000 CMD ["web"] FROM runtime-base AS runtime-celery CMD ["celery-worker"]