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/fns input/fns/processed input/fns/failed src/static \ && chmod +x /app/docker/scripts/*.sh \ && chown -R appuser:appgroup /app ENV PATH="/app/.venv/bin:${PATH}" \ PYTHONPATH=/app/src \ DJANGO_SETTINGS_MODULE=settings.dev \ POSTGRES_HOST=10.10.0.114 \ POSTGRES_PORT=5432 \ POSTGRES_DB=mostovik \ POSTGRES_USER=postgres \ POSTGRES_PASSWORD=postgres \ POSTGRES_SSLMODE=disable \ REDIS_HOST=10.10.0.110 \ REDIS_CACHE_URL=redis://10.10.0.110:6379/1 \ CELERY_BROKER_URL=redis://10.10.0.110:6379/0 \ CELERY_RESULT_BACKEND=redis://10.10.0.110:6379/0 \ PORT=8000 \ GUNICORN_WORKERS=4 \ GUNICORN_TIMEOUT=60 \ CELERY_LOG_LEVEL=INFO \ CELERY_WORKER_CONCURRENCY=2 \ CHECKO_API_KEY=pRiEnJuD1tclsLCb \ ZAKUPKI_TOKEN=019c03d7-e1f6-7091-b296-8c88b4c585dd \ COLLECTSTATIC_ON_MIGRATE=0 \ BACKUP_ENCRYPTION_KEY=a2tra2tra2tra2tra2tra2tra2tra2tra2tra2s \ BACKUP_KEY_ID=default \ BACKUP_EXPORT_DIRECTORY=/app/media/backups \ STATE_CORP_EXCHANGE_URL= \ STATE_CORP_EXCHANGE_TOKEN= \ STATE_CORP_EXCHANGE_KEY_ID=state-corp-shared-token \ STATE_CORP_EXCHANGE_TIMEOUT_SECONDS=60 USER appuser FROM runtime-base AS runtime-web EXPOSE 8000 CMD ["/app/docker/scripts/start-web.sh"] FROM runtime-base AS runtime-celery USER root # Playwright/Chromium runtime dependencies. # hadolint ignore=DL3008 RUN apt-get update \ && apt-get install -y --no-install-recommends \ libnss3 \ libnspr4 \ libatk1.0-0 \ libatk-bridge2.0-0 \ libcups2 \ libdrm2 \ libdbus-1-3 \ libxkbcommon0 \ libxcomposite1 \ libxdamage1 \ libxfixes3 \ libxrandr2 \ libgbm1 \ libasound2 \ libpango-1.0-0 \ libcairo2 \ libatspi2.0-0 \ && rm -rf /var/lib/apt/lists/* ENV PLAYWRIGHT_BROWSERS_PATH=/app/.playwright RUN python -m playwright install chromium \ && chown -R appuser:appgroup /app USER appuser CMD ["/app/docker/scripts/start-celery-worker.sh"]