2018-03-27 12:32:07 -07:00
|
|
|
const logger = require('winston');
|
2018-03-27 12:47:55 -07:00
|
|
|
|
2018-03-27 12:32:07 -07:00
|
|
|
function LoggerConfig () {
|
|
|
|
this.logLevel = 'debug';
|
2018-03-29 12:46:20 -07:00
|
|
|
this.update = (config) => {
|
2018-03-27 12:32:07 -07:00
|
|
|
if (!config) {
|
2018-03-29 12:33:52 -07:00
|
|
|
return logger.warn('No logger config received.');
|
2018-03-27 12:32:07 -07:00
|
|
|
}
|
2018-03-29 12:33:52 -07:00
|
|
|
logger.info('configuring winston logger...');
|
2018-03-27 12:32:07 -07:00
|
|
|
// update values with local config params
|
|
|
|
const {logLevel} = config;
|
|
|
|
this.logLevel = logLevel;
|
|
|
|
// configure the winston logger
|
|
|
|
logger.configure({
|
|
|
|
transports: [
|
|
|
|
new (logger.transports.Console)({
|
|
|
|
level : this.logLevel,
|
|
|
|
timestamp : false,
|
|
|
|
colorize : true,
|
|
|
|
prettyPrint : true,
|
|
|
|
handleExceptions : true,
|
|
|
|
humanReadableUnhandledException: true,
|
|
|
|
}),
|
|
|
|
],
|
|
|
|
});
|
|
|
|
// test all the log levels
|
2018-03-29 12:33:52 -07:00
|
|
|
logger.info('testing winston log levels...');
|
2018-03-27 12:32:07 -07:00
|
|
|
logger.error('Level 0');
|
|
|
|
logger.warn('Level 1');
|
|
|
|
logger.info('Level 2');
|
|
|
|
logger.verbose('Level 3');
|
|
|
|
logger.debug('Level 4');
|
|
|
|
logger.silly('Level 5');
|
|
|
|
};
|
2017-06-19 13:10:06 -07:00
|
|
|
};
|
2018-03-09 16:45:24 -08:00
|
|
|
|
2018-03-27 12:32:07 -07:00
|
|
|
module.exports = new LoggerConfig();
|