# ───────────────────────────────────────────────────────── # YouTube Summarizer — StartOS 0.4 Docker image # # Multi-stage build for ARM64 (Raspberry Pi / Start9 server) # Includes: Node.js 20, Python 3, yt-dlp, ffmpeg # # Uses Debian slim (not Alpine) because: # - yt-dlp's --impersonate chrome requires curl_cffi (compiled C extension) # - curl_cffi's prebuilt wheels target glibc, not musl # - Debian is more reliable for pip-installed packages with C deps on ARM64 # ───────────────────────────────────────────────────────── # ── Stage 1: Install Node.js dependencies ────────────────── FROM node:20-slim AS builder # git is required by npm to clone the @keysat/licensing-client git+https # dependency. Stripped from the final image (only used in this builder stage). # The url.insteadOf rewrites force npm/git to use https for github.com even # when npm's git resolver tries ssh first — there's no ssh client or key in # this container. RUN apt-get update && apt-get install -y --no-install-recommends git ca-certificates \ && rm -rf /var/lib/apt/lists/* \ && git config --global --add url."https://github.com/".insteadOf "ssh://git@github.com/" \ && git config --global --add url."https://github.com/".insteadOf "git@github.com:" \ && git config --global --add url."https://github.com/".insteadOf "git://github.com/" WORKDIR /app/server COPY server/package.json server/package-lock.json* ./ RUN npm ci --production --ignore-scripts 2>/dev/null || npm install --production --ignore-scripts # ── Stage 2: Final runtime image ─────────────────────────── FROM node:20-slim AS runner WORKDIR /app # Install runtime dependencies: # - dumb-init: proper PID 1 signal handling in containers # - curl: health checks + yt-dlp binary downloads # - python3 + pip: yt-dlp installation and updates # - ffmpeg: audio extraction, splitting, and duration detection # - ca-certificates: HTTPS for YouTube/Gemini API calls RUN apt-get update && apt-get install -y --no-install-recommends \ dumb-init \ curl \ python3 \ python3-pip \ python3-venv \ ffmpeg \ ca-certificates \ && rm -rf /var/lib/apt/lists/* \ && pip3 install --break-system-packages yt-dlp curl_cffi \ && yt-dlp --version # Copy Node.js app from builder COPY --from=builder /app/server/node_modules ./server/node_modules/ COPY server/package.json ./server/ COPY server/index.js ./server/ COPY server/license.js ./server/ COPY public/ ./public/ COPY assets/ ./assets/ # Copy StartOS scripts COPY start9/0.4/docker_entrypoint.sh /usr/local/bin/docker_entrypoint.sh COPY start9/0.4/healthcheck.sh /usr/local/bin/healthcheck.sh RUN chmod +x /usr/local/bin/docker_entrypoint.sh /usr/local/bin/healthcheck.sh # Create persistent data mount point RUN mkdir -p /data ENV NODE_ENV=production \ PORT=3001 \ DATA_DIR=/data EXPOSE 3001 ENTRYPOINT ["dumb-init", "--", "/usr/local/bin/docker_entrypoint.sh"]