Add dashboard to the docker image build
authorJérôme Benoit <jerome.benoit@sap.com>
Sat, 27 Aug 2022 19:41:12 +0000 (21:41 +0200)
committerJérôme Benoit <jerome.benoit@sap.com>
Sat, 27 Aug 2022 19:41:12 +0000 (21:41 +0200)
Signed-off-by: Jérôme Benoit <jerome.benoit@sap.com>
build-requirements.js
docker/Dockerfile
docker/autoconfig.sh [changed mode: 0644->0755]
docker/docker-compose.yml
docker/start.sh [new file with mode: 0755]

index ebcd5ef04680f340c030b7d84c2f1c7d70a13d52..7f36a4876c4ade6c23e0aa8548c2cb5c8be97527 100644 (file)
@@ -4,12 +4,21 @@ const SemVer = require('semver');
 
 const enginesNodeVersion = require('./package.json').engines.node;
 
-if (SemVer.satisfies(process.version, enginesNodeVersion) === false) {
-  console.error(
-    chalk.red(
-      `Required node version ${enginesNodeVersion} not satisfied with current version ${process.version}.`
-    )
-  );
-  // eslint-disable-next-line no-process-exit
-  process.exit(1);
+/**
+ *
+ */
+function checkNodeVersion() {
+  if (SemVer.satisfies(process.version, enginesNodeVersion) === false) {
+    console.error(
+      chalk.red(
+        `Required node version ${enginesNodeVersion} not satisfied with current version ${process.version}.`
+      )
+    );
+    // eslint-disable-next-line no-process-exit
+    process.exit(1);
+  }
 }
+
+checkNodeVersion();
+
+module.exports = { checkNodeVersion };
index c5ac91aaefb97e8526147b0a58947fc697be7bdb..9843d05b86ed4b7defe6c6c756ae68fc51284572 100644 (file)
@@ -1,20 +1,25 @@
 FROM node:lts-alpine as builder
 
-WORKDIR /usr/builder
-
-COPY package.json package-lock.json prepare.js ./
-
-RUN npm set progress=false && npm config set depth 0 && npm cache clean --force
 RUN apk add --no-cache --virtual .gyp \
   build-base \
-  python3 \
-  && npm install \
-  && apk del .gyp
-COPY tsconfig.json rollup.config.mjs ./
+  python3
+
+# Build simulator
+WORKDIR /usr/builder
+COPY package.json package-lock.json tsconfig.json rollup.config.mjs prepare.js build-requirements.js ./
 COPY src ./src
 COPY docker/config.json ./src/assets/config.json
+RUN npm set progress=false && npm config set depth 0 && npm cache clean --force && npm install
+RUN npm run build
+
+# Build simulator dashboard
+WORKDIR /usr/builder/webui
+COPY src/ui/web ./
+RUN npm set progress=false && npm config set depth 0 && npm cache clean --force && npm install
 RUN npm run build
 
+RUN apk del .gyp
+
 FROM node:lts-alpine
 
 ARG STACK_TRACE_LIMIT
@@ -24,11 +29,13 @@ WORKDIR /usr/app
 
 ENV NODE_OPTIONS="--stack-trace-limit=${STACK_TRACE_LIMIT} --max-old-space-size=${MAX_OLD_SPACE_SIZE}"
 
+COPY --from=builder /usr/builder/webui ./webui
 COPY --from=builder /usr/builder/node_modules ./node_modules
 COPY --from=builder /usr/builder/dist ./dist
 COPY README.md LICENSE ./
+COPY docker/start.sh /start.sh
 COPY docker/autoconfig.sh /autoconfig.sh
+RUN chmod +x /start.sh
 RUN chmod +x /autoconfig.sh
 
-#CMD ["node", "dist/start.cjs"]
-CMD /autoconfig.sh && node -r source-map-support/register dist/start.cjs
+CMD /autoconfig.sh && /start.sh
old mode 100644 (file)
new mode 100755 (executable)
index 1f21f63932c3842da7e36ed3e377dd8a28107ecc..c9065cdae8c50e8178531c7e2bb21caea45d7818 100644 (file)
@@ -12,3 +12,5 @@ services:
         MAX_OLD_SPACE_SIZE: 1024
     networks:
       - ev_network
+    ports:
+      - "3030:3030"
diff --git a/docker/start.sh b/docker/start.sh
new file mode 100755 (executable)
index 0000000..caf3084
--- /dev/null
@@ -0,0 +1,4 @@
+#!/usr/bin/env sh
+
+node -r source-map-support/register dist/start.cjs &
+node webui/start.js