修改一些名字;让 maskSecret 换用 secretEnvarFile 参数来过滤机密
This commit is contained in:
parent
d391472855
commit
f37c431c62
47
index.js
47
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
|
||||
|
Loading…
Reference in New Issue
Block a user