console.xxx({_at,_from,...})

This commit is contained in:
Luk 2024-02-05 11:36:01 +08:00
parent c4f591367d
commit 424e363b60

View File

@ -25,15 +25,15 @@ module.exports = {
if (!global.envar) { if (!global.envar) {
global.envar = rawEnvar // 不知为何必须定义成全局变量才能保证多次require只执行一次。 global.envar = rawEnvar // 不知为何必须定义成全局变量才能保证多次require只执行一次。
console.info(`<<<<<<<< Configuring [${process.env.NODE_ENV}] Environment <<<<<<<<`) console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: `<<<<<<<< Configuring [${process.env.NODE_ENV}] Environment <<<<<<<<` }, '\n,')
console.info('- Loading Configuration Files (读取配置文件)') console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: '- Loading Configuration Files (读取配置文件)' }, '\n,')
if (typeof envarFiles === 'string') { if (typeof envarFiles === 'string') {
// 例如当输入参数为 envarFiles = 'envar-base.js' 里面应当 module.exports 一个数组 // 例如当输入参数为 envarFiles = 'envar-base.js' 里面应当 module.exports 一个数组
if (fs.existsSync(path.resolve(envarFiles))) { if (fs.existsSync(path.resolve(envarFiles))) {
envarFiles = require(path.resolve(envarFiles)) envarFiles = require(path.resolve(envarFiles))
} else { } else {
console.warn(` - ${envarFiles} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar', about: ` - ${envarFiles} is missing.` }, '\n,')
envarFiles = undefined envarFiles = undefined
} }
} }
@ -42,26 +42,26 @@ module.exports = {
for (let configFile of envarFiles) { for (let configFile of envarFiles) {
if (fs.existsSync(path.resolve(configFile))) { if (fs.existsSync(path.resolve(configFile))) {
global.envar = deepmerge(global.envar, require(path.resolve(configFile))) global.envar = deepmerge(global.envar, require(path.resolve(configFile)))
console.info(` - ${configFile} is loaded.`) console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: ` - ${configFile} is loaded.` }, '\n,')
} else { } else {
console.warn(` - ${configFile} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar', about: ` - ${configFile} is missing.` }, '\n,')
} }
} }
} else if (typeof envarFiles === 'object') { } else if (typeof envarFiles === 'object') {
global.envar = deepmerge(global.envar, envarFiles) global.envar = deepmerge(global.envar, envarFiles)
} else { } else {
console.warn(` - unrecognized envarFiles!`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar', about: ` - unrecognized envarFiles!` }, '\n,')
} }
if (process.argv.length > 2 && Array.isArray(global.envar.commanderOptions)) { if (process.argv.length > 2 && Array.isArray(global.envar.commanderOptions)) {
console.info('- Loading Command Line Parameters (载入命令行参数)') console.info({ _at: new Date().toJSON(), _from: 'merge_envar', about: '- Loading Command Line Parameters (载入命令行参数)' }, '\n,')
const commander = require('commander') const commander = require('commander')
commander.version(global.envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v就要加 '-v --version' commander.version(global.envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v就要加 '-v --version'
for (let [key, param, desc] of global.envar.commanderOptions || []) { for (let [key, param, desc] of global.envar.commanderOptions || []) {
commander.option(param, `${desc} Default = "${global.envar[key]}"`) commander.option(param, `${desc} Default = "${global.envar[key]}"`)
} }
commander.parse(process.argv) commander.parse(process.argv)
// console.log('- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)') // console.log({_at:new Date().toJSON(),_from:'merge_envar', about: '- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)' },'\n,')
for (let key in commander) { for (let key in commander) {
if (!/^_/.test(key) && typeof commander[key] === 'string') { if (!/^_/.test(key) && typeof commander[key] === 'string') {
// commander 自带了一批 _开头的属性过滤掉 // commander 自带了一批 _开头的属性过滤掉
@ -71,7 +71,7 @@ module.exports = {
delete global.envar.commanderOptions delete global.envar.commanderOptions
} }
console.log(`>>>>>>>> Configured [${process.env.NODE_ENV}] Environment >>>>>>>>`) console.log({ _at: new Date().toJSON(), _from: 'merge_envar', about: `>>>>>>>> Configured [${process.env.NODE_ENV}] Environment >>>>>>>>` }, '\n,')
} }
return global.envar return global.envar
@ -89,7 +89,7 @@ module.exports = {
if (fs.existsSync(path.resolve(dynamicEnvarFiles))) { if (fs.existsSync(path.resolve(dynamicEnvarFiles))) {
dynamicEnvarFiles = require(path.resolve(dynamicEnvarFiles)) dynamicEnvarFiles = require(path.resolve(dynamicEnvarFiles))
} else { } else {
console.warn(` - ${dynamicEnvarFiles} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'get_dynamic_envar', about: ` - ${dynamicEnvarFiles} is missing.` }, '\n,')
dynamicEnvarFiles = undefined dynamicEnvarFiles = undefined
} }
} }
@ -99,15 +99,15 @@ module.exports = {
if (fs.existsSync(path.resolve(dynamicFile))) { if (fs.existsSync(path.resolve(dynamicFile))) {
delete require.cache[require.resolve(path.resolve(dynamicFile))] // delete require.cache[fullpath] 不起作用,必须要加 require.resolve delete require.cache[require.resolve(path.resolve(dynamicFile))] // delete require.cache[fullpath] 不起作用,必须要加 require.resolve
dynamicEnvar = deepmerge(dynamicEnvar, require(path.resolve(dynamicFile))) // 在这里其实不需要 deepmerge dynamicEnvar = deepmerge(dynamicEnvar, require(path.resolve(dynamicFile))) // 在这里其实不需要 deepmerge
console.info(` - ${dynamicFile} is parsed.`) console.info({ _at: new Date().toJSON(), _from: 'get_dynamic_envar', about: ` - ${dynamicFile} is parsed.` }, '\n,')
} else { } else {
console.warn(` - ${dynamicFile} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'get_dynamic_envar', about: ` - ${dynamicFile} is missing.` }, '\n,')
} }
} }
} else if (typeof dynamicEnvarFiles === 'object') { } else if (typeof dynamicEnvarFiles === 'object') {
dynamicEnvar = dynamicEnvarFiles dynamicEnvar = dynamicEnvarFiles
} else { } else {
console.warn(` - unrecognized dynamicEnvarFiles!`) console.warn({ _at: new Date().toJSON(), _from: 'get_dynamic_envar', about: ` - unrecognized dynamicEnvarFiles!` }, '\n,')
} }
return dynamicEnvar return dynamicEnvar
@ -125,25 +125,25 @@ module.exports = {
if (fs.existsSync(path.resolve(secretEnvarFiles))) { if (fs.existsSync(path.resolve(secretEnvarFiles))) {
secretEnvarFiles = require(path.resolve(secretEnvarFiles)) secretEnvarFiles = require(path.resolve(secretEnvarFiles))
} else { } else {
console.warn(` - ${secretEnvarFiles} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'mask_secret_envar', about: ` - ${secretEnvarFiles} is missing.` }, '\n,')
secretEnvarFiles = undefined secretEnvarFiles = undefined
} }
} }
console.info(` - Parsing secretEnvarFiles...`) console.info({ _at: new Date().toJSON(), _from: 'mask_secret_envar', about: ` - Parsing secretEnvarFiles...` }, '\n,')
if (Array.isArray(secretEnvarFiles)) { if (Array.isArray(secretEnvarFiles)) {
for (let secretFile of secretEnvarFiles) { for (let secretFile of secretEnvarFiles) {
if (fs.existsSync(path.resolve(secretFile))) { if (fs.existsSync(path.resolve(secretFile))) {
secretEnvar = deepmerge(secretEnvar, require(path.resolve(secretFile))) // 在这里其实不需要 deepmerge secretEnvar = deepmerge(secretEnvar, require(path.resolve(secretFile))) // 在这里其实不需要 deepmerge
console.info(` - ${secretFile} is parsed.`) console.info({ _at: new Date().toJSON(), _from: 'mask_secret_envar', about: ` - ${secretFile} is parsed.` }, '\n,')
} else { } else {
console.warn(` - ${secretFile} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'mask_secret_envar', about: ` - ${secretFile} is missing.` }, '\n,')
} }
} }
} else if (typeof secretEnvarFiles === 'object') { } else if (typeof secretEnvarFiles === 'object') {
secretEnvar = secretEnvarFiles secretEnvar = secretEnvarFiles
} else { } else {
console.warn(` - unrecognized secretEnvarFiles!`) console.warn({ _at: new Date().toJSON(), _from: 'mask_secret_envar', about: ` - unrecognized secretEnvarFiles!` }, '\n,')
} }
for (let key in secretEnvar) { for (let key in secretEnvar) {
@ -166,14 +166,14 @@ module.exports = {
} = {}) { } = {}) {
let envar = this.get_envar({ inProcess: false, refresh: true, files }) let envar = this.get_envar({ inProcess: false, refresh: true, files })
if (process.argv.length > 2 && Array.isArray(envar.commanderOptions)) { if (process.argv.length > 2 && Array.isArray(envar.commanderOptions)) {
console.info('- Loading Command Line Parameters (载入命令行参数)') console.info({ _at: new Date().toJSON(), _from: 'envar_all', about: '- Loading Command Line Parameters (载入命令行参数)' }, '\n,')
const commander = require('commander') const commander = require('commander')
commander.version(envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v就要加 '-v --version' commander.version(envar.Base_Version || '0.0.1', '-v, --version') // 默认是 -V。如果要 -v就要加 '-v --version'
for (let [key, param, desc] of envar.commanderOptions || []) { for (let [key, param, desc] of envar.commanderOptions || []) {
commander.option(param, `${desc} Default = "${envar[key]}"`) commander.option(param, `${desc} Default = "${envar[key]}"`)
} }
commander.parse(process.argv) commander.parse(process.argv)
// console.log('- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)') // console.log({_at:new Date().toJSON(),_from:'envar_all', about: '- Merging Command Line Parameters into Configuration (把命令行参数值合并入配置)' },'\n,')
for (let key in commander) { for (let key in commander) {
if (!/^_/.test(key) && typeof commander[key] === 'string') { if (!/^_/.test(key) && typeof commander[key] === 'string') {
// commander 自带了一批 _开头的属性过滤掉 // commander 自带了一批 _开头的属性过滤掉
@ -211,7 +211,7 @@ module.exports = {
if (fs.existsSync(path.resolve(files))) { if (fs.existsSync(path.resolve(files))) {
files = require(path.resolve(files)) files = require(path.resolve(files))
} else { } else {
console.warn(` - ${files} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar_files', about: ` - ${files} is missing.` }, '\n,')
files = undefined files = undefined
} }
} }
@ -223,15 +223,15 @@ module.exports = {
delete require.cache[require.resolve(path.resolve(envarFile))] // delete require.cache[fullpath] 不起作用,必须要加 require.resolve delete require.cache[require.resolve(path.resolve(envarFile))] // delete require.cache[fullpath] 不起作用,必须要加 require.resolve
} }
envar = deepmerge(envar, require(path.resolve(envarFile))) envar = deepmerge(envar, require(path.resolve(envarFile)))
console.info(` - ${envarFile} is parsed.`) console.info({ _at: new Date().toJSON(), _from: 'merge_envar_files', about: ` - ${envarFile} is parsed.` }, '\n,')
} else { } else {
console.warn(` - ${envarFile} is missing.`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar_files', about: ` - ${envarFile} is missing.` }, '\n,')
} }
} }
} else if (typeof files === 'object') { } else if (typeof files === 'object') {
envar = files envar = files
} else { } else {
console.warn(` - unrecognized files!`) console.warn({ _at: new Date().toJSON(), _from: 'merge_envar_files', about: ` - unrecognized files!` }, '\n,')
} }
return envar return envar