mirror of
https://github.com/reality/dbot.git
synced 2024-11-30 16:09:27 +01:00
8e8953999d
* Admin module doesn't try to use reload string when it's not there. * Fix dent event hookin * Fix quote retrieval (two ~q definitions and no false check before interpolate) * Change databankerised modules to use redis for testing
79 lines
2.3 KiB
JavaScript
79 lines
2.3 KiB
JavaScript
var request = require('request');
|
|
_ = require('underscore')._;
|
|
|
|
var dent = function(dbot) {
|
|
this.dbot = dbot;
|
|
this.StatusRegex = {
|
|
identica: /\bhttps?:\/\/identi\.ca\/notice\/(\d+)\b/ig,
|
|
twitter: /\bhttps?:\/\/twitter\.com\/\w+\/status\/(\d+)\b/ig
|
|
};
|
|
|
|
this.StatusAPI = {
|
|
identica: "http://identi.ca/api/statuses/show.json",
|
|
twitter: "https://api.twitter.com/1/statuses/show.json"
|
|
};
|
|
|
|
this.api = {
|
|
'post': function(content) {
|
|
var username = dbot.config.dent.username,
|
|
password = dbot.config.dent.password,
|
|
info,
|
|
auth = "Basic " +
|
|
new Buffer(username + ":" + password).toString("base64");
|
|
|
|
request.post({
|
|
'url': 'http://identi.ca/api/statuses/update.json?status=' +
|
|
escape(content),
|
|
'headers': {
|
|
'Authorization': auth
|
|
}
|
|
},
|
|
function(error, response, body) {
|
|
console.log(body);
|
|
}.bind(this));
|
|
}
|
|
};
|
|
|
|
this.lookup = function(event, id, service) {
|
|
request({
|
|
url: this.StatusAPI[service],
|
|
qs: {"id": id},
|
|
json: true
|
|
}, function(error, response, body) {
|
|
if (!error && response.statusCode == 200) {
|
|
if (_.has(body, 'text')) {
|
|
event.reply(service + " [" + body.user.screen_name + '] ' + body.text);
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
this.commands = {
|
|
'~dent': function(event) {
|
|
this.api.post(event.input[1]);
|
|
event.reply('Dent posted (probably).');
|
|
}
|
|
};
|
|
this.commands['~dent'].regex = [/^~dent (.+)$/, 2];
|
|
|
|
this.onLoad = function() {
|
|
if(dbot.config.dent.dentQuotes === true && _.has(dbot.modules, 'quotes')) {
|
|
dbot.api.event.addHook('~qadd', function(key, text) {
|
|
if(text.indexOf('~~') == -1) {
|
|
this.api.post(key + ': ' + text);
|
|
}
|
|
}.bind(this));
|
|
}
|
|
|
|
for(s in this.StatusRegex) {
|
|
dbot.api.link.addHandler(s, this.StatusRegex[s], function(event, matches, name) {
|
|
this.lookup(event, matches[1], name);
|
|
}.bind(this));
|
|
}
|
|
}.bind(this);
|
|
};
|
|
|
|
exports.fetch = function(dbot) {
|
|
return new dent(dbot);
|
|
};
|