From 9a7d03552dc21a379ad2f6da0b69fbb07646b004 Mon Sep 17 00:00:00 2001 From: Luk Date: Sat, 2 Nov 2024 20:51:19 +0800 Subject: [PATCH] rename envar-base-* to envar-config and envar-secret --- envar-tool.js | 42 +++++++++++++----------------------------- 1 file changed, 13 insertions(+), 29 deletions(-) diff --git a/envar-tool.js b/envar-tool.js index 3b69941..4c7a4b5 100644 --- a/envar-tool.js +++ b/envar-tool.js @@ -13,7 +13,7 @@ const readlineSync = require('readline-sync') const my = { envar: {} } module.exports = { - start_watching ({ envarFiles = ['./envar-base-dynamic.js', './envar-base-dynamic.gitignore.js'], rawEnvar = {}, interval = 1000 } = {}) { + start_watching ({ envarFiles = ['./envar-config.js', './envar-config.gitignore.js'], rawEnvar = {}, interval = 1000 } = {}) { chokidar.watch(envarFiles, { interval }).on('change', (onpath) => { // .on('all', (event, onpath)) 但这时,即使server刚启动,也会调用到这里一次 console.log('envarTool.start_watching: envar file changed:', onpath) @@ -77,22 +77,12 @@ module.exports = { * - 字符串数组: 按顺序导入导入每个文件,后面文件里的变量覆盖前面的。 * - 对象: 直接添加到 rawEnvar 上。 */ - merge_envar ({ - rawEnvar = {}, - envarFiles = [ - './envar-base-basic.js', - './envar-base-basic.gitignore.js', - './envar-base-dynamic.js', - './envar-base-dynamic.gitignore.js', - './envar-base-secret.js', - './envar-base-secret.gitignore.js', - ], - } = {}) { + merge_envar ({ rawEnvar = {}, envarFiles = ['./envar-config.js', './envar-config.gitignore.js'] } = {}) { console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: `<<<<<<<< Configuring [${process.env.NODE_ENV}] Environment <<<<<<<<` }, '\n,') console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: '- Loading Configuration Files (读取配置文件)' }, '\n,') if (typeof envarFiles === 'string') { - // 例如当输入参数为 envarFiles = 'envar-base.js' 里面应当 module.exports 一个数组 + // 例如当输入参数为 envarFiles = 'envar-config.js' 里面应当 module.exports 一个数组 if (fs.existsSync(path.resolve(envarFiles))) { envarFiles = require(path.resolve(envarFiles)) } else { @@ -141,14 +131,17 @@ module.exports = { delete rawEnvar.commanderOptions } - console.log({ _at: new Date().toJSON(), _from: 'merge_envar', about: `>>>>>>>> Configured [${process.env.NODE_ENV}] Environment >>>>>>>>` }, '\n,') + console.log( + { _at: new Date().toJSON(), _from: 'merge_envar', about: `>>>>>>>> Configured [${process.env.NODE_ENV || 'development'}] Environment >>>>>>>>` }, + '\n,' + ) return rawEnvar }, /* 读取动态配置文件中的环境变量。 */ - get_dynamic_envar ({ dynamicEnvarFiles = ['./envar-base-dynamic.js', './envar-base-dynamic.gitignore.js'], base2app } = {}) { + get_dynamic_envar ({ dynamicEnvarFiles = ['./envar-config.js', './envar-config.gitignore.js'], base2app } = {}) { // config file should be absolute or relative to the node process's dir. let dynamicEnvar = {} @@ -192,7 +185,7 @@ module.exports = { /* 隐藏机密配置文件中的环境变量。 * 需要输出当前环境变量时,必须调用本函数,避免机密信息被输出。 */ - mask_secret_envar ({ rawEnvar, secretEnvarFiles = ['./envar-base-secret.js', './envar-base-secret.gitignore.js'] } = {}) { + mask_secret_envar ({ rawEnvar, secretEnvarFiles = ['./envar-secret.js', './envar-secret.gitignore.js'] } = {}) { let envar = JSON.parse(JSON.stringify(rawEnvar)) // 复制一份,避免污染 let secretEnvar = {} @@ -237,16 +230,7 @@ module.exports = { }, // 预制方法 - envar_all ({ - files = [ - './envar-base-basic.js', - './envar-base-basic.gitignore.js', - './envar-base-dynamic.js', - './envar-base-dynamic.gitignore.js', - './envar-base-secret.js', - './envar-base-secret.gitignore.js', - ], - } = {}) { + envar_all ({ files = ['./envar-config.js', './envar-config.gitignore.js', './envar-secret.js', './envar-secret.gitignore.js'] } = {}) { let envar = this.get_envar({ inProcess: false, refresh: true, files }) if (process.argv.length > 2 && Array.isArray(envar.commanderOptions)) { console.info({ _at: new Date().toJSON(), _from: 'envar_all', about: '- Loading Command Line Parameters (载入命令行参数)' }, '\n,') @@ -267,13 +251,13 @@ module.exports = { } return envar }, - envar_basic ({ envarKey, files = ['./envar-base-basic.js', './envar-base-basic.gitignore.js'] } = {}) { + envar_basic ({ envarKey, files = ['./envar-config.js', './envar-config.gitignore.js'] } = {}) { return (my['basic'] = this.get_envar({ envarKey, inProcess: false, inCache: true, cachename: 'basic', refresh: false, files })) }, - envar_dynamic ({ envarKey, files = ['./envar-base-dynamic.js', './envar-base-dynamic.gitignore.js'] } = {}) { + envar_dynamic ({ envarKey, files = ['./envar-config.js', './envar-config.gitignore.js'] } = {}) { return this.get_envar({ envarKey, inProcess: true, inCache: false, refresh: true, files }) }, - envar_sesame ({ envarKey, files = ['./envar-base-secret.js', './envar-base-secret.gitignore.js'] } = {}) { + envar_sesame ({ envarKey, files = ['./envar-secret.js', './envar-secret.gitignore.js'] } = {}) { return (my['sesame'] = this.get_envar({ envarKey, inProcess: true, inCache: true, cachename: 'sesame', refresh: false, files })) }, // 可定制的通用方法