3
0
mirror of https://github.com/reality/dbot.git synced 2024-12-12 13:59:26 +01:00
dbot/modules/log/log.js

73 lines
2.3 KiB
JavaScript
Raw Normal View History

2013-05-25 21:13:35 +02:00
/**
* Name: Log
* Description: Log commands to a channel.
*/
2013-09-08 12:51:21 +02:00
var _ = require('underscore')._,
process = require('process');
2013-05-25 21:13:35 +02:00
var log = function(dbot) {
2013-08-18 19:42:23 +02:00
this.ignoredCommands = [];
this.api = {
'log': function(server, user, message) {
2013-08-18 18:39:35 +02:00
var logChannel = this.config.logChannel[server];
dbot.say(server, logChannel, dbot.t('log_message', {
'time': new Date().toUTCString(),
'command': message,
"channel": 'nochan',
'user': user
}));
2013-08-18 19:42:23 +02:00
},
2013-09-08 12:51:21 +02:00
'logError': function(server, err) {
var stack = err.stack.split('\n').slice(1, dbot.config.debugLevel + 1),
logChannel = this.config.logChannel[server],
time = new Date().toUTCString();
dbot.say(server, logChannel, dbot.t('error_message', {
'time': time,
'error': 'Message: ' + err
}));
_.each(stack, function(stackLine, index) {
dbot.say(server, logChannel, dbot.t('error_message', {
'time': time,
'error': 'Stack[' + index + ']: ' +
stackLine.trim()
}));
});
},
2013-08-18 19:42:23 +02:00
'ignoreCommand': function(commandName) {
this.ignoredCommands.push(commandName);
}
};
2013-05-25 21:13:35 +02:00
this.onLoad = function() {
dbot.api.event.addHook('command', function(event) {
var logChannel = this.config.logChannel[event.server];
2013-08-31 15:33:10 +02:00
channel = event.channel.name || 'PM';
2013-08-18 19:46:57 +02:00
if(logChannel && !_.include(this.ignoredCommands, event.message.split(' ')[0])) {
2013-05-25 21:13:35 +02:00
dbot.say(event.server, logChannel, dbot.t('log_message', {
'time': new Date().toUTCString(),
2013-08-31 15:33:10 +02:00
'channel': channel,
2013-05-25 21:13:35 +02:00
'command': event.message,
'user': event.user
}));
}
}.bind(this));
2013-09-08 12:51:21 +02:00
process.on('uncaughtException', function(err) {
2013-09-10 20:11:39 +02:00
console.log(err);
2013-09-08 12:51:21 +02:00
_.each(this.config.logChannel, function(chan, server) {
this.api.logError(server, err);
}, this);
process.exit(1);
}.bind(this));
2013-05-25 21:13:35 +02:00
}.bind(this);
};
exports.fetch = function(dbot) {
return new log(dbot);
};