From 1c34e39d8a8f0fed6563e72f94fea119f4743e33 Mon Sep 17 00:00:00 2001 From: Andreas Martens Date: Tue, 2 Feb 2021 16:55:55 +0000 Subject: [PATCH] XMPP: improve debugging and error handling (#753) --- social/xmpp/92-xmpp.js | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/social/xmpp/92-xmpp.js b/social/xmpp/92-xmpp.js index c324d8d7..4ba648ed 100644 --- a/social/xmpp/92-xmpp.js +++ b/social/xmpp/92-xmpp.js @@ -115,10 +115,14 @@ module.exports = function(RED) { text = textObj.getText(); } } - if (RED.settings.verbose || LOGITALL) {that.log("Culprit: "+that.lastUsed); } + if (RED.settings.verbose || LOGITALL) {that.log("Culprit: "+that.lastUsed.id); } if ("undefined" !== typeof that.lastUsed) { that.lastUsed.status({fill:"red",shape:"ring",text:text}); that.lastUsed.warn(text); + if (that.lastUsed.join) { + // it was trying to MUC things up + clearMUC(that); + } } if (RED.settings.verbose || LOGITALL) { that.log("We did wrong: "+text); @@ -237,6 +241,13 @@ module.exports = function(RED) { } } + function clearMUC(config) { + //something has happened, so clear out our presence indicators + if (RED.settings.verbose || LOGITALL) { + config.log("cleared all MUC membership"); + } + config.MUCs = {}; + } // separated out since we want the same functionality from both in and out nodes function errorHandler(node, err){ if (!node.quiet) { @@ -250,8 +261,9 @@ module.exports = function(RED) { } // The error might be a string else if (err == "TimeoutError") { - // OK, this happens with OpenFire, suppress it. - node.status({fill:"grey",shape:"dot",text:"opening"}); + // OK, this happens with OpenFire, suppress it, but invalidate MUC membership as it will need to be re-established. + clearMUC(node.serverConfig); + node.status({fill:"grey",shape:"dot",text:"TimeoutError"}); node.log("Timed out! ",err); // node.status({fill:"red",shape:"ring",text:"XMPP timeout"}); } @@ -271,7 +283,7 @@ module.exports = function(RED) { node.status({fill:"red",shape:"ring",text:"timeout"}); } else if (err.errno === "ENOTFOUND") { - node.error("Server doesn't exist "+xmpp.options.service,err); + node.error("Server doesn't exist "+node.serverConfig.server,err); node.status({fill:"red",shape:"ring",text:"bad address"}); } // nothing we've seen before!