# ── builder: Next.js production build ──────────────────────────────────────── FROM node:22-bookworm-slim AS builder WORKDIR /app COPY package.json package-lock.json* ./ RUN npm ci COPY . . RUN npm run build # ── backend-build: compile backend TypeScript to JS (better-sqlite3 build) ─── FROM node:22-bookworm-slim AS backend-build RUN apt-get update && apt-get install -y --no-install-recommends python3 make g++ && \ rm -rf /var/lib/apt/lists/* WORKDIR /app COPY backend/package.json backend/package-lock.json* ./backend/ COPY backend/tsconfig.json ./backend/ RUN cd backend && npm ci COPY backend/src ./backend/src COPY lib ./lib RUN cd backend && npm run build # ── backend-prod-deps: production-only node_modules (omits tsc/tsx) ────────── FROM node:22-bookworm-slim AS backend-prod-deps RUN apt-get update && apt-get install -y --no-install-recommends python3 make g++ && \ rm -rf /var/lib/apt/lists/* WORKDIR /app/backend COPY backend/package.json backend/package-lock.json* ./ RUN npm ci --omit=dev # ── web ────────────────────────────────────────────────────────────────────── # Minimal Next.js standalone runner. No database, no native modules. FROM node:22-bookworm-slim AS web WORKDIR /app ENV NODE_ENV=production ENV NEXT_TELEMETRY_DISABLED=1 RUN addgroup --system --gid 1001 nodejs && \ adduser --system --uid 1001 nextjs COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static COPY --from=builder --chown=nextjs:nodejs /app/public ./public USER nextjs EXPOSE 3000 ENV PORT=3000 ENV HOSTNAME="0.0.0.0" CMD ["node", "server.js"] # ── backend ────────────────────────────────────────────────────────────────── # Hono API server + node-cron scheduler. Owns the SQLite database exclusively. # Runs compiled JS (no tsx/tsc at runtime). FROM node:22-bookworm-slim AS backend WORKDIR /app ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \ adduser --system --uid 1001 nextjs COPY --from=backend-prod-deps --chown=nextjs:nodejs /app/backend/node_modules ./backend/node_modules COPY --from=backend-build --chown=nextjs:nodejs /app/backend/dist ./backend/dist COPY --chown=nextjs:nodejs backend/package.json ./backend/package.json RUN mkdir -p /app/backend/data && chown nextjs:nodejs /app/backend/data VOLUME ["/app/backend/data"] USER nextjs EXPOSE 3001 ENV PORT=3001 WORKDIR /app/backend CMD ["node", "dist/backend/src/index.js"]