FROM python:3.12-slim AS builder ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PIP_NO_CACHE_DIR=1 \ VIRTUAL_ENV=/opt/venv WORKDIR /app RUN apt-get update \ && apt-get install -y --no-install-recommends build-essential libpq-dev \ && rm -rf /var/lib/apt/lists/* RUN python -m venv "${VIRTUAL_ENV}" ENV PATH="${VIRTUAL_ENV}/bin:${PATH}" COPY requirements/base.txt /tmp/requirements/base.txt RUN pip install --upgrade pip && pip install -r /tmp/requirements/base.txt FROM python:3.12-slim AS runtime ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PIP_NO_CACHE_DIR=1 \ VIRTUAL_ENV=/opt/venv \ PATH="/opt/venv/bin:/home/app/.local/bin:${PATH}" \ APP_USER=app \ APP_UID=10001 \ APP_GID=10001 WORKDIR /app RUN apt-get update \ && apt-get install -y --no-install-recommends libpq5 postgresql-client curl nodejs npm \ && rm -rf /var/lib/apt/lists/* RUN groupadd --gid "${APP_GID}" "${APP_USER}" \ && useradd --uid "${APP_UID}" --gid "${APP_GID}" --create-home --shell /usr/sbin/nologin "${APP_USER}" RUN printf '%s\n' 'export PATH="/opt/venv/bin:/home/app/.local/bin:$PATH"' > /etc/profile.d/hoopscout-path.sh COPY --from=builder /opt/venv /opt/venv COPY . /app RUN if [ -f package.json ]; then npm install --no-audit --no-fund; fi RUN if [ -f package.json ]; then npm run build; fi RUN chmod +x /app/entrypoint.sh RUN mkdir -p /app/staticfiles /app/media /app/runtime /app/node_modules /app/static/vendor \ && chown -R "${APP_UID}:${APP_GID}" /app /opt/venv USER ${APP_UID}:${APP_GID} ENTRYPOINT ["/app/entrypoint.sh"] CMD ["gunicorn", "config.wsgi:application", "--bind", "0.0.0.0:8000"]