# Build stage FROM node:20-alpine AS builder WORKDIR /app # Install pnpm RUN corepack enable && corepack prepare pnpm@latest --activate # Copy package files COPY package.json pnpm-lock.yaml* ./ # Install dependencies RUN pnpm install # Copy source code COPY . . # Build TypeScript RUN pnpm build # Production stage FROM node:20-alpine AS runner WORKDIR /app # Install pnpm RUN corepack enable && corepack prepare pnpm@latest --activate # Create non-root user RUN addgroup --system --gid 1001 nodejs && \ adduser --system --uid 1001 expressjs # Copy package files COPY package.json pnpm-lock.yaml* ./ # Install production dependencies only RUN pnpm install --prod # Copy built application COPY --from=builder /app/dist ./dist # Set ownership RUN chown -R expressjs:nodejs /app # Switch to non-root user USER expressjs # Expose port EXPOSE 3000 # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ CMD wget -q --spider http://localhost:3000/api/health || exit 1 # Start application CMD ["node", "dist/index.js"]