2017-06-03 22:35:47 +02:00
|
|
|
import * as winston from "winston";
|
|
|
|
|
|
|
|
declare module 'winston' {
|
2017-06-10 22:32:56 +02:00
|
|
|
interface LoggerInstance {
|
|
|
|
logFileName: string;
|
|
|
|
logFilePath: string;
|
|
|
|
}
|
2017-06-03 22:35:47 +02:00
|
|
|
}
|
|
|
|
|
2017-06-04 15:25:08 +02:00
|
|
|
export const winstonSettings = {
|
2017-06-10 22:32:56 +02:00
|
|
|
transports: [
|
|
|
|
new winston.transports.Console({
|
2017-07-16 20:49:39 +02:00
|
|
|
level: process.env.NODE_ENV == "production" ? "info" : 'silly',
|
2017-06-10 22:32:56 +02:00
|
|
|
handleExceptions: true,
|
|
|
|
json: false,
|
|
|
|
colorize: true,
|
|
|
|
timestamp: function () {
|
|
|
|
return (new Date()).toLocaleString();
|
|
|
|
},
|
|
|
|
label: "innerLabel",
|
|
|
|
formatter: (options) => {
|
|
|
|
// Return string will be passed to logger.
|
|
|
|
return options.timestamp() + '[' + winston['config']['colorize'](options.level, options.level.toUpperCase()) + '] ' +
|
|
|
|
(undefined !== options.message ? options.message : '') +
|
|
|
|
(options.meta && Object.keys(options.meta).length ? '\n\t' + JSON.stringify(options.meta) : '' );
|
|
|
|
},
|
|
|
|
debugStdout: true
|
|
|
|
})
|
|
|
|
],
|
|
|
|
exitOnError: false
|
2017-06-04 15:25:08 +02:00
|
|
|
};
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
export const Logger = new winston.Logger(winstonSettings);
|