-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile.web
More file actions
39 lines (32 loc) · 1.43 KB
/
Dockerfile.web
File metadata and controls
39 lines (32 loc) · 1.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# Multi-stage Dockerfile for MidstreamHub React frontend
# Usage: docker build -f Dockerfile.web .
# Stage 1: Build
FROM node:22-alpine AS build
WORKDIR /app
# Trust corporate proxy root certificate
COPY docker/certs/RootCert.pem /usr/local/share/ca-certificates/RootCert.crt
RUN cp /usr/local/share/ca-certificates/RootCert.crt /etc/ssl/certs/RootCert.pem && \
cat /usr/local/share/ca-certificates/RootCert.crt >> /etc/ssl/certs/ca-certificates.crt
ENV NODE_EXTRA_CA_CERTS=/usr/local/share/ca-certificates/RootCert.crt
COPY src/Web/midstreamhub-ui/package*.json ./
RUN npm ci
COPY src/Web/midstreamhub-ui/ .
RUN npm run build
# Stage 2: Production — serve with nginx
FROM nginx:alpine AS production
COPY --from=build /app/dist /usr/share/nginx/html
COPY src/Web/midstreamhub-ui/nginx.conf /etc/nginx/conf.d/default.conf
EXPOSE 80
# Dev stage — Vite dev server with HMR
FROM node:22-alpine AS dev
WORKDIR /app
# Trust corporate proxy root certificate
COPY docker/certs/RootCert.pem /usr/local/share/ca-certificates/RootCert.crt
RUN cp /usr/local/share/ca-certificates/RootCert.crt /etc/ssl/certs/RootCert.pem && \
cat /usr/local/share/ca-certificates/RootCert.crt >> /etc/ssl/certs/ca-certificates.crt
ENV NODE_EXTRA_CA_CERTS=/usr/local/share/ca-certificates/RootCert.crt
COPY src/Web/midstreamhub-ui/package*.json ./
RUN npm ci
COPY src/Web/midstreamhub-ui/ .
EXPOSE 3000
CMD ["npm", "run", "dev", "--", "--host", "0.0.0.0", "--port", "3000"]