- Add pnpm-workspace.yaml (backend + web + common-plat packages) - Add root package.json with workspace scripts and pnpm config - Add packageManager: pnpm@10.6.5 to backend/web manifests - Remove package-lock.json files, generate pnpm-lock.yaml - Add root .gitignore (was missing) - Update CI to use pnpm workspace commands - Add transpilePackages + webpack symlinks to next.config.ts - Update docker-prep.sh for backend + web consumers - Rewrite backend/web Dockerfiles to .docker-deps consumer pattern - Add .dockerignore Verified: typecheck + 576 tests (182 backend + 394 web) + builds pass Docker: backend + web smoke builds pass
39 lines
1.3 KiB
Docker
39 lines
1.3 KiB
Docker
# Pre-requisite: run ./scripts/docker-prep.sh to pack @bytelyst/* tarballs
|
|
# ── Stage 1: Build ────────────────────────────────────
|
|
FROM node:22-slim AS builder
|
|
WORKDIR /app/backend
|
|
ENV NODE_TLS_REJECT_UNAUTHORIZED=0
|
|
|
|
RUN npm config set strict-ssl false
|
|
COPY backend/package.json ./package.json
|
|
COPY backend/.docker-deps/ ./.docker-deps/
|
|
RUN npm install
|
|
|
|
COPY backend/tsconfig.json ./tsconfig.json
|
|
COPY backend/src/ ./src/
|
|
COPY shared/ ../shared/
|
|
RUN npm run build
|
|
|
|
# ── Stage 2: Prod deps ───────────────────────────────
|
|
FROM node:22-slim AS deps
|
|
WORKDIR /app/backend
|
|
ENV NODE_TLS_REJECT_UNAUTHORIZED=0
|
|
|
|
RUN npm config set strict-ssl false
|
|
COPY backend/package.json ./package.json
|
|
COPY backend/.docker-deps/ ./.docker-deps/
|
|
RUN npm install --omit=dev
|
|
|
|
# ── Stage 3: Runtime ──────────────────────────────────
|
|
FROM node:22-slim
|
|
WORKDIR /app/backend
|
|
ENV NODE_ENV=production
|
|
|
|
COPY --from=deps /app/backend/node_modules ./node_modules
|
|
COPY --from=deps /app/backend/package.json ./package.json
|
|
COPY --from=builder /app/backend/dist ./dist
|
|
COPY shared/product.json ../shared/product.json
|
|
|
|
EXPOSE 4011
|
|
CMD ["node", "dist/server.js"]
|