aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--doc/doap.xml4
-rw-r--r--plugins/muc/hats.lib.lua11
2 files changed, 12 insertions, 3 deletions
diff --git a/doc/doap.xml b/doc/doap.xml
index c5501be2..62e4063c 100644
--- a/doc/doap.xml
+++ b/doc/doap.xml
@@ -699,8 +699,8 @@
<implements>
<xmpp:SupportedXep>
<xmpp:xep rdf:resource="https://xmpp.org/extensions/xep-0317.html"/>
- <xmpp:version>0.1</xmpp:version>
- <xmpp:status>planned</xmpp:status>
+ <xmpp:version>0.2.0</xmpp:version>
+ <xmpp:status>complete</xmpp:status>
<xmpp:since>0.12.0</xmpp:since>
<xmpp:note>muc/hats</xmpp:note>
</xmpp:SupportedXep>
diff --git a/plugins/muc/hats.lib.lua b/plugins/muc/hats.lib.lua
index e1587974..47667d7b 100644
--- a/plugins/muc/hats.lib.lua
+++ b/plugins/muc/hats.lib.lua
@@ -1,7 +1,10 @@
local st = require "prosody.util.stanza";
local muc_util = module:require "muc/util";
-local xmlns_hats = "xmpp:prosody.im/protocol/hats:1";
+local hats_compat = module:get_option_boolean("muc_hats_compat", true); -- COMPAT for pre-XEP namespace, TODO reconsider default for next release
+
+local xmlns_hats_legacy = "xmpp:prosody.im/protocol/hats:1";
+local xmlns_hats = "urn:xmpp:hats:0";
-- Strip any hats claimed by the client (to prevent spoofing)
muc_util.add_filtered_namespace(xmlns_hats);
@@ -19,6 +22,12 @@ module:hook("muc-build-occupant-presence", function (event)
hats_el = st.stanza("hats", { xmlns = xmlns_hats });
end
hats_el:tag("hat", { uri = hat_id, title = hat_data.title }):up();
+ if hats_compat then
+ if not hats_el then
+ hats_el = st.stanza("hats", { xmlns = xmlns_hats_legacy });
+ end
+ hats_el:tag("hat", { uri = hat_id, title = hat_data.title }):up();
+ end
end
end
if not hats_el then return; end