# ============================================================================== # Goa GEL Frontend - Multi-stage Docker Build # ============================================================================== # Supports runtime configuration via environment variables # ============================================================================== # Stage 1: Build Angular application FROM node:20-alpine AS builder WORKDIR /app # Copy package files COPY package*.json ./ # Install dependencies RUN npm ci --legacy-peer-deps # Copy source code COPY . . # Build Angular app for production RUN npm run build -- --configuration production # Stage 2: Serve with Nginx FROM nginx:alpine # Copy custom nginx configuration COPY nginx.conf /etc/nginx/nginx.conf # Copy built application from builder stage COPY --from=builder /app/dist/goa-gel-frontend/browser /usr/share/nginx/html # Copy runtime config script COPY docker-entrypoint.sh /docker-entrypoint.sh RUN chmod +x /docker-entrypoint.sh # Expose port 80 EXPOSE 80 # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD wget --quiet --tries=1 --spider http://localhost/ || exit 1 # Use entrypoint to inject runtime config ENTRYPOINT ["/docker-entrypoint.sh"] CMD ["nginx", "-g", "daemon off;"]