-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathDockerfile
More file actions
66 lines (51 loc) · 2.6 KB
/
Dockerfile
File metadata and controls
66 lines (51 loc) · 2.6 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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# syntax=docker/dockerfile:1
# ── Stage 1: Build ──────────────────────────────────────────────
FROM node:24-slim AS builder
WORKDIR /app
COPY package.json package-lock.json ./
COPY packages/core/package.json packages/core/
COPY packages/cli/package.json packages/cli/
COPY packages/architecture/package.json packages/architecture/
COPY packages/eslint-config/package.json packages/eslint-config/
COPY packages/web/package.json packages/web/
ARG TARGETPLATFORM
RUN --mount=type=cache,target=/root/.npm,id=npm-${TARGETPLATFORM} \
npm ci --workspace=packages/core
COPY packages/core/tsconfig.json packages/core/
COPY packages/core/src/ packages/core/src/
COPY packages/core/scripts/ packages/core/scripts/
RUN npm run build --workspace=packages/core
# ── Stage 2: JRE ───────────────────────────────────────────────
FROM eclipse-temurin:25-jre-noble AS jre
# ── Stage 3: Structurizr WAR (runs parallel with Stage 1) ──────
FROM node:24-slim AS structurizr
ARG STRUCTURIZR_VERSION=2026.02.01
RUN apt-get update && \
apt-get install -y --no-install-recommends curl ca-certificates && \
curl -fSL -o /structurizr.war \
"https://download.structurizr.com/structurizr-${STRUCTURIZR_VERSION}.war" && \
rm -rf /var/lib/apt/lists/*
# ── Stage 4: Runtime ───────────────────────────────────────────
FROM node:24-slim
WORKDIR /app
COPY --from=jre /opt/java/openjdk /opt/java/openjdk
ENV JAVA_HOME=/opt/java/openjdk
ENV PATH="${JAVA_HOME}/bin:${PATH}"
COPY --from=structurizr /structurizr.war /opt/structurizr.war
ENV ERODE_STRUCTURIZR_CLI_PATH=/opt/structurizr.war
RUN apt-get update && \
apt-get install -y --no-install-recommends git jq ca-certificates && \
rm -rf /var/lib/apt/lists/*
COPY package.json package-lock.json ./
COPY packages/core/package.json packages/core/
COPY packages/cli/package.json packages/cli/
COPY packages/architecture/package.json packages/architecture/
COPY packages/eslint-config/package.json packages/eslint-config/
COPY packages/web/package.json packages/web/
ARG TARGETPLATFORM
RUN --mount=type=cache,target=/root/.npm,id=npm-${TARGETPLATFORM} \
npm ci --workspace=packages/core --omit=dev && \
npm cache clean --force
COPY --from=builder /app/packages/core/dist/ packages/core/dist/
COPY --chmod=755 entrypoint.sh entrypoint-gitlab.sh entrypoint-bitbucket.sh /
ENTRYPOINT ["/entrypoint.sh"]