summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/BitrafBot.js (renamed from lib/client.js)43
-rw-r--r--main.js11
2 files changed, 31 insertions, 23 deletions
diff --git a/lib/client.js b/lib/BitrafBot.js
index adbc25a..9388ddb 100644
--- a/lib/client.js
+++ b/lib/BitrafBot.js
@@ -8,7 +8,7 @@ var IRC = require('../node_modules/node-irc/IRC.js').IRC
var BitrafBot = function(config) {
var nick = '';
var nickCount = 0;
- var nickAdditions = [ '', '^', '_', '\\', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' ];
+ var nickAdditions = [ '', '^', '-', '_', '\\', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' ];
function findNick() {
if (nickCount == nickAdditions.length) {
@@ -27,34 +27,39 @@ var BitrafBot = function(config) {
});
irc.on('privmsg', function(from, to, message) {
if(message == ',checkins') {
- console.log('checkins request.');
- var now = new Date();
- var from = (now.getYear() + 1900) + "-" + (now.getMonth() + 1) + "-" + now.getDate();
+ var checkinsUrl = config.checkinsUrl
+ console.log('checkins request. url=' + checkinsUrl);
- var options = url.parse(config.checkinsUrl + '?from=' + from);
+ var options = url.parse(checkinsUrl);
options.headers = { Accept: 'application/vnd.collection+json' };
options.method = 'GET';
var req = http.get(options, function(res) {
- var chunks = "";
+ var chunks = '';
res.on('data', function (chunk) {
chunks += chunk;
});
res.on('end', function () {
- // console.log("chunks", chunks);
- data = JSON.parse(chunks);
- var checkins = -1;
- _.each(data["collection"].items, function(item, i) {
- _.each(item.data, function(item, i) {
- if(item.name === "checkins") {
- checkins = parseInt(item.value);
- }
+ try {
+ data = JSON.parse(chunks);
+ var checkins = -1;
+ var lastCheckin = 'unknown';
+ _.each(data['collection'].items, function(item, i) {
+ _.each(item.data, function(item, i) {
+ switch(item.name) {
+ case 'checkins': checkins = parseInt(item.value); break;
+ case 'last-checkin': lastCheckin = item.value; break;
+ }
+ });
});
- });
- if(checkins != -1) {
- irc.privmsg(to, 'checkins: ' + checkins);
+ if(checkins != -1) {
+ irc.privmsg(to, 'checkins: ' + checkins + ', last checkin: ' + lastCheckin);
+ }
+ else {
+ irc.privmsg(to, 'Could not find any checkins');
+ }
}
- else {
- irc.privmsg(to, 'Could not find any checkins');
+ catch(ex) {
+ irc.privmsg(to, 'Could not parse document');
}
});
}).on('error', function(e) {
diff --git a/main.js b/main.js
index 6774bae..105543d 100644
--- a/main.js
+++ b/main.js
@@ -12,17 +12,20 @@ parser.option("--checkinsUrl", "URL to use when looking for checkins");
var args = process.argv.slice(2);
var defaults = {
channel: "#bitraf",
- checkinsUrl: 'http://hermes.bitraf.no/~trygvis/checkins.php',
+ checkinsUrl: 'http://hermes.bitraf.no/~trygvis/checkins/checkins-by-day.php?from=today',
nick: os.hostname()
};
try {
var config = parser.parse(args);
+ if (config.help) {
+ console.log(parser.help());
+ return;
+ }
config = _.defaults(config, defaults);
- console.log("config", config);
- if (config.help) console.log(parser.help());
- var bot = require('./lib/client.js')(config);
+ console.log("configuration: ", config);
+ var bot = require('./lib/BitrafBot.js')(config);
var r = repl.start('irc> ');
r.context.bot = bot;
r.context.config = config;