From f37c431c6297cdf65fd9bd4df85708d6b3906df6 Mon Sep 17 00:00:00 2001 From: Luk Lu Date: Wed, 27 Apr 2022 09:26:07 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E4=B8=80=E4=BA=9B=E5=90=8D?= =?UTF-8?q?=E5=AD=97=EF=BC=9B=E8=AE=A9=20maskSecret=20=E6=8D=A2=E7=94=A8?= =?UTF-8?q?=20secretEnvarFile=20=E5=8F=82=E6=95=B0=E6=9D=A5=E8=BF=87?= =?UTF-8?q?=E6=BB=A4=E6=9C=BA=E5=AF=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- index.js | 47 ++++++++++++++++++++++++----------------------- 1 file changed, 24 insertions(+), 23 deletions(-) diff --git a/index.js b/index.js index 7a37a8a..3e0ab50 100644 --- a/index.js +++ b/index.js @@ -3,15 +3,13 @@ const path = require('path') const commander = require('commander') const deepmerge = require('deepmerge') -const my = { secretKeys:[] } - module.exports = { - mergeConfig({rawConfig={}, envarFiles=['./envar-base-basic.js', './envar-base-custom.js', './envar-base-secret.js']} = {}) { + mergeEnvar({rawEnvar={}, envarFiles=['./envar-base-basic.js', './envar-base-custom.js', './envar-base-secret.js'], hasCommander=true} = {}) { if (!global.envar) { - global.envar = rawConfig + global.envar = rawEnvar // 不知为何,必须定义成全局变量,才能保证多次require只执行一次。 - console.info('<<<<<<<< Collecting Environment Configuration <<<<<<<<') + console.info('<<<<<<<< Configuring Environment Variables <<<<<<<<') console.info('- Loading Configuration Files (读取配置文件)') @@ -31,28 +29,30 @@ module.exports = { delete global.envar.ENV_PRODUCTION } - console.info('- Loading Command Line Parameters (载入命令行参数)') - commander.version(global.envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v,就要加 '-v --version' - for (let [key, param, desc] of global.envar.Commander_Option_List || []) { - commander.option(param, `${desc} Default = "${global.envar[key]}"`) - } - commander.parse(process.argv) - delete global.envar.Commander_Option_List // do not print Commander_Option_List to console + if (hasCommander) { + console.info('- Loading Command Line Parameters (载入命令行参数)') + commander.version(global.envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v,就要加 '-v --version' + for (let [key, param, desc] of global.envar.Commander_Option_List || []) { + commander.option(param, `${desc} Default = "${global.envar[key]}"`) + } + commander.parse(process.argv) + delete global.envar.Commander_Option_List - console.log('- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)') - for (let key in commander) { - if (!/^_/.test(key) && typeof commander[key] === 'string') { // commander 自带了一批 _开头的属性,过滤掉 - global.envar[key] = commander[key] + console.log('- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)') + for (let key in commander) { + if (!/^_/.test(key) && typeof commander[key] === 'string') { // commander 自带了一批 _开头的属性,过滤掉 + global.envar[key] = commander[key] + } } } } - console.log('>>>>>>>> Collected Environment Configuration >>>>>>>>') + console.log('>>>>>>>> Configured Environment Variables >>>>>>>>') return global.envar }, - getDynamicConfig(dynamicConfigFile='envar-base-dynamic.js') { // dynamicConfigFile should be absolute or relative to the node process's dir. - const fullpath = path.resolve(dynamicConfigFile) + getDynamicEnvar({dynamicEnvarFile='envar-base-dynamic.js'}={}) { // dynamicEnvarFile should be absolute or relative to the node process's dir. + const fullpath = path.resolve(dynamicEnvarFile) if (fs.existsSync(fullpath)) { delete require.cache[require.resolve(fullpath)] // delete require.cache[fullpath] 不起作用 return require(fullpath) @@ -61,11 +61,12 @@ module.exports = { } }, - maskSecret() { + maskSecret({secretEnvarFile='./envar-base-secret.js'}={}) { let envar = JSON.parse(JSON.stringify(global.envar)) // 复制一份,避免污染 - for (let key in envar) { - if (/^SECRET_/.test(key)) { - envar[key] = '*** confidentical ***' + if (fs.existsSync(path.resolve(secretEnvarFile))) { + const secretEnvar = require(path.resolve(secretEnvarFile)) + for (let key in secretEnvar) { + envar[key] = '****** confidential ******' } } return envar