# syntax=docker/dockerfile:1.7 FROM python:3.11-slim AS builder ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PIP_NO_CACHE_DIR=1 \ PIP_DISABLE_PIP_VERSION_CHECK=1 \ VIRTUAL_ENV=/opt/venv WORKDIR /app RUN apt-get update \ && apt-get install --no-install-recommends -y build-essential \ && rm -rf /var/lib/apt/lists/* \ && python -m venv "$VIRTUAL_ENV" ENV PATH="$VIRTUAL_ENV/bin:$PATH" COPY requirements.txt ./ RUN pip install --upgrade pip setuptools wheel \ && pip install -r requirements.txt FROM python:3.11-slim AS runtime ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ VIRTUAL_ENV=/opt/venv \ PATH="/opt/venv/bin:$PATH" WORKDIR /app RUN groupadd --system appuser \ && useradd --system --gid appuser --create-home --home-dir /home/appuser appuser \ && mkdir -p /app/data/cache /app/data/exports \ && chown -R appuser:appuser /app /home/appuser COPY --from=builder /opt/venv /opt/venv COPY --chown=appuser:appuser app ./app COPY --chown=appuser:appuser config ./config COPY --chown=appuser:appuser scripts/entrypoint.sh ./scripts/entrypoint.sh RUN chmod +x /app/scripts/entrypoint.sh USER appuser EXPOSE 8000 HEALTHCHECK --interval=30s --timeout=5s --start-period=20s --retries=3 \ CMD python -c "import sys, urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/health', timeout=3); sys.exit(0)" ENTRYPOINT ["/app/scripts/entrypoint.sh"]