wikijs-fork/server/libs/logger.js

78 lines
1.9 KiB
JavaScript
Raw Normal View History

2017-03-29 00:19:01 +00:00
'use strict'
2017-04-28 22:46:27 +00:00
module.exports = (isDebug, processName) => {
let winston = require('winston')
2017-03-29 00:19:01 +00:00
2017-04-28 22:46:27 +00:00
if (typeof processName === 'undefined') {
processName = 'SERVER'
2017-03-29 00:19:01 +00:00
}
2017-04-28 22:46:27 +00:00
// Console
2017-03-29 00:19:01 +00:00
2017-04-28 22:46:27 +00:00
let logger = new (winston.Logger)({
2017-03-29 00:19:01 +00:00
level: (isDebug) ? 'debug' : 'info',
2017-04-28 22:46:27 +00:00
transports: [
new (winston.transports.Console)({
level: (isDebug) ? 'debug' : 'info',
prettyPrint: true,
colorize: true,
silent: false,
timestamp: true
})
]
})
logger.filters.push((level, msg) => {
return '[' + processName + '] ' + msg
2017-03-29 00:19:01 +00:00
})
// External services
if (appconfig.externalLogging.bugsnag) {
const bugsnagTransport = require('./winston-transports/bugsnag')
2017-04-28 22:46:27 +00:00
logger.add(bugsnagTransport, {
2017-03-29 00:19:01 +00:00
level: 'warn',
key: appconfig.externalLogging.bugsnag
})
}
if (appconfig.externalLogging.loggly) {
require('winston-loggly-bulk')
2017-04-28 22:46:27 +00:00
logger.add(winston.transports.Loggly, {
2017-03-29 00:19:01 +00:00
token: appconfig.externalLogging.loggly.token,
subdomain: appconfig.externalLogging.loggly.subdomain,
tags: ['wiki-js'],
level: 'warn',
json: true
})
}
if (appconfig.externalLogging.papertrail) {
require('winston-papertrail').Papertrail // eslint-disable-line no-unused-expressions
2017-04-28 22:46:27 +00:00
logger.add(winston.transports.Papertrail, {
2017-03-29 00:19:01 +00:00
host: appconfig.externalLogging.papertrail.host,
port: appconfig.externalLogging.papertrail.port,
level: 'warn',
program: 'wiki.js'
})
}
if (appconfig.externalLogging.rollbar) {
const rollbarTransport = require('./winston-transports/rollbar')
2017-04-28 22:46:27 +00:00
logger.add(rollbarTransport, {
2017-03-29 00:19:01 +00:00
level: 'warn',
key: appconfig.externalLogging.rollbar
})
}
2017-03-30 01:49:30 +00:00
if (appconfig.externalLogging.sentry) {
const sentryTransport = require('./winston-transports/sentry')
2017-04-28 22:46:27 +00:00
logger.add(sentryTransport, {
2017-03-30 01:49:30 +00:00
level: 'warn',
key: appconfig.externalLogging.sentry
})
}
2017-04-28 22:46:27 +00:00
return logger
2017-03-29 00:19:01 +00:00
}