Software /
code /
prosody-modules
File
mod_tcpproxy/web/xmpp.io.js @ 6112:4c0e3fe57e92
mod_compliance_latest: Gracefull error logging on missing dependency.
diff --git a/mod_compliance_latest/README.md b/mod_compliance_latest/README.md
--- a/mod_compliance_latest/README.md
+++ b/mod_compliance_latest/README.md
@@ -9,13 +9,15 @@ rockspec:
# Introduction
-This module will always require and load to the lastest compliance tester we have in the community modules.
-Currently this is [mod_compliance_2023].
+This meta-module will always `require` (and therefore auto-load) the lastest compliance tester we have in the community modules.
+Currently this is [mod_compliance_2023]. See the linked module for further details.
+
+If you do not use the *Prosody plugin installer* this module will likely have limited value to you.
+You can also just install the current compliance tester manually.
# Configuration
-Just load this module as any other module and it will automatically install [mod_compliance_2023] if you use the Prosody plugin installer.
-See the linked module for further details.
+Just load this module as any other module and it will automatically install and load [mod_compliance_2023] if you use the *Prosody plugin installer*.
# Compatibility
diff --git a/mod_compliance_latest/mod_compliance_latest.lua b/mod_compliance_latest/mod_compliance_latest.lua
--- a/mod_compliance_latest/mod_compliance_latest.lua
+++ b/mod_compliance_latest/mod_compliance_latest.lua
@@ -1,1 +1,6 @@
-module:depends("compliance_2023");
+local success, err = pcall(function() module:depends("compliance_2023") end)
+
+if not success then
+ module:log("error", "Error, can't load module: mod_compliance_2023. Is this module downloaded in a folder readable by prosody?")
+ return 1, "Error: Couldn't load dependency mod_compliance_2023."
+end
author | Menel <menel@snikket.de> |
---|---|
date | Mon, 23 Dec 2024 12:58:03 +0100 |
parent | 1343:7dbde05b48a9 |
line wrap: on
line source
var xmlns_ibb = "http://jabber.org/protocol/ibb"; var xmlns_tcp = "http://prosody.im/protocol/tcpproxy"; function XMPPIO(xmppconn, xmpptcp_host) { this.xmppconn = xmppconn; this.xmpphost = xmpptcp_host; this.sid = "FIXME"; this.listeners = []; return this; } XMPPIO.prototype = { connect: function (host, port) { var conn = this; console.log("Connecting..."); function onConnect() { this.xmppconn.addHandler(function (stanza) { var data = stanza.getElementsByTagName("data")[0]; if(data) conn.emit("data", Strophe.Base64.decode(Strophe.getText(data))); }, null, "message", null, null, this.xmpphost, {}); this.xmppconn.addHandler(function (stanza) { var data = stanza.getElementsByTagName("close")[0]; if(close) { conn.write = function () { throw "Connection closed"; }; conn.emit("end"); } }, xmlns_ibb, "iq", "set", null, this.xmpphost, {}); conn.emit("connect"); } this.xmppconn.sendIQ($iq({to:this.xmpphost,type:"set"}) .c("open", { "xmlns": xmlns_ibb, "xmlns:tcp": xmlns_tcp, "tcp:host": host, "tcp:port": port.toString(), "block-size": "4096", "sid": this.sid.toString(), "stanza": "message" }), onConnect, function () { conn.emit("error"); }); }, emit: function () { console.log("xmpp.io: Emitting "+arguments[0]); var args = Array.prototype.slice.call(arguments, 1); var listeners = this.listeners[arguments[0]]; if(listeners) { for(var i=0;i<listeners.length;i++) { listeners[i][1].apply(listeners[i][0], args); } } }, addListener: function (event, method, obj) { if(typeof(obj)=="undefined") obj = this; if(!(event in this.listeners)) this.listeners[event] = []; this.listeners[event].push([obj, method]); }, write: function (data) { return this.xmppconn.send($msg({to:this.xmpphost}) .c("data", {xmlns:xmlns_ibb, sid:this.sid.toString()}) .t(Strophe.Base64.encode(data))); }, end: function () { return this.xmppconn.send($iq({to:this.xmpphost}) .c("close", {xmlns:xmlns_ibb, sid:this.sid.toString()})); } };