# syntax=docker/dockerfile:1 # ---------- Stage 1: Build editor JS/CSS ---------- FROM node:20-slim AS editor-build WORKDIR /build COPY shared/editor/package.json shared/editor/package-lock.json* ./ RUN npm ci --ignore-scripts 2>/dev/null || npm install COPY shared/editor/ ./ RUN NODE_ENV=production node build.mjs # ---------- Stage 2: Python runtime ---------- FROM python:3.11-slim AS base ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PYTHONPATH=/app \ PIP_NO_CACHE_DIR=1 \ APP_PORT=8000 \ APP_MODULE=app:app WORKDIR /app # Install system deps + psql client RUN apt-get update && apt-get install -y --no-install-recommends \ ca-certificates \ postgresql-client \ && rm -rf /var/lib/apt/lists/* COPY shared/requirements.txt ./requirements.txt RUN pip install -r requirements.txt # Shared code (replaces submodule) COPY shared/ ./shared/ # App code COPY blog/ ./ # Sibling models for cross-domain SQLAlchemy imports COPY market/__init__.py ./market/__init__.py COPY market/models/ ./market/models/ COPY cart/__init__.py ./cart/__init__.py COPY cart/models/ ./cart/models/ COPY events/__init__.py ./events/__init__.py COPY events/models/ ./events/models/ COPY federation/__init__.py ./federation/__init__.py COPY federation/models/ ./federation/models/ COPY account/__init__.py ./account/__init__.py COPY account/models/ ./account/models/ # Copy built editor assets from stage 1 COPY --from=editor-build /static/scripts/editor.js /static/scripts/editor.css shared/static/scripts/ # ---------- Runtime setup ---------- COPY blog/entrypoint.sh /usr/local/bin/entrypoint.sh RUN chmod +x /usr/local/bin/entrypoint.sh RUN useradd -m -u 10001 appuser && chown -R appuser:appuser /app USER appuser EXPOSE ${APP_PORT} ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]