Allow IRC to listen on multiple channels from one or multiple nodes...

Issue #362
pull/347/merge
Dave C-J 2014-08-29 16:41:15 +01:00
parent 44ec551ed9
commit 0a3c889cc6
2 changed files with 63 additions and 43 deletions

View File

@ -27,12 +27,16 @@
<label for="node-input-name"><i class="fa fa-tag"></i> Name</label> <label for="node-input-name"><i class="fa fa-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name"> <input type="text" id="node-input-name" placeholder="Name">
</div> </div>
<div class="form-tips">The channel to join must start with a # (as per normal irc rules...)</div> <div class="form-tips">The channel to join must start with a # (as per normal irc rules...)<br/>
You may join multiple channels by comma separating a list - #chan1,#chan2,etc.</div>
</script> </script>
<script type="text/x-red" data-help-name="irc in"> <script type="text/x-red" data-help-name="irc in">
<p>Connects to a channel on an IRC server</p> <p>Connects to a channel on an IRC server.</p>
<p>Any messages on that channel will appear on the <code>msg.payload</code> at the output, while <code>msg.topic</code> will contain who it is from.</p> <p>You may join multiple channels by comma separating a list - #chan1,#chan2,#etc.</p>
<p>Any messages on that channel will appear on the <code>msg.payload</code> at the output,
while <code>msg.topic</code> will contain who it is from.
<code>msg.to</code> contains either the name of the channel or PRIV in the case of a pm.</p>
<p>The second output provides a <code>msg.payload</code> that has any status messages such as joins, parts, kicks etc.</p> <p>The second output provides a <code>msg.payload</code> that has any status messages such as joins, parts, kicks etc.</p>
<p>The type of the status message is set as <code>msg.payload.type</code>.</p> <p>The type of the status message is set as <code>msg.payload.type</code>.</p>
<p>The possible status types are: <br /> <p>The possible status types are: <br />

View File

@ -17,7 +17,6 @@
module.exports = function(RED) { module.exports = function(RED) {
"use strict"; "use strict";
var irc = require("irc"); var irc = require("irc");
var util = require("util");
// The Server Definition - this opens (and closes) the connection // The Server Definition - this opens (and closes) the connection
function IRCServerNode(n) { function IRCServerNode(n) {
@ -41,53 +40,61 @@ module.exports = function(RED) {
this.ircserver = n.ircserver; this.ircserver = n.ircserver;
this.serverConfig = RED.nodes.getNode(this.ircserver); this.serverConfig = RED.nodes.getNode(this.ircserver);
this.channel = n.channel || this.serverConfig.channel; this.channel = n.channel || this.serverConfig.channel;
if (this.serverConfig.ircclient == null) { var node = this;
this.serverConfig.ircclient = new irc.Client(this.serverConfig.server, this.serverConfig.nickname, { if (node.serverConfig.ircclient == null) {
channels: [this.channel] node.log("Connecting to "+node.serverConfig.server);
}); node.serverConfig.ircclient = new irc.Client(node.serverConfig.server, node.serverConfig.nickname);
this.serverConfig.ircclient.addListener('error', function(message) { node.serverConfig.ircclient.addListener('error', function(message) {
util.log('[irc] '+ JSON.stringify(message)); node.log(JSON.stringify(message));
}); });
} }
this.ircclient = this.serverConfig.ircclient; node.ircclient = node.serverConfig.ircclient;
var node = this;
this.ircclient.addListener('message', function (from, to, message) {
//util.log(from + ' => ' + to + ': ' + message); node.ircclient.addListener('registered', function(message) {
node.log(node.ircclient.nick+" ONLINE");
node.ircclient.join( node.channel, function(data) {
// node.log(data+" JOINED "+node.channel);
});
});
node.ircclient.addListener('message', function (from, to, message) {
//node.log(from + ' => ' + to + ' : ' + message);
if (node.channel.indexOf(to) > -1) {
var msg = { "topic":from, "from":from, "to":to, "payload":message }; var msg = { "topic":from, "from":from, "to":to, "payload":message };
node.send([msg,null]); node.send([msg,null]);
}
}); });
this.ircclient.addListener('pm', function(from, message) { node.ircclient.addListener('pm', function(from, message) {
//node.log("PM => "+from + ': ' + message);
var msg = { "topic":from, "from":from, "to":"PRIV", "payload":message }; var msg = { "topic":from, "from":from, "to":"PRIV", "payload":message };
node.send([msg,null]); node.send([msg,null]);
}); });
node.ircclient.addListener('join', function(channel, who) {
this.ircclient.addListener('join', function(channel, who) {
var msg = { "payload": { "type":"join", "who":who, "channel":channel } }; var msg = { "payload": { "type":"join", "who":who, "channel":channel } };
node.send([null,msg]); node.send([null,msg]);
node.log(who+' has joined '+channel); node.log(who+' has joined '+channel);
}); });
this.ircclient.addListener('invite', function(channel, from, message) { node.ircclient.addListener('invite', function(channel, from, message) {
var msg = { "payload": { "type":"invite", "who":from, "channel":channel, "message":message } }; var msg = { "payload": { "type":"invite", "who":from, "channel":channel, "message":message } };
node.send([null,msg]); node.send([null,msg]);
node.log(from+' sent invite to '+channel+': '+message); node.log(from+' sent invite to '+channel+': '+message);
}); });
this.ircclient.addListener('part', function(channel, who, reason) { node.ircclient.addListener('part', function(channel, who, reason) {
var msg = { "payload": { "type":"part", "who":who, "channel":channel, "reason":reason } }; var msg = { "payload": { "type":"part", "who":who, "channel":channel, "reason":reason } };
node.send([null,msg]); node.send([null,msg]);
node.log(who+' has left '+channel+': '+reason); node.log(who+' has left '+channel+': '+reason);
}); });
this.ircclient.addListener('quit', function(nick, reason, channels, message) { node.ircclient.addListener('quit', function(nick, reason, channels, message) {
var msg = { "payload": { "type":"quit", "who":nick, "channel":channels, "reason":reason } }; var msg = { "payload": { "type":"quit", "who":nick, "channel":channels, "reason":reason } };
node.send([null,msg]); node.send([null,msg]);
node.log(nick+' has quit '+channels+': '+reason); node.log(nick+' has quit '+channels+': '+reason);
}); });
this.ircclient.addListener('kick', function(channel, who, by, reason) { node.ircclient.addListener('kick', function(channel, who, by, reason) {
var msg = { "payload": { "type":"kick", "who":who, "channel":channel, "by":by, "reason":reason } }; var msg = { "payload": { "type":"kick", "who":who, "channel":channel, "by":by, "reason":reason } };
node.send([null,msg]); node.send([null,msg]);
node.log(who+' was kicked from '+channel+' by '+by+': '+reason); node.log(who+' was kicked from '+channel+' by '+by+': '+reason);
}); });
this.ircclient.addListener('names', function (channel, nicks) { node.ircclient.addListener('names', function (channel, nicks) {
var msg = { "payload": { "type": "names", "channel": channel, "names": nicks} }; var msg = { "payload": { "type": "names", "channel": channel, "names": nicks} };
node.send([null, msg]); node.send([null, msg]);
}); });
@ -103,43 +110,52 @@ module.exports = function(RED) {
this.ircserver = n.ircserver; this.ircserver = n.ircserver;
this.serverConfig = RED.nodes.getNode(this.ircserver); this.serverConfig = RED.nodes.getNode(this.ircserver);
this.channel = n.channel || this.serverConfig.channel; this.channel = n.channel || this.serverConfig.channel;
if (this.serverConfig.ircclient == null) { var node = this;
this.serverConfig.ircclient = new irc.Client(this.serverConfig.server, this.serverConfig.nickname, { if (node.serverConfig.ircclient == null) {
channels: [this.channel] node.log("Connecting to "+node.serverConfig.server);
}); node.serverConfig.ircclient = new irc.Client(node.serverConfig.server, node.serverConfig.nickname);
this.serverConfig.ircclient.addListener('error', function(message) { node.serverConfig.ircclient.addListener('error', function(message) {
util.log('[irc] '+ JSON.stringify(message)); node.log(JSON.stringify(message));
}); });
} }
this.ircclient = this.serverConfig.ircclient; node.ircclient = node.serverConfig.ircclient;
var node = this;
this.on("input", function(msg) { node.ircclient.addListener('registered', function(message) {
node.log(node.ircclient.nick+" ONLINE");
node.ircclient.join( node.channel, function(data) {
//node.log(data+" JOINED "+node.channel);
});
});
node.on("input", function(msg) {
if (Object.prototype.toString.call( msg.raw ) === '[object Array]') { if (Object.prototype.toString.call( msg.raw ) === '[object Array]') {
var m = msg.raw; var m = msg.raw;
for (var i = 0; i < 10; i++) { for (var i = 0; i < 10; i++) {
if (typeof m[i] !== "string") { m[i] = ""; } if (typeof m[i] !== "string") { m[i] = ""; }
m[i] = m[i].replace(/"/g, ""); m[i] = m[i].replace(/"/g, "");
} }
util.log("[irc] RAW command:"+m); node.log("RAW command:"+m);
node.ircclient.send(m[0],m[1],m[2],m[3],m[4],m[5],m[6],m[7],m[8],m[9]); node.ircclient.send(m[0],m[1],m[2],m[3],m[4],m[5],m[6],m[7],m[8],m[9]);
} }
else { else {
if (msg._topic) { delete msg._topic; } if (msg._topic) { delete msg._topic; }
var ch = node.channel.split(",");
for (var c=0; c<ch.length; c++) {
if (node.sendAll == "false") { if (node.sendAll == "false") {
node.ircclient.say(node.channel, JSON.stringify(msg)); node.ircclient.say(ch[c], JSON.stringify(msg));
} }
else { else {
if (typeof msg.payload === "object") { msg.payload = JSON.stringify(msg.payload); } if (typeof msg.payload === "object") { msg.payload = JSON.stringify(msg.payload); }
if (node.sendAll == "pay") { if (node.sendAll == "pay") {
node.ircclient.say(node.channel, msg.payload); node.ircclient.say(ch[c], msg.payload);
} }
else { else {
var to = msg.topic || node.channel; var to = msg.topic || ch[c];
node.ircclient.say(to, msg.payload); node.ircclient.say(to, msg.payload);
} }
} }
} }
}
}); });
} }
RED.nodes.registerType("irc out",IrcOutNode); RED.nodes.registerType("irc out",IrcOutNode);