# Backend build stage FROM golang:1.25-alpine AS builder WORKDIR /app RUN apk add --no-cache git COPY backend/go.mod backend/go.sum ./ RUN go mod download COPY backend/ ./ RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -ldflags="-w -s" -o api ./cmd/api # Runtime stage FROM alpine:3.19 RUN apk --no-cache add ca-certificates tzdata wget # Create non-root user for security RUN addgroup -g 1000 appgroup && \ adduser -u 1000 -G appgroup -h /app -D appuser WORKDIR /app COPY --from=builder /app/api . RUN mkdir -p /app/config/users /app/config/workflows /app/tmp /app/logs /app/dist && \ chown -R appuser:appgroup /app USER appuser EXPOSE 8678 HEALTHCHECK --interval=30s --timeout=3s --start-period=10s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://localhost:8678/health || exit 1 CMD ["./api"]