From 05eace759fdb7b2b3e84b2b8b1e92161b68e0d2b Mon Sep 17 00:00:00 2001 From: kwizzn Date: Wed, 29 Sep 2021 18:52:34 +0200 Subject: [PATCH] Add the transpiled artifacts to build/ for a slimmer native Node Docker container --- .dockerignore | 15 +++++++++++++++ .gitignore | 1 + Dockerfile | 13 ++++++------- controllers/api.js | 4 +++- package.json | 1 + 5 files changed, 26 insertions(+), 8 deletions(-) create mode 100644 .dockerignore diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..d9c55e33 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,15 @@ +* +!build/ +!class/ +!controllers/ +!scripts/ +!static/ +!templates/ +!utils/ +!*.js +!.babelrc +!.eslint* +!admin.macaroon +!package*.json +!rpc.proto +!tls.cert diff --git a/.gitignore b/.gitignore index cc50bc41..266f97ec 100644 --- a/.gitignore +++ b/.gitignore @@ -2,6 +2,7 @@ admin.macaroon tls.cert +build/ logs/ # dependencies diff --git a/Dockerfile b/Dockerfile index ad3ac630..4655717f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -13,19 +13,17 @@ RUN apt-get update && apt-get -y install python3 WORKDIR /lndhub -# Copy 'package-lock.json' and 'package.json' -COPY package.json package-lock.json ./ +# Copy project files and folders to the current working directory +COPY . . # Install dependencies RUN npm i - -# Copy project files and folders to the current working directory -COPY . . +RUN npm run build # Delete git data as it's not needed inside the container RUN rm -rf .git -FROM node:16-bullseye-slim +FROM node:16-alpine # Create a specific user so LNDHub doesn't run as root COPY --from=perms /etc/group /etc/passwd /etc/shadow /etc/ @@ -34,10 +32,11 @@ COPY --from=perms /etc/group /etc/passwd /etc/shadow /etc/ COPY --from=builder /lndhub /lndhub # Create logs folder and ensure permissions are set correctly -RUN mkdir /lndhub/logs && chown -R lndhub:lndhub /lndhub +RUN mkdir -p /lndhub/logs && chown -R lndhub:lndhub /lndhub USER lndhub ENV PORT=3000 EXPOSE 3000 +WORKDIR /lndhub CMD cp $LND_CERT_FILE /lndhub/ && cp $LND_ADMIN_MACAROON_FILE /lndhub/ && cd /lndhub && npm start diff --git a/controllers/api.js b/controllers/api.js index 3309a6e4..2a582e63 100644 --- a/controllers/api.js +++ b/controllers/api.js @@ -5,7 +5,9 @@ let express = require('express'); let router = express.Router(); let logger = require('../utils/logger'); const MIN_BTC_BLOCK = 670000; -console.log('using config', JSON.stringify(config)); +if (process.env.NODE_ENV !== 'prod') { + console.log('using config', JSON.stringify(config)); +} var Redis = require('ioredis'); var redis = new Redis(config.redis); diff --git a/package.json b/package.json index da737de9..bed6f3b2 100644 --- a/package.json +++ b/package.json @@ -5,6 +5,7 @@ "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1", + "build": "./node_modules/.bin/babel ./ --ignore node_modules/ --ignore *.spec.js --out-dir ./build", "dev": "nodemon node_modules/.bin/babel-node index.js", "start": "node_modules/.bin/babel-node index.js", "lint": "./node_modules/.bin/eslint ./ controllers/ class/ --fix"