2026-03-04 18:07:18 +01:00
|
|
|
# syntax=docker/dockerfile:1
|
|
|
|
|
|
|
|
|
|
# ============================================================================
|
|
|
|
|
# Builder stage
|
|
|
|
|
# ============================================================================
|
|
|
|
|
FROM node:22.11.0-slim AS builder
|
|
|
|
|
|
|
|
|
|
RUN npm install -g corepack@latest && corepack enable
|
|
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
2026-03-04 19:08:48 +01:00
|
|
|
# Copy all package manifests so pnpm can resolve the workspace lockfile,
|
|
|
|
|
# but use --ignore-scripts to skip buttplug's Rust/WASM build entirely.
|
2026-03-04 18:07:18 +01:00
|
|
|
COPY pnpm-workspace.yaml package.json pnpm-lock.yaml ./
|
|
|
|
|
COPY packages/backend/package.json ./packages/backend/package.json
|
2026-03-04 19:08:48 +01:00
|
|
|
COPY packages/frontend/package.json ./packages/frontend/package.json
|
|
|
|
|
COPY packages/buttplug/package.json ./packages/buttplug/package.json
|
2026-03-05 12:51:52 +01:00
|
|
|
COPY packages/types/package.json ./packages/types/package.json
|
2026-03-04 18:07:18 +01:00
|
|
|
|
2026-03-04 19:08:48 +01:00
|
|
|
RUN pnpm install --frozen-lockfile --filter @sexy.pivoine.art/backend --ignore-scripts
|
2026-03-04 18:07:18 +01:00
|
|
|
|
2026-03-04 20:56:33 +01:00
|
|
|
# Rebuild native bindings (argon2, sharp)
|
|
|
|
|
RUN pnpm rebuild argon2 sharp
|
2026-03-04 18:19:52 +01:00
|
|
|
|
2026-03-05 12:51:52 +01:00
|
|
|
COPY packages/types ./packages/types
|
2026-03-04 18:07:18 +01:00
|
|
|
COPY packages/backend ./packages/backend
|
|
|
|
|
|
|
|
|
|
RUN pnpm --filter @sexy.pivoine.art/backend build
|
|
|
|
|
|
2026-03-04 19:26:25 +01:00
|
|
|
RUN CI=true pnpm install --frozen-lockfile --filter @sexy.pivoine.art/backend --prod --ignore-scripts
|
2026-03-04 19:08:48 +01:00
|
|
|
|
2026-03-04 20:56:33 +01:00
|
|
|
RUN pnpm rebuild argon2 sharp
|
2026-03-04 18:07:18 +01:00
|
|
|
|
|
|
|
|
# ============================================================================
|
|
|
|
|
# Runner stage
|
|
|
|
|
# ============================================================================
|
|
|
|
|
FROM node:22.11.0-slim AS runner
|
|
|
|
|
|
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
|
|
|
dumb-init \
|
|
|
|
|
ffmpeg \
|
|
|
|
|
wget \
|
|
|
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
|
|
|
|
|
|
RUN userdel -r node && \
|
|
|
|
|
groupadd -r -g 1000 node && \
|
|
|
|
|
useradd -r -u 1000 -g node -m -d /home/node -s /bin/bash node
|
|
|
|
|
|
|
|
|
|
WORKDIR /home/node/app
|
|
|
|
|
|
|
|
|
|
RUN mkdir -p packages/backend
|
|
|
|
|
|
2026-03-04 19:29:36 +01:00
|
|
|
COPY --from=builder --chown=node:node /app/node_modules ./node_modules
|
|
|
|
|
COPY --from=builder --chown=node:node /app/package.json ./package.json
|
2026-03-04 18:07:18 +01:00
|
|
|
COPY --from=builder --chown=node:node /app/packages/backend/dist ./packages/backend/dist
|
|
|
|
|
COPY --from=builder --chown=node:node /app/packages/backend/node_modules ./packages/backend/node_modules
|
|
|
|
|
COPY --from=builder --chown=node:node /app/packages/backend/package.json ./packages/backend/package.json
|
2026-03-04 18:42:58 +01:00
|
|
|
COPY --from=builder --chown=node:node /app/packages/backend/src/migrations ./packages/backend/migrations
|
2026-03-04 18:07:18 +01:00
|
|
|
|
|
|
|
|
RUN mkdir -p /data/uploads && chown node:node /data/uploads
|
|
|
|
|
|
|
|
|
|
USER node
|
|
|
|
|
|
|
|
|
|
ENV NODE_ENV=production \
|
|
|
|
|
PORT=4000
|
|
|
|
|
|
|
|
|
|
EXPOSE 4000
|
|
|
|
|
|
|
|
|
|
HEALTHCHECK --interval=30s --timeout=5s --start-period=20s --retries=3 \
|
|
|
|
|
CMD wget --no-verbose --tries=1 --spider http://localhost:4000/health
|
|
|
|
|
|
|
|
|
|
ENTRYPOINT ["dumb-init", "--"]
|
|
|
|
|
CMD ["node", "packages/backend/dist/index.js"]
|