From 221f86f77fc01e9c02c5c80ac8eb35222c036506 Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Thu, 28 Mar 2024 15:39:59 +0100 Subject: MUC: Fix legacy hats (thanks nicoco) Why do we not have tests for this? --- plugins/muc/hats.lib.lua | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/plugins/muc/hats.lib.lua b/plugins/muc/hats.lib.lua index 47667d7b..492dc72c 100644 --- a/plugins/muc/hats.lib.lua +++ b/plugins/muc/hats.lib.lua @@ -16,20 +16,26 @@ module:hook("muc-build-occupant-presence", function (event) local hats = aff_data and aff_data.hats; if not hats then return; end local hats_el; + local legacy_hats_el; for hat_id, hat_data in pairs(hats) do if hat_data.active then if not hats_el then 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 }); + legacy_hats_el = st.stanza("hats", { xmlns = xmlns_hats_legacy }); end - hats_el:tag("hat", { uri = hat_id, title = hat_data.title }):up(); + legacy_hats_el:tag("hat", { uri = hat_id, title = hat_data.title }):up(); end end end if not hats_el then return; end event.stanza:add_direct_child(hats_el); + + if legacy_hats_el then + event.stanza:add_direct_child(legacy_hats_el); + end end); -- cgit v1.2.3