# Build stage FROM node:20-alpine AS builder # Set working directory WORKDIR /app # Copy package files COPY package*.json ./ # Install dependencies RUN npm ci # Copy source code COPY . . # Build-time API URL injection for Vite ARG VITE_API_URL=http://localhost:8082 ARG VITE_AUTH_URL=http://localhost:8082/api/auth ENV VITE_API_URL=${VITE_API_URL} ENV VITE_AUTH_URL=${VITE_AUTH_URL} # Build the application RUN npm run build # Production stage FROM nginx:alpine # Copy custom nginx config COPY nginx.conf /etc/nginx/nginx.conf # Copy built assets from builder stage COPY --from=builder /app/dist /usr/share/nginx/html # Create non-root user RUN addgroup -g 1001 -S appgroup && \ adduser -u 1001 -S appuser -G appgroup # Change ownership of nginx directories RUN chown -R appuser:appgroup /usr/share/nginx/html && \ chown -R appuser:appgroup /var/cache/nginx && \ chown -R appuser:appgroup /var/log/nginx && \ chown -R appuser:appgroup /etc/nginx/conf.d # Create nginx PID directory RUN touch /var/run/nginx.pid && \ chown -R appuser:appgroup /var/run/nginx.pid # Switch to non-root user USER appuser # Expose port EXPOSE 80 # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://127.0.0.1:80 || exit 1 # Start nginx CMD ["nginx", "-g", "daemon off;"]