1
0
mirror of https://github.com/node-red/node-red-nodes.git synced 2023-10-10 13:36:58 +02:00

XMPP: ability to dynamically join chat rooms (#752)

* join a MUC if we're already connected to server and refactor error handling

* ability to dynamically join a MUC when provided as msg.topic
This commit is contained in:
Andreas Martens 2021-02-02 09:14:11 +00:00 committed by GitHub
parent 77fac03319
commit 886158485b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -50,6 +50,8 @@ module.exports = function(RED) {
this.connected = false; this.connected = false;
// store the nodes that have us as config so we know when to tear it all down. // store the nodes that have us as config so we know when to tear it all down.
this.users = {}; this.users = {};
// Store the chatrooms (MUC) that we've joined (sent "presence" XML to) already
this.MUCs = {};
// helper variable, because "this" changes definition inside a callback // helper variable, because "this" changes definition inside a callback
var that = this; var that = this;
@ -216,14 +218,23 @@ module.exports = function(RED) {
// if we want to support passwords, we need to add that as a child of the x element // if we want to support passwords, we need to add that as a child of the x element
// (third argument to the x/muc/children ) // (third argument to the x/muc/children )
// We also turn off chat history (maxstanzas 0) because that's not what this node is about. // We also turn off chat history (maxstanzas 0) because that's not what this node is about.
// Yes, there's a race condition, but it's not a huge problem to send two messages
// so we don't care.
if (name in node.serverConfig.MUCs) {
if (RED.settings.verbose || LOGITALL) {
node.log("already joined MUC "+name);
}
}
else {
var stanza = xml('presence', var stanza = xml('presence',
{"to": name}, {"to": name},
xml("x",'http://jabber.org/protocol/muc'), xml("x",'http://jabber.org/protocol/muc'),
{ maxstanzas:0, seconds:1 } { maxstanzas:0, seconds:1 }
); );
node.serverConfig.used(node); node.serverConfig.used(node);
node.serverConfig.MUCs[name] = "joined";
xmpp.send(stanza); xmpp.send(stanza);
}
} }
// separated out since we want the same functionality from both in and out nodes // separated out since we want the same functionality from both in and out nodes
@ -579,7 +590,13 @@ module.exports = function(RED) {
var to = node.to || msg.topic || ""; var to = node.to || msg.topic || "";
if (to !== "") { if (to !== "") {
var message; var message;
var type = node.join? "groupchat":"chat"; var type = "chat";
if (node.join) {
// we want to connect to groupchat / chatroom / MUC
type = "groupchat";
// joinMUC will do nothing if we're already joined
joinMUC(node, xmpp, to+'/'+node.nick);
}
if (node.sendAll) { if (node.sendAll) {
message = xml( message = xml(
"message", "message",