From a49f89bf97956abcca5a57e7b17720afd42db03c Mon Sep 17 00:00:00 2001 From: Pavel Gnedov Date: Sun, 24 Jul 2022 06:44:20 +0700 Subject: [PATCH] =?UTF-8?q?=D0=9E=D0=B1=D0=BD=D0=BE=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=B0=20=D0=BA=D0=BE=D0=BD=D1=84=D0=B8=D0=B3=D1=83=D1=80?= =?UTF-8?q?=D0=B0=D1=86=D0=B8=D1=8F=20=D0=BE=D1=81=D0=BD=D0=BE=D0=B2=D0=BD?= =?UTF-8?q?=D0=BE=D0=B3=D0=BE=20=D0=BF=D1=80=D0=B8=D0=BB=D0=BE=D0=B6=D0=B5?= =?UTF-8?q?=D0=BD=D0=B8=D1=8F=20=D0=B8=20=D0=B7=D0=B0=D0=B3=D1=80=D1=83?= =?UTF-8?q?=D0=B7=D1=87=D0=B8=D0=BA=20=D0=BA=D0=BE=D0=BD=D1=84=D0=B8=D0=B3?= =?UTF-8?q?=D1=83=D1=80=D0=B0=D1=86=D0=B8=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- configs/main-config.jsonc.dist | 7 +++++++ src/configs/app.ts | 36 ++++++++++++++++++++-------------- 2 files changed, 28 insertions(+), 15 deletions(-) create mode 100644 configs/main-config.jsonc.dist diff --git a/configs/main-config.jsonc.dist b/configs/main-config.jsonc.dist new file mode 100644 index 0000000..90c7a6b --- /dev/null +++ b/configs/main-config.jsonc.dist @@ -0,0 +1,7 @@ +{ + "couchDb": { + "dbs": { + "changes": "" + } + } +} \ No newline at end of file diff --git a/src/configs/app.ts b/src/configs/app.ts index 64e2c38..03017c7 100644 --- a/src/configs/app.ts +++ b/src/configs/app.ts @@ -1,23 +1,29 @@ import RedmineIssueEventEmitterConfigLoader from '@app/event-emitter/configs/main-config'; +import { readFileSync } from 'fs'; +import { join } from 'path'; +import { parse } from 'jsonc-parser'; const redmineIssueEventEmitterConfig = RedmineIssueEventEmitterConfigLoader(); -const appConfig = { - couchDbUrl: - process.env['ELTEX_REDMINE_HELPER_COUCHDB_URL'] || 'http://localhost:5984', - - dbs: { - issues: - process.env['ELTEX_REDMINE_HELPER_COUCHDB_ISSUES_DB_NAME'] || - 'redmine_issues', - users: - process.env['ELTEX_REDMINE_HELPER_COUCHDB_USERS_DB_NAME'] || - 'redmine_users', - }, - - redmineIssueEventEmitterConfig: redmineIssueEventEmitterConfig, -}; +let appConfig; export default () => { + if (appConfig) { + return appConfig; + } + + const userDefinedConfigPath = process.env['ELTEX_REDMINE_HELPER_CONFIG_PATH']; + const defaultConfigPath = join('configs', 'main-config.jsonc'); + const configPath = userDefinedConfigPath || defaultConfigPath; + + const rawData = readFileSync(configPath, { encoding: 'utf-8' }); + + const data = parse(rawData); + + appConfig = { + ...data, + redmineIssueEventEmitterConfig: redmineIssueEventEmitterConfig, + }; + return appConfig; };