diff options
-rw-r--r-- | src/xmpp/biboumi_component.cpp | 6 | ||||
-rw-r--r-- | tests/end_to_end/scenarios/stable_id.py | 14 |
2 files changed, 13 insertions, 7 deletions
diff --git a/src/xmpp/biboumi_component.cpp b/src/xmpp/biboumi_component.cpp index f2e3753..6fda98f 100644 --- a/src/xmpp/biboumi_component.cpp +++ b/src/xmpp/biboumi_component.cpp @@ -294,15 +294,15 @@ void BiboumiComponent::handle_message(const Stanza& stanza) if (origin_id) nodes_to_reflect.push_back(*origin_id); const auto own_address = std::to_string(iid) + '@' + this->served_hostname; - for (const XmlNode* stable_id: stanza.get_children("stable-id", STABLE_ID_NS)) + for (const XmlNode* stanza_id: stanza.get_children("stanza-id", STABLE_ID_NS)) { // Stanza ID generating entities, which encounter a // <stanza-id/> element where the 'by' attribute matches // the 'by' attribute they would otherwise set, MUST // delete that element even if they are not adding their // own stanza ID. - if (stable_id->get_tag("by") != own_address) - nodes_to_reflect.push_back(*stable_id); + if (stanza_id->get_tag("by") != own_address) + nodes_to_reflect.push_back(*stanza_id); } bridge->send_channel_message(iid, body->get_inner(), id, std::move(nodes_to_reflect)); } diff --git a/tests/end_to_end/scenarios/stable_id.py b/tests/end_to_end/scenarios/stable_id.py index 90b5866..9f3181b 100644 --- a/tests/end_to_end/scenarios/stable_id.py +++ b/tests/end_to_end/scenarios/stable_id.py @@ -8,19 +8,25 @@ scenario = ( scenarios.simple_channel_join.scenario, send_stanza("""<message id='first_id' from='{jid_one}/{resource_one}' to='#foo%{irc_server_one}' type='groupchat'> - <origin-id xmlns='urn:xmpp:sid:0' id='client-origin-id'/> - <stanza-id xmlns='urn:xmpp:sid:0' id='client-stanza-id'/> + <origin-id xmlns='urn:xmpp:sid:0' id='client-origin-id-should-be-kept'/> + <stanza-id xmlns='urn:xmpp:sid:0' id='client-stanza-id-should-be-removed' by='#foo%{irc_server_one}'/> + <stanza-id xmlns='urn:xmpp:sid:0' id='client-stanza-id-should-be-kept' by='someother@jid'/> <body>coucou</body></message>"""), # Entities, which are routing stanzas, SHOULD NOT strip any elements # qualified by the 'urn:xmpp:sid:0' namespace from message stanzas # unless the preceding rule applied to those elements. - expect_stanza("/message/stable_id:origin-id[@id='client-origin-id']", + expect_stanza("/message/stable_id:origin-id[@id='client-origin-id-should-be-kept']", # Stanza ID generating entities, which encounter a <stanza-id/> # element where the 'by' attribute matches the 'by' attribute they # would otherwise set, MUST delete that element even if they are not # adding their own stanza ID. "/message/stable_id:stanza-id[@id][@by='#foo%{irc_server_one}']", - "!/message/stable_id:stanza-id[@id='client-stanza-id']", + "!/message/stable_id:stanza-id[@id='client-stanza-id-should-be-removed']", + # Entities, which are routing stanzas, SHOULD NOT strip + # any elements qualified by the 'urn:xmpp:sid:0' + # namespace from message stanzas unless the preceding + # rule applied to those elements. + "/message/stable_id:stanza-id[@id='client-stanza-id-should-be-kept'][@by='someother@jid']", ), ) |