aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2019-11-23 17:15:34 +0100
committerKim Alvefur <zash@zash.se>2019-11-23 17:15:34 +0100
commit33e92de38717fce322d4c2a6ddd8b5c7be0b1c46 (patch)
tree15c6672d54e5c891e59b941a1eb1f41b6c927adb /plugins
parent0e3cb510adbc4d6f09360e6929c0146b7a5b4378 (diff)
downloadprosody-33e92de38717fce322d4c2a6ddd8b5c7be0b1c46.tar.gz
prosody-33e92de38717fce322d4c2a6ddd8b5c7be0b1c46.zip
mod_csi: Cache CSI module availability to improve readabilty
Diffstat (limited to 'plugins')
-rw-r--r--plugins/mod_csi.lua5
1 files changed, 4 insertions, 1 deletions
diff --git a/plugins/mod_csi.lua b/plugins/mod_csi.lua
index e84ee032..458ff491 100644
--- a/plugins/mod_csi.lua
+++ b/plugins/mod_csi.lua
@@ -2,8 +2,9 @@ local st = require "util.stanza";
local xmlns_csi = "urn:xmpp:csi:0";
local csi_feature = st.stanza("csi", { xmlns = xmlns_csi });
+local csi_handler_available = nil;
module:hook("stream-features", function (event)
- if event.origin.username and prosody.hosts[module.host].events._handlers["csi-client-active"] then
+ if event.origin.username and csi_handler_available then
event.features:add_child(csi_feature);
end
end);
@@ -23,8 +24,10 @@ module:hook("stanza/"..xmlns_csi..":inactive", refire_event("csi-client-inactive
function module.load()
if prosody.hosts[module.host].events._handlers["csi-client-active"] then
+ csi_handler_available = true;
module:set_status("core", "CSI handler module loaded");
else
+ csi_handler_available = false;
module:set_status("warn", "No CSI handler module loaded");
end
end