dbot/modules/atheme/atheme.js

116 lines
4.6 KiB
JavaScript
Raw Normal View History

/**
2014-09-05 13:38:33 +02:00
* Module Name: atheme
* Description: atheme mode references & retrieve channel flags
*/
var _ = require('underscore')._;
2014-09-04 17:26:28 +02:00
var atheme = function(dbot) {
2014-09-05 10:51:48 +02:00
this.flagStack = {};
2014-09-14 21:02:45 +02:00
this.hostStack = {};
2014-09-05 10:51:48 +02:00
this.api = {
'getChannelFlags': function(server, channel, callback) {
if(!_.has(this.flagStack, server)) this.flagStack[server] = {};
2014-09-05 11:15:05 +02:00
if(_.has(this.flagStack[server], channel)) { // Already an active flag call
2014-09-05 10:51:48 +02:00
this.flagStack[server][channel].callbacks.push(callback);
} else {
this.flagStack[server][channel] = {
'flags': {},
'callbacks': [ callback ]
};
}
dbot.say(server, 'chanserv', 'FLAGS ' + channel);
setTimeout(function() { // Delete callback if no response
if(_.has(this.flagStack[server], channel)) {
_.each(this.flagStack[server][channel].callbacks, function(callback) {
callback(true, null);
});
delete this.flagStack[server][channel];
}
}.bind(this), 10000);
2014-09-14 21:02:45 +02:00
},
'getVHosts': function(server, mask, callback) {
if(!_.has(this.hostStack, server)) this.hostStack[server] = {};
if(_.has(this.hostStack[server], mask)) { // Already an active host call
this.hostStack[server][channel].callbacks.push(callback);
} else {
this.hostStack[server][mask] = {
'users': [],
'callbacks': [ callback ]
};
}
dbot.say(server, 'hostserv', 'LISTVHOST ' + mask);
setTimeout(function() { // Delete callback if no response
if(_.has(this.hostStack[server], mask)) {
_.each(this.hostStack[server][mask].callbacks, function(callback) {
callback(true, null);
});
delete this.hostStack[server][mask];
}
}.bind(this), 10000);
2014-09-05 10:51:48 +02:00
}
};
this.commands = {
'~chanserv': function(event) {
if(_.has(this.config.chanserv, event.input[1])) {
event.reply('ChanServ flag ' + event.input[1] + ': ' + this.config.chanserv[event.input[1]]);
} else {
event.reply('I don\'t know anything about ' + event.input[1]);
}
},
'~chanmode': function(event) {
if(_.has(this.config.chanmodes, event.input[1])) {
event.reply('Channel Mode ' + event.input[1] + ': ' + this.config.chanmodes[event.input[1]]);
} else {
event.reply('I don\'t know anything about ' + event.input[1]);
}
}
};
2014-09-04 17:26:28 +02:00
this.commands['~chanserv'].regex = [/^chanserv (\+.)/, 2];
this.commands['~chanmode'].regex = [/^chanmode (\+.)/, 2];
2014-09-05 10:51:48 +02:00
this.listener = function(event) {
2014-09-05 11:15:05 +02:00
if(event.user === 'ChanServ') {
2014-09-06 20:43:26 +02:00
var flags = event.params.match(/(\d+)\s+([^ ]+)\s+(\+\w+)\s+\((\#[\w\.]+)\)/),
2014-09-08 12:42:59 +02:00
end = event.params.match(/end of \u0002(\#[\w\.]+)\u0002 flags listing/i);
2014-09-05 10:51:48 +02:00
if(flags && _.has(this.flagStack[event.server], flags[4])) {
this.flagStack[event.server][flags[4]].flags[flags[2]] = flags[3];
} else if(end) {
if(_.has(this.flagStack[event.server], end[1])) {
_.each(this.flagStack[event.server][end[1]].callbacks, function(callback) {
callback(null, this.flagStack[event.server][end[1]].flags);
2014-09-05 11:15:05 +02:00
}.bind(this));
2014-09-05 10:51:48 +02:00
delete this.flagStack[event.server][end[1]];
}
}
2014-09-14 21:02:45 +02:00
} else if(event.user === 'HostServ') {
_.each(this.hostStack[event.server], function(el, mask) {
if(event.params.match(mask)) {
var user = event.params.match(/- ([^ ]+)/),
end = event.params.match(/matches for pattern/);
if(user) {
this.hostStack[event.server][mask].users.push(user[1]);
} else if(end) {
_.each(this.hostStack[event.server][mask].callbacks, function(callback) {
callback(null, this.hostStack[event.server][mask].users);
}, this);
delete this.hostStack[event.server][mask];
}
}
}, this);
2014-09-05 10:51:48 +02:00
}
}.bind(this);
this.on = 'NOTICE';
};
exports.fetch = function(dbot) {
2014-09-04 17:26:28 +02:00
return new atheme(dbot);
};