2018-06-14 08:33:45 +10:00

48 lines
1.1 KiB
JavaScript

'use strict';
/**
* This appender has been deprecated.
* Updates and bug fixes should be made against https://github.com/log4js-node/slack
*/
const Slack = require('slack-node');
function slackAppender(_config, layout, slack) {
const appender = (loggingEvent) => {
const data = {
channel_id: _config.channel_id,
text: layout(loggingEvent, _config.timezoneOffset),
icon_url: _config.icon_url,
username: _config.username
};
/* eslint no-unused-vars:0 */
slack.api('chat.postMessage', {
channel: data.channel_id,
text: data.text,
icon_url: data.icon_url,
username: data.username
}, (err, response) => {
if (err) {
throw err;
}
});
};
// trigger a deprecation warning.
appender.deprecated = '@logj4s-node/slack';
return appender;
}
function configure(_config, layouts) {
const slack = new Slack(_config.token);
let layout = layouts.basicLayout;
if (_config.layout) {
layout = layouts.layout(_config.layout.type, _config.layout);
}
return slackAppender(_config, layout, slack);
}
module.exports.configure = configure;