# Production Dockerfile for SerpentRace Backend FROM node:20-alpine AS builder # Set working directory WORKDIR /app # Install dependencies needed for native modules RUN apk add --no-cache python3 make g++ # Copy package files COPY package.json package-lock.json* ./ # Install ALL dependencies for building (including devDependencies) RUN npm ci # Copy source code COPY . . # Build the application RUN npm run build || echo "No build script found" # Production stage FROM node:20-alpine AS production # Set working directory WORKDIR /app # Install dependencies needed for native modules RUN apk add --no-cache python3 make g++ # Copy package files COPY package.json package-lock.json* ./ # Install only production dependencies RUN npm ci --only=production && npm cache clean --force # Copy built application from builder stage COPY --from=builder /app/dist ./dist COPY --from=builder /app/package.json ./ # Copy assets directory for email templates and logos COPY --from=builder /app/assets ./assets # Create logs directory with proper permissions RUN mkdir -p logs && chmod 777 logs # Create non-root user but don't switch to it for now RUN addgroup -g 1001 -S nodejs RUN adduser -S serpentrace -u 1001 RUN chown -R serpentrace:nodejs /app # Keep running as root to avoid permission issues with mounted volumes # USER serpentrace # Expose port EXPOSE 3000 # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD curl -f http://localhost:3000/health || exit 1 # Production command CMD ["npm", "start"]