Mailspring/packages/nylas-core/logger.js
2016-07-11 12:12:38 -07:00

53 lines
1.2 KiB
JavaScript

const bunyan = require('bunyan')
const createCWStream = require('bunyan-cloudwatch')
const NODE_ENV = process.env.NODE_ENV || 'unknown'
function getLogStreams(name, env) {
const stdoutStream = {
stream: process.stdout,
level: 'info',
}
if (env === 'development') {
return [stdoutStream]
}
const cloudwatchStream = {
stream: createCWStream({
logGroupName: `k2-${env}`,
logStreamName: `${name}-${env}`,
cloudWatchLogsOptions: {
region: 'us-east-1',
},
}),
type: 'raw',
reemitErrorEvents: true,
}
return [stdoutStream, cloudwatchStream]
}
function createLogger(name, env = NODE_ENV) {
const childLogs = new Map()
const logger = bunyan.createLogger({
name,
serializers: bunyan.stdSerializers,
streams: getLogStreams(name, env),
})
return Object.assign(logger, {
forAccount(account = {}) {
if (!childLogs.has(account.id)) {
const childLog = logger.child({
account_id: account.id,
account_email: account.emailAddress,
})
childLogs.set(account.id, childLog)
}
return childLogs.get(account.id)
},
})
}
module.exports = {
createLogger,
}