From d410b13c9bec41ea9e0d459399325b13a3b1128d Mon Sep 17 00:00:00 2001 From: mikiher Date: Tue, 7 Jan 2025 17:41:09 +0200 Subject: [PATCH 1/2] Merge prod.js into index.js --- Dockerfile | 5 +++++ index.js | 32 ++++++++++++++++++++++++++------ package-lock.json | 2 +- package.json | 8 ++++---- prod.js | 33 --------------------------------- 5 files changed, 36 insertions(+), 44 deletions(-) delete mode 100644 prod.js diff --git a/Dockerfile b/Dockerfile index 0d4629f8..4e110a61 100644 --- a/Dockerfile +++ b/Dockerfile @@ -46,5 +46,10 @@ RUN apk del make python3 g++ EXPOSE 80 +ENV PORT=80 +ENV CONFIG_PATH="/config" +ENV METADATA_PATH="/metadata" +ENV SOURCE="docker" + ENTRYPOINT ["tini", "--"] CMD ["node", "index.js"] diff --git a/index.js b/index.js index 9a0be347..4b3a2648 100644 --- a/index.js +++ b/index.js @@ -1,3 +1,18 @@ +const optionDefinitions = [ + { name: 'config', alias: 'c', type: String }, + { name: 'metadata', alias: 'm', type: String }, + { name: 'port', alias: 'p', type: String }, + { name: 'host', alias: 'h', type: String }, + { name: 'source', alias: 's', type: String }, + { name: 'dev', alias: 'd', type: Boolean } +] + +const commandLineArgs = require('./server/libs/commandLineArgs') +const options = commandLineArgs(optionDefinitions) + +const Path = require('path') +process.env.NODE_ENV = options.dev ? 'development' : process.env.NODE_ENV || 'production' + const server = require('./server/Server') global.appRoot = __dirname @@ -17,14 +32,19 @@ if (isDev) { process.env.ROUTER_BASE_PATH = devEnv.RouterBasePath || '' } -const PORT = process.env.PORT || 80 -const HOST = process.env.HOST -const CONFIG_PATH = process.env.CONFIG_PATH || '/config' -const METADATA_PATH = process.env.METADATA_PATH || '/metadata' -const SOURCE = process.env.SOURCE || 'docker' +const inputConfig = options.config ? Path.resolve(options.config) : null +const inputMetadata = options.metadata ? Path.resolve(options.metadata) : null + +const PORT = options.port || process.env.PORT || 3333 +const HOST = options.host || process.env.HOST +const CONFIG_PATH = inputConfig || process.env.CONFIG_PATH || Path.resolve('config') +const METADATA_PATH = inputMetadata || process.env.METADATA_PATH || Path.resolve('metadata') +const SOURCE = options.source || process.env.SOURCE || 'debian' + const ROUTER_BASE_PATH = process.env.ROUTER_BASE_PATH || '' -console.log('Config', CONFIG_PATH, METADATA_PATH) +console.log(`Running in ${process.env.NODE_ENV} mode.`) +console.log(`Options: CONFIG_PATH=${CONFIG_PATH}, METADATA_PATH=${METADATA_PATH}, PORT=${PORT}, HOST=${HOST}, SOURCE=${SOURCE}, ROUTER_BASE_PATH=${ROUTER_BASE_PATH}`) const Server = new server(SOURCE, PORT, HOST, CONFIG_PATH, METADATA_PATH, ROUTER_BASE_PATH) Server.start() diff --git a/package-lock.json b/package-lock.json index 31d9d0c2..6fd8cc2e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -30,7 +30,7 @@ "xml2js": "^0.5.0" }, "bin": { - "audiobookshelf": "prod.js" + "audiobookshelf": "index.js" }, "devDependencies": { "chai": "^4.3.10", diff --git a/package.json b/package.json index f6729ef6..ea73669c 100644 --- a/package.json +++ b/package.json @@ -5,10 +5,10 @@ "description": "Self-hosted audiobook and podcast server", "main": "index.js", "scripts": { - "dev": "nodemon --watch server index.js", + "dev": "nodemon --watch server index.js -- --dev", "start": "node index.js", "client": "cd client && npm ci && npm run generate", - "prod": "npm run client && npm ci && node prod.js", + "prod": "npm run client && npm ci && node index.js", "build-win": "npm run client && pkg -t node20-win-x64 -o ./dist/win/audiobookshelf -C GZip .", "build-linux": "build/linuxpackager", "docker": "docker buildx build --platform linux/amd64,linux/arm64 --push . -t advplyr/audiobookshelf", @@ -18,7 +18,7 @@ "test": "mocha", "coverage": "nyc mocha" }, - "bin": "prod.js", + "bin": "index.js", "pkg": { "assets": [ "client/dist/**/*", @@ -26,7 +26,7 @@ "server/migrations/*.js" ], "scripts": [ - "prod.js", + "index.js", "server/**/*.js" ] }, diff --git a/prod.js b/prod.js deleted file mode 100644 index 70633d5b..00000000 --- a/prod.js +++ /dev/null @@ -1,33 +0,0 @@ -const optionDefinitions = [ - { name: 'config', alias: 'c', type: String }, - { name: 'metadata', alias: 'm', type: String }, - { name: 'port', alias: 'p', type: String }, - { name: 'host', alias: 'h', type: String }, - { name: 'source', alias: 's', type: String } -] - -const commandLineArgs = require('./server/libs/commandLineArgs') -const options = commandLineArgs(optionDefinitions) - -const Path = require('path') -process.env.NODE_ENV = 'production' - -const server = require('./server/Server') - -global.appRoot = __dirname - -var inputConfig = options.config ? Path.resolve(options.config) : null -var inputMetadata = options.metadata ? Path.resolve(options.metadata) : null - -const PORT = options.port || process.env.PORT || 3333 -const HOST = options.host || process.env.HOST -const CONFIG_PATH = inputConfig || process.env.CONFIG_PATH || Path.resolve('config') -const METADATA_PATH = inputMetadata || process.env.METADATA_PATH || Path.resolve('metadata') -const SOURCE = options.source || process.env.SOURCE || 'debian' - -const ROUTER_BASE_PATH = process.env.ROUTER_BASE_PATH || '' - -console.log(process.env.NODE_ENV, 'Config', CONFIG_PATH, METADATA_PATH) - -const Server = new server(SOURCE, PORT, HOST, CONFIG_PATH, METADATA_PATH, ROUTER_BASE_PATH) -Server.start() From 052e0059ff52737ca620e38673b5b270f052e267 Mon Sep 17 00:00:00 2001 From: mikiher Date: Wed, 8 Jan 2025 07:23:08 +0200 Subject: [PATCH 2/2] Restore prod.js --- prod.js | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 prod.js diff --git a/prod.js b/prod.js new file mode 100644 index 00000000..70633d5b --- /dev/null +++ b/prod.js @@ -0,0 +1,33 @@ +const optionDefinitions = [ + { name: 'config', alias: 'c', type: String }, + { name: 'metadata', alias: 'm', type: String }, + { name: 'port', alias: 'p', type: String }, + { name: 'host', alias: 'h', type: String }, + { name: 'source', alias: 's', type: String } +] + +const commandLineArgs = require('./server/libs/commandLineArgs') +const options = commandLineArgs(optionDefinitions) + +const Path = require('path') +process.env.NODE_ENV = 'production' + +const server = require('./server/Server') + +global.appRoot = __dirname + +var inputConfig = options.config ? Path.resolve(options.config) : null +var inputMetadata = options.metadata ? Path.resolve(options.metadata) : null + +const PORT = options.port || process.env.PORT || 3333 +const HOST = options.host || process.env.HOST +const CONFIG_PATH = inputConfig || process.env.CONFIG_PATH || Path.resolve('config') +const METADATA_PATH = inputMetadata || process.env.METADATA_PATH || Path.resolve('metadata') +const SOURCE = options.source || process.env.SOURCE || 'debian' + +const ROUTER_BASE_PATH = process.env.ROUTER_BASE_PATH || '' + +console.log(process.env.NODE_ENV, 'Config', CONFIG_PATH, METADATA_PATH) + +const Server = new server(SOURCE, PORT, HOST, CONFIG_PATH, METADATA_PATH, ROUTER_BASE_PATH) +Server.start()