mirror of https://github.com/BTCPrivate/z-nomp.git
87 lines
2.2 KiB
JavaScript
87 lines
2.2 KiB
JavaScript
var dateFormat = require('dateformat');
|
|
/*
|
|
var defaultConfiguration = {
|
|
'default': true,
|
|
'keys': {
|
|
'client' : 'warning',
|
|
'system' : true,
|
|
'submitblock' : true,
|
|
}
|
|
};
|
|
*/
|
|
|
|
var severityToInt = function(severity) {
|
|
switch(severity) {
|
|
case 'debug':
|
|
return 10;
|
|
case 'warning':
|
|
return 20;
|
|
case 'error':
|
|
return 30;
|
|
default:
|
|
console.log("Unknown severity "+severity);
|
|
return 1000;
|
|
}
|
|
}
|
|
var getSeverityColor = function(severity) {
|
|
switch(severity) {
|
|
case 'debug':
|
|
return 32;
|
|
case 'warning':
|
|
return 33;
|
|
case 'error':
|
|
return 31;
|
|
default:
|
|
console.log("Unknown severity "+severity);
|
|
return 31;
|
|
}
|
|
}
|
|
|
|
var PoolLogger = function (configuration) {
|
|
|
|
// privates
|
|
var shouldLog = function(key, severity) {
|
|
var keyValue = configuration.keys[key];
|
|
if (typeof(keyValue) === 'undefined') {
|
|
keyValue = configuration.default;
|
|
}
|
|
|
|
if (typeof(keyValue) === 'boolean') {
|
|
return keyValue;
|
|
} else if (typeof(keyValue) === 'string') {
|
|
return severityToInt(severity) >= severityToInt(keyValue);
|
|
}
|
|
}
|
|
|
|
var log = function(severity, key, poolName, text) {
|
|
if ( ! shouldLog(key, severity) ) {
|
|
// if this tag is set to not be logged or the default value is false then drop it!
|
|
//console.log(key+"DROPPED "+text + 'SEV' + severity);
|
|
return;
|
|
|
|
}
|
|
var desc = poolName ? '[' + poolName + '] ' : '';
|
|
console.log(
|
|
'\u001b['+getSeverityColor(severity)+'m' +
|
|
dateFormat(new Date(), 'yyyy-mm-dd HH:mm:ss') +
|
|
" ["+key+"]" + '\u001b[39m: ' + "\t" +
|
|
desc +
|
|
text);
|
|
}
|
|
|
|
// public
|
|
|
|
this.logDebug = function(poolName, logKey, text){
|
|
log('debug', logKey, poolName, text);
|
|
}
|
|
|
|
this.logWarning = function(poolName, logKey, text) {
|
|
log('warning', logKey, poolName, text);
|
|
}
|
|
|
|
this.logError = function(poolName, logKey, text) {
|
|
log('error', logKey, poolName, text);
|
|
}
|
|
}
|
|
|
|
module.exports = PoolLogger; |