summaryrefslogtreecommitdiffstats
path: root/news/newsbot.js
diff options
context:
space:
mode:
Diffstat (limited to 'news/newsbot.js')
-rw-r--r--news/newsbot.js104
1 files changed, 89 insertions, 15 deletions
diff --git a/news/newsbot.js b/news/newsbot.js
index 4171e968..683bf39a 100644
--- a/news/newsbot.js
+++ b/news/newsbot.js
@@ -1,31 +1,40 @@
var IRC = require('irc')
var FeedParser = require('feedparser')
var Request = require('request')
+var Parse = require('shell-quote').parse
+var FS = require('fs')
var irc_server = 'ire.retiolum'
var master_nick = 'knews'
-var news_channel = '&testing'
+var news_channel = '#news'
var feeds_file = 'new_feeds'
var feedbot_loop_delay = 60 * 1000 // [ms]
+var slaves = {}
+
function main () {
- // XXX mangle nick to not clash with newsbot.py
- var master = new IRC.Client(irc_server, master_nick + '_2', {
+ var master = new IRC.Client(irc_server, master_nick, {
channels: [ news_channel ],
})
master.on('message' + news_channel, function (nick, text, message) {
if (is_talking_to(master_nick, text)) {
- var parse = /^[^:]*:\s*(\S*\S)\s*$/.exec(text)
- if (parse) {
- client.say(to, nick + ': ' + parse[1] + '?')
+ var request = parse_request(text)
+ if (request) {
+ return run_command(request.method, request.params, function (error, result) {
+ if (error) {
+ return master.say(news_channel, '4' + error)
+ } else {
+ return master.say(news_channel, result)
+ }
+ })
}
}
})
master.once('registered', function () {
// read feeds file and create a feedbot for each entry
- require('fs')
+ FS
.readFileSync(feeds_file)
.toString()
.split('\n')
@@ -45,16 +54,10 @@ function main () {
return
}
- // XXX mangle nick to not clash with newsbot.py
- var nick = parts[0] + '_2'
+ var nick = parts[0]
var uri = parts[1]
var channels = parts[2].split(' ')
- // XXX mangle channel to not clash with newsbot.py
- channels = channels.map(function (channel) {
- return channel === '#news' ? news_channel : channel
- })
-
return create_feedbot(nick, uri, channels)
})
})
@@ -65,6 +68,13 @@ function create_feedbot (nick, uri, channels) {
channels: channels,
})
+ slaves[nick] = {
+ client: client,
+ nick: nick,
+ uri: uri,
+ channels: channels,
+ }
+
// say text in every joined channel
function broadcast (text) {
Object.keys(client.chans).forEach(function (channel) {
@@ -141,7 +151,9 @@ function create_feedbot (nick, uri, channels) {
// (i.e. we already have a lastTitle)
if (client.lastTitle) {
newitems.forEach(function (item) {
- broadcast(item.title + ' ' + item.link)
+ return getShortLink(item.link, function (error, shortlink) {
+ return broadcast(item.title + ' ' + shortlink)
+ })
})
}
@@ -162,6 +174,68 @@ function is_talking_to (my_nick, text) {
&& text[my_nick.length] === ':'
}
+function parse_request (text) {
+ var parse = Parse(text)
+ return {
+ method: parse[1],
+ params: parse.slice(2),
+ }
+}
+
+function run_command (methodname, params, callback) {
+ var method = methods[methodname]
+ if (method) {
+ return method(params, callback)
+ } else {
+ return callback(new Error('dunno what ' + methodname + ' is'));
+ }
+}
+
+function getShortLink (link, callback) {
+ return callback(null, link)
+}
+
+var methods = {}
+methods.add = function (params, callback) {
+ if (slaves.hasOwnProperty(params[0])) {
+ return callback(new Error('name already taken'))
+ } else {
+ create_feedbot(params[0], params[1], [news_channel])
+ return callback(null)
+ }
+}
+methods.del = function (params, callback) {
+ var slave = slaves[params[0]]
+ if (slave) {
+ slave.client.disconnect()
+ delete slaves[params[0]]
+ return callback(null)
+ } else {
+ return callback(new Error('botname not found'))
+ }
+}
+methods.save = function (params, callback) {
+ var feeds = Object.keys(slaves)
+ .map(function (nick) {
+ return slaves[nick]
+ })
+ .map(function (slave) {
+ return [
+ slave.nick,
+ slave.uri,
+ slave.channels.join(' '),
+ ].join('|')
+ }).join('\n') + '\n'
+ return FS.writeFile(feeds_file, feeds, function (error) {
+ if (error) {
+ return callback(error)
+ } else {
+ return callback(null, 'Feeds saved')
+ }
+ })
+}
+
+
if (require.main === module) {
main()
}