Files
WatchLink/Dockerfile
MrSphay 1b68be8802
All checks were successful
Release Dry Run / release-dry-run (push) Successful in 1m55s
Template Compliance / compliance (push) Successful in 9s
Build / build (push) Successful in 15m7s
Security Scan / scan (push) Successful in 1m2s
Repository Cleanup Report / report (push) Successful in 5s
Dependency Check / dependencies (push) Successful in 1m1s
Reduce runtime Docker image size
2026-05-15 23:58:40 +02:00

33 lines
1.4 KiB
Docker

FROM node:22-bookworm-slim AS deps
WORKDIR /app
RUN apt-get update -y && apt-get install -y --no-install-recommends openssl && rm -rf /var/lib/apt/lists/*
COPY package.json ./
RUN npm install
FROM node:22-bookworm-slim AS builder
WORKDIR /app
RUN apt-get update -y && apt-get install -y --no-install-recommends openssl && rm -rf /var/lib/apt/lists/*
ENV NEXT_TELEMETRY_DISABLED=1
ARG DATABASE_URL="postgresql://watchlink:watchlink@localhost:5432/watchlink?schema=public"
ENV DATABASE_URL=$DATABASE_URL
COPY --from=deps /app/node_modules ./node_modules
COPY . .
RUN npx prisma generate && npm run build && npm prune --omit=dev
FROM node:22-bookworm-slim AS runner
WORKDIR /app
ENV NODE_ENV=production
ENV NEXT_TELEMETRY_DISABLED=1
RUN apt-get update -y && apt-get install -y --no-install-recommends openssl && rm -rf /var/lib/apt/lists/* && groupadd --system --gid 1001 nodejs && useradd --system --uid 1001 --gid nodejs nextjs
COPY --from=builder /app/public ./public
COPY --from=builder /app/package.json ./package.json
COPY --from=builder /app/server.js ./server.js
COPY --from=builder /app/prisma ./prisma
COPY --from=builder /app/.next/standalone ./
COPY --from=builder /app/.next/static ./.next/static
COPY --from=builder /app/node_modules ./node_modules
RUN mkdir -p /app/public/uploads/avatars && chown -R nextjs:nodejs /app/public/uploads
USER nextjs
EXPOSE 3000
CMD ["node", "server.js"]