Archive results for private messages are incomplete

Testing with openfire 4.8.3 and Monitoring plugin 3.6.1

Assume two users A and B. A and B have joined the same anonymous room. They have both sent each other 2 private messages in the room. They have also opened a private chat and send each other 2 direct private messages.

When user A sends a query to his own archive (to:A) and specifies a with critirium for B (with=B), the plugin returns 6 messages: 4 private and two whispers, the private messages sent by B as room participant. In fact those are the two messages which user A should not be allowed to know that they were send by B, because they were send by the B room alias.

It does not matter if the room was not anonymous, the result is always 6 messages, so either their are 2 message to many or 2 are missing (the private messages A has sent to B in the Room)

I had a look in the code, but this only added to the confusement.

Hi Anno,

Thanks for reporting this. Please bear with me as I’m trying to reproduce with a copious amount of examples.

I have tried to reproduce the issue(s) using this snippet of Smack code executed against Openfire in demoboot. I suspect that behavior is pretty consistent across versions, but I’ve used Smack 4.5.0-beta5, Openfire 5.0.0-SNAPSHOT and Monitoring 2.7.0-SNAPSHOT (things that I happened to have installed).

The Smack code that I had was this:

import org.jivesoftware.smack.ConnectionConfiguration;
import org.jivesoftware.smack.SmackConfiguration;
import org.jivesoftware.smack.packet.MessageBuilder;
import org.jivesoftware.smack.tcp.XMPPTCPConnection;
import org.jivesoftware.smack.tcp.XMPPTCPConnectionConfiguration;
import org.jivesoftware.smackx.mam.MamManager;
import org.jivesoftware.smackx.muc.MultiUserChat;
import org.jivesoftware.smackx.muc.MultiUserChatManager;
import org.jxmpp.jid.impl.JidCreate;
import org.jxmpp.jid.parts.Resourcepart;

public class TestClientMam
{
    public static void main(String[] args) throws Exception {

        SmackConfiguration.setDefaultReplyTimeout(5000);
        SmackConfiguration.DEBUG = true;

        final XMPPTCPConnection connJane = new XMPPTCPConnection(
                XMPPTCPConnectionConfiguration.builder()
                    .setUsernameAndPassword("jane", "secret")
                    .setXmppDomain("example.org")
                    .setHost("localhost")
                    .setResource("test")
                    .setPort(5222)
                    .addEnabledSaslMechanism("PLAIN")
                    .setSecurityMode(ConnectionConfiguration.SecurityMode.disabled)
                    .build());

        final XMPPTCPConnection connJohn = new XMPPTCPConnection(
            XMPPTCPConnectionConfiguration.builder()
                .setUsernameAndPassword("john", "secret")
                .setXmppDomain("example.org")
                .setHost("localhost")
                .setResource("test")
                .setPort(5222)
                .addEnabledSaslMechanism("PLAIN")
                .setSecurityMode(ConnectionConfiguration.SecurityMode.disabled)
                .build());

        // Reduce XMPP data in debug output.
        connJane.setUseStreamManagement(false);
        connJane.setUseStreamManagementResumption(false);

        connJane.connect();
        connJohn.connect();
        try {
            connJane.login();
            connJohn.login();

            final MultiUserChat mucJane = MultiUserChatManager.getInstanceFor(connJane).getMultiUserChat(JidCreate.entityBareFrom("test@conference.example.org"));
            mucJane.createOrJoin(Resourcepart.from("Jill")).makeInstant();
            final MultiUserChat mucJohn = MultiUserChatManager.getInstanceFor(connJohn).getMultiUserChat(JidCreate.entityBareFrom("test@conference.example.org"));
            mucJohn.createOrJoin(Resourcepart.from("Jack"));

            connJane.sendStanza(MessageBuilder.buildMessage().to(connJohn.getUser()).setBody("Direct message from Jane to John").build());
            connJohn.sendStanza(MessageBuilder.buildMessage().to(connJane.getUser()).setBody("Direct message from John to Jane").build());
            mucJane.sendMessage("MUC message (public) from Jane");
            mucJohn.sendMessage("MUC message (public) from John");
            mucJane.createPrivateChat(JidCreate.entityFullFrom("test@conference.example.org/Jack"), null).sendMessage("MUC message (private) from Jane (as Jill) to John (as Jack).");
            mucJohn.createPrivateChat(JidCreate.entityFullFrom("test@conference.example.org/Jill"), null).sendMessage("MUC message (private) from John (as Jack) to Jane (as Jill).");

            Thread.sleep(250);

            final MamManager janeMamManager = MamManager.getInstanceFor(connJane);
            janeMamManager.getMamNamespace();

            janeMamManager.queryArchive(MamManager.MamQueryArgs.builder().build()).getMessages();

            Thread.sleep(250);

            janeMamManager.queryArchive(MamManager.MamQueryArgs.builder().limitResultsToJid(JidCreate.bareFrom("john@example.org")).build()).getMessages();

            Thread.sleep(250);

        } finally {
            connJane.disconnect();
            connJohn.disconnect();
        }
    }
}

This generates XMPP stanzas that query both the entire personal archive of Jane, as well as another query result that contains data from Jane’s personal archive, filtered for John.

The full XMPP dump for only Jane’s connection is included below.

21:35:53.7 SENT (0): 
<stream:stream xmlns='jabber:client' to='example.org' xmlns:stream='http://etherx.jabber.org/streams' version='1.0' from='jane@example.org' xml:lang='en-US'>
21:35:53.37 RECV (0): ?xml version="1.0" encoding="UTF-8"?>
<stream:stream xmlns:strea
21:35:53.39 RECV (0): m="http://etherx.jabber.org/streams" xmlns="jabber:client" from="example.org" id="6mg0nljbty" xml:lang="en-US" version="1.0">
<stream:features>
  <starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls"/>
  <limits xmlns="urn:xmpp:stream-limits:0">
    <max-bytes>
      1048576
    </max-bytes>
    <idle-seconds>
      360
    </idle-seconds>
  </limits>
  <mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
    <mechanism>
      PLAIN
    </mechanism>
    <mechanism>
      ANONYMOUS
    </mechanism>
    <mechanism>
      SCRAM-SHA-1
    </mechanism>
  </mechanisms>
  <compression xmlns="http://jabber.org/features/compress">
    <method>
      zlib
    </method>
  </compression>
  <ver xmlns="urn:xmpp:features:rosterver"/>
  <register xmlns="http://jabber.org/features/iq-register"/>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://www.igniterealtime.org/projects/openfire/" ver="Z7H9iDsIqFpMR74gN8KEj4qMbEI="/>
  <limits xmlns="urn:xmpp:stream-limits:0">
    <max-bytes>
      1048576
    </max-bytes>
    <idle-seconds>
      360
    </idle-seconds>
  </limits>
</stream:features>
21:35:53.58 SENT (0): 
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>
  AGphbmUAc2VjcmV0
</auth>
21:35:53.66 RECV (0): 
<success xmlns="urn:ietf:params:xml:ns:xmpp-sasl"/>
21:35:53.67 SENT (0): 
<stream:stream xmlns='jabber:client' to='example.org' xmlns:stream='http://etherx.jabber.org/streams' version='1.0' from='jane@example.org' id='6mg0nljbty' xml:lang='en-US'>
21:35:53.69 RECV (0): ?xml version="1.0" encoding="UTF-8"?>
<stream:stream xmlns:strea
21:35:53.69 RECV (0): m="http://etherx.jabber.org/streams" xmlns="jabber:client" from="example.org" id="6mg0nljbty" xml:lang="en-US" version="1.0">
<stream:features>
  <compression xmlns="http://jabber.org/features/compress">
    <method>
      zlib
    </method>
  </compression>
  <ver xmlns="urn:xmpp:features:rosterver"/>
  <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"/>
  <session xmlns="urn:ietf:params:xml:ns:xmpp-session">
    <optional/>
  </session>
  <sm xmlns="urn:xmpp:sm:2"/>
  <sm xmlns="urn:xmpp:sm:3"/>
  <csi xmlns="urn:xmpp:csi:0"/>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://www.igniterealtime.org/projects/openfire/" ver="HBR8KOqrNej/mdMlrM545mXs4Ks="/>
  <limits xmlns="urn:xmpp:stream-limits:0">
    <max-bytes>
      1048576
    </max-bytes>
    <idle-seconds>
      360
    </idle-seconds>
  </limits>
</stream:features>
21:35:53.72 SENT (0): 
<iq id='6RTF3-1' type='set'>
  <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
    <resource>
      test
    </resource>
  </bind>
</iq>
21:35:53.75 RECV (0): 
<iq type="result" id="6RTF3-1" to="example.org/50327d50-0f57-4116-9bbd-130fa1bac52c">
  <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind">
    <jid>
      jane@example.org/test
    </jid>
  </bind>
</iq>
21:35:53.90 User logged (0): jane@example.org:5222/test
21:35:53.92 SENT (0): 
<iq id='6RTF3-3' type='get'>
  <query xmlns='jabber:iq:roster'>
  </query>
</iq>
21:35:53.94 SENT (0): 
<iq to='example.org' id='STX8I-1' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info' node='https://www.igniterealtime.org/projects/openfire/#HBR8KOqrNej/mdMlrM545mXs4Ks='>
  </query>
</iq>
21:35:53.98 RECV (0): 
<iq type="result" id="6RTF3-3" to="jane@example.org/test">
  <query xmlns="jabber:iq:roster" ver="-375080640">
    <item jid="john@example.org" name="John" subscription="both"/>
  </query>
</iq>
21:35:53.103 RECV (0): 
<iq type="result" id="STX8I-1" from="example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info" node="https://www.igniterealtime.org/projects/openfire/#HBR8KOqrNej/mdMlrM545mXs4Ks=">
    <identity category="server" name="Openfire Server" type="im"/>
    <identity category="pubsub" type="pep"/>
    <feature var="http://jabber.org/protocol/caps"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-default"/>
    <feature var="http://jabber.org/protocol/pubsub#purge-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#subscription-options"/>
    <feature var="http://jabber.org/protocol/pubsub#outcast-affiliation"/>
    <feature var="msgoffline"/>
    <feature var="jabber:iq:register"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#config-node"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-items"/>
    <feature var="http://jabber.org/protocol/pubsub#auto-create"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-items"/>
    <feature var="http://jabber.org/protocol/disco#items"/>
    <feature var="urn:xmpp:mam:0"/>
    <feature var="urn:xmpp:mam:1"/>
    <feature var="urn:xmpp:mam:2"/>
    <feature var="http://jabber.org/protocol/pubsub#persistent-items"/>
    <feature var="urn:xmpp:fulltext:0"/>
    <feature var="http://jabber.org/protocol/pubsub#create-and-configure"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-affiliations"/>
    <feature var="urn:xmpp:time"/>
    <feature var="http://jabber.org/protocol/pubsub#manage-subscriptions"/>
    <feature var="urn:xmpp:bookmarks-conversion:0"/>
    <feature var="http://jabber.org/protocol/offline"/>
    <feature var="http://jabber.org/protocol/pubsub#auto-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#publish-options"/>
    <feature var="urn:xmpp:carbons:2"/>
    <feature var="http://jabber.org/protocol/address"/>
    <feature var="http://jabber.org/protocol/pubsub#collections"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-subscriptions"/>
    <feature var="vcard-temp"/>
    <feature var="http://jabber.org/protocol/pubsub#subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#create-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#get-pending"/>
    <feature var="urn:xmpp:blocking"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#presence-notifications"/>
    <feature var="urn:xmpp:ping"/>
    <feature var="urn:xmpp:archive:manage"/>
    <feature var="http://jabber.org/protocol/pubsub#filtered-notifications"/>
    <feature var="http://jabber.org/protocol/pubsub#item-ids"/>
    <feature var="http://jabber.org/protocol/pubsub#meta-data"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-items"/>
    <feature var="jabber:iq:roster"/>
    <feature var="http://jabber.org/protocol/pubsub#instant-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#modify-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub"/>
    <feature var="http://jabber.org/protocol/pubsub#publisher-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#access-open"/>
    <feature var="jabber:iq:version"/>
    <feature var="http://jabber.org/protocol/pubsub#retract-items"/>
    <feature var="jabber:iq:privacy"/>
    <feature var="jabber:iq:last"/>
    <feature var="http://jabber.org/protocol/commands"/>
    <feature var="http://jabber.org/protocol/pubsub#publish"/>
    <feature var="urn:xmpp:archive:auto"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="jabber:iq:private"/>
    <feature var="http://jabber.org/protocol/rsm"/>
    <x xmlns="jabber:x:data" type="result">
      <field var="FORM_TYPE" type="hidden">
        <value>
          http://jabber.org/network/serverinfo
        </value>
      </field>
      <field var="admin-addresses" type="list-multi">
        <value>
          xmpp:admin@example.org
        </value>
        <value>
          mailto:admin@example.com
        </value>
      </field>
    </x>
    <x xmlns="jabber:x:data" type="result">
      <field var="FORM_TYPE" type="hidden">
        <value>
          urn:xmpp:dataforms:softwareinfo
        </value>
      </field>
      <field type="text-single" var="os">
        <value>
          Linux
        </value>
      </field>
      <field type="text-single" var="os_version">
        <value>
          6.8.0-56-generic amd64 - Java 21.0.6
        </value>
      </field>
      <field type="text-single" var="software">
        <value>
          Openfire
        </value>
      </field>
      <field type="text-single" var="software_version">
        <value>
          5.0.0 Alpha
        </value>
      </field>
    </x>
  </query>
</iq>
21:35:53.112 SENT (0): 
<iq to='example.org' id='6RTF3-5' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#items'>
  </query>
</iq>
21:35:53.115 RECV (0): 
<iq type="result" id="6RTF3-5" from="example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#items">
    <item jid="search.example.org" name="User Search"/>
    <item jid="conference.example.org" name="Public Chatrooms"/>
    <item jid="proxy.example.org" name="Socks 5 Bytestreams Proxy"/>
    <item jid="pubsub.example.org" name="Publish-Subscribe service"/>
  </query>
</iq>
21:35:53.116 SENT (0): 
<iq to='search.example.org' id='STX8I-2' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.118 RECV (0): 
<iq type="result" id="STX8I-2" from="search.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="directory" type="user" name="User Search"/>
    <feature var="jabber:iq:search"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="http://jabber.org/protocol/rsm"/>
  </query>
</iq>
21:35:53.118 SENT (0): 
<iq to='conference.example.org' id='STX8I-3' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.120 RECV (0): 
<iq type="result" id="STX8I-3" from="conference.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="conference" name="Public Chatrooms" type="text"/>
    <identity category="directory" name="Public Chatroom Search" type="chatroom"/>
    <feature var="http://jabber.org/protocol/muc"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="http://jabber.org/protocol/disco#items"/>
    <feature var="jabber:iq:search"/>
    <feature var="https://xmlns.zombofant.net/muclumbus/search/1.0"/>
    <feature var="http://jabber.org/protocol/rsm"/>
    <feature var="urn:xmpp:mam:0"/>
    <feature var="urn:xmpp:mam:1"/>
    <feature var="urn:xmpp:mam:2"/>
  </query>
</iq>
21:35:53.121 SENT (0): 
<iq to='proxy.example.org' id='STX8I-4' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.122 RECV (0): 
<iq type="result" id="STX8I-4" from="proxy.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="proxy" name="SOCKS5 Bytestreams Service" type="bytestreams"/>
    <feature var="http://jabber.org/protocol/bytestreams"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
  </query>
</iq>
21:35:53.123 SENT (0): 
<iq to='pubsub.example.org' id='STX8I-5' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.126 RECV (0): 
<iq type="result" id="STX8I-5" from="pubsub.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="pubsub" name="Publish-Subscribe service" type="service"/>
    <feature var="http://jabber.org/protocol/pubsub"/>
    <feature var="http://jabber.org/protocol/pubsub#access-open"/>
    <feature var="http://jabber.org/protocol/pubsub#collections"/>
    <feature var="http://jabber.org/protocol/pubsub#config-node"/>
    <feature var="http://jabber.org/protocol/pubsub#create-and-configure"/>
    <feature var="http://jabber.org/protocol/pubsub#create-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-items"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#get-pending"/>
    <feature var="http://jabber.org/protocol/pubsub#instant-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#item-ids"/>
    <feature var="http://jabber.org/protocol/pubsub#meta-data"/>
    <feature var="http://jabber.org/protocol/pubsub#modify-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#manage-subscriptions"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#outcast-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#persistent-items"/>
    <feature var="http://jabber.org/protocol/pubsub#presence-notifications"/>
    <feature var="http://jabber.org/protocol/pubsub#publish"/>
    <feature var="http://jabber.org/protocol/pubsub#publisher-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#purge-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#retract-items"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-default"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-items"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-subscriptions"/>
    <feature var="http://jabber.org/protocol/pubsub#subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#subscription-options"/>
    <feature var="http://jabber.org/protocol/pubsub#publish-options"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-items"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="urn:xmpp:bookmarks-conversion:0"/>
  </query>
</iq>
21:35:53.128 SENT (0): 
<iq to='example.org' id='6RTF3-7' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#items'>
  </query>
</iq>
21:35:53.130 RECV (0): 
<iq type="result" id="6RTF3-7" from="example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#items">
    <item jid="search.example.org" name="User Search"/>
    <item jid="conference.example.org" name="Public Chatrooms"/>
    <item jid="proxy.example.org" name="Socks 5 Bytestreams Proxy"/>
    <item jid="pubsub.example.org" name="Publish-Subscribe service"/>
  </query>
</iq>
21:35:53.130 SENT (0): 
<iq to='search.example.org' id='STX8I-6' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.132 RECV (0): 
<iq type="result" id="STX8I-6" from="search.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="directory" type="user" name="User Search"/>
    <feature var="jabber:iq:search"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="http://jabber.org/protocol/rsm"/>
  </query>
</iq>
21:35:53.133 SENT (0): 
<iq to='conference.example.org' id='STX8I-7' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.135 RECV (0): 
<iq type="result" id="STX8I-7" from="conference.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="conference" name="Public Chatrooms" type="text"/>
    <identity category="directory" name="Public Chatroom Search" type="chatroom"/>
    <feature var="http://jabber.org/protocol/muc"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="http://jabber.org/protocol/disco#items"/>
    <feature var="jabber:iq:search"/>
    <feature var="https://xmlns.zombofant.net/muclumbus/search/1.0"/>
    <feature var="http://jabber.org/protocol/rsm"/>
    <feature var="urn:xmpp:mam:0"/>
    <feature var="urn:xmpp:mam:1"/>
    <feature var="urn:xmpp:mam:2"/>
  </query>
</iq>
21:35:53.136 SENT (0): 
<iq to='proxy.example.org' id='STX8I-8' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.137 RECV (0): 
<iq type="result" id="STX8I-8" from="proxy.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="proxy" name="SOCKS5 Bytestreams Service" type="bytestreams"/>
    <feature var="http://jabber.org/protocol/bytestreams"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
  </query>
</iq>
21:35:53.138 SENT (0): 
<iq to='pubsub.example.org' id='STX8I-9' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.140 RECV (0): 
<iq type="result" id="STX8I-9" from="pubsub.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="pubsub" name="Publish-Subscribe service" type="service"/>
    <feature var="http://jabber.org/protocol/pubsub"/>
    <feature var="http://jabber.org/protocol/pubsub#access-open"/>
    <feature var="http://jabber.org/protocol/pubsub#collections"/>
    <feature var="http://jabber.org/protocol/pubsub#config-node"/>
    <feature var="http://jabber.org/protocol/pubsub#create-and-configure"/>
    <feature var="http://jabber.org/protocol/pubsub#create-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-items"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#get-pending"/>
    <feature var="http://jabber.org/protocol/pubsub#instant-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#item-ids"/>
    <feature var="http://jabber.org/protocol/pubsub#meta-data"/>
    <feature var="http://jabber.org/protocol/pubsub#modify-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#manage-subscriptions"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#outcast-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#persistent-items"/>
    <feature var="http://jabber.org/protocol/pubsub#presence-notifications"/>
    <feature var="http://jabber.org/protocol/pubsub#publish"/>
    <feature var="http://jabber.org/protocol/pubsub#publisher-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#purge-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#retract-items"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-default"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-items"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-subscriptions"/>
    <feature var="http://jabber.org/protocol/pubsub#subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#subscription-options"/>
    <feature var="http://jabber.org/protocol/pubsub#publish-options"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-items"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="urn:xmpp:bookmarks-conversion:0"/>
  </query>
</iq>
21:35:53.151 XMPPConnection authenticated (XMPPTCPConnection[jane@example.org/test] (0))
21:35:53.152 SENT (0): 
<presence id='STX8I-10'>
  <priority>
    0
  </priority>
  <c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://igniterealtime.org/projects/smack' ver='lWpWNgqtfynY+MxupmhOr2LZqOg='/>
</presence>
21:35:53.154 RECV (0): 
<iq type="get" id="363-8" to="jane@example.org/test" from="example.org">
  <query xmlns="http://jabber.org/protocol/disco#info"/>
</iq>
21:35:53.156 RECV (0): 
<presence id="STX8I-10" from="jane@example.org/test" to="jane@example.org/test">
  <priority>
    0
  </priority>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://igniterealtime.org/projects/smack" ver="lWpWNgqtfynY+MxupmhOr2LZqOg=">
  </c>
</presence>
21:35:53.157 SENT (0): 
<iq to='example.org' id='363-8' type='result'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
    <identity category='client' name='Smack' type='pc'/>
    <feature var='http://jabber.org/protocol/disco#items'/>
    <feature var='http://jabber.org/protocol/caps'/>
    <feature var='vcard-temp'/>
    <feature var='http://jabber.org/protocol/bytestreams'/>
    <feature var='http://jabber.org/protocol/xhtml-im'/>
    <feature var='jabber:x:data'/>
    <feature var='jabber:iq:version'/>
    <feature var='urn:xmpp:http'/>
    <feature var='urn:xmpp:time'/>
    <feature var='urn:xmpp:eme:0'/>
    <feature var='jabber:iq:privacy'/>
    <feature var='urn:xmpp:ping'/>
    <feature var='jabber:iq:last'/>
    <feature var='http://jabber.org/protocol/commands'/>
    <feature var='http://jabber.org/protocol/muc'/>
    <feature var='http://jabber.org/protocol/xdata-validate'/>
    <feature var='http://jabber.org/protocol/xdata-layout'/>
    <feature var='urn:xmpp:receipts'/>
    <feature var='http://jabber.org/protocol/disco#info'/>
  </query>
</iq>
21:35:53.261 SENT (0): 
<iq to='conference.example.org' id='STX8I-12' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.262 RECV (0): 
<presence id="6B6RN-9" from="john@example.org/test" to="jane@example.org">
  <priority>
    0
  </priority>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://igniterealtime.org/projects/smack" ver="lWpWNgqtfynY+MxupmhOr2LZqOg=">
  </c>
</presence>
21:35:53.264 RECV (0): 
<iq type="result" id="STX8I-12" from="conference.example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="conference" name="Public Chatrooms" type="text"/>
    <identity category="directory" name="Public Chatroom Search" type="chatroom"/>
    <feature var="http://jabber.org/protocol/muc"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="http://jabber.org/protocol/disco#items"/>
    <feature var="jabber:iq:search"/>
    <feature var="https://xmlns.zombofant.net/muclumbus/search/1.0"/>
    <feature var="http://jabber.org/protocol/rsm"/>
    <feature var="urn:xmpp:mam:0"/>
    <feature var="urn:xmpp:mam:1"/>
    <feature var="urn:xmpp:mam:2"/>
  </query>
</iq>
21:35:53.269 SENT (0): 
<presence to='test@conference.example.org/Jill' id='STX8I-11'>
  <priority>
    0
  </priority>
  <x xmlns='http://jabber.org/protocol/muc'>
  </x>
  <c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://igniterealtime.org/projects/smack' ver='lWpWNgqtfynY+MxupmhOr2LZqOg='/>
</presence>
21:35:53.287 RECV (0): 
<presence to="jane@example.org/test" id="STX8I-11" from="test@conference.example.org/Jill">
  <priority>
    0
  </priority>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://igniterealtime.org/projects/smack" ver="lWpWNgqtfynY+MxupmhOr2LZqOg=">
  </c>
  <occupant-id xmlns="urn:xmpp:occupant-id:0" id="997716be2f639961ef8ec032cfa82d0bc57d451d"/>
  <x xmlns="http://jabber.org/protocol/muc#user">
    <item jid="jane@example.org/test" affiliation="owner" role="moderator"/>
    <status code="110"/>
    <status code="100"/>
    <status code="170"/>
    <status code="201"/>
  </x>
</presence>
21:35:53.292 RECV (0): 
<message from="test@conference.example.org" type="groupchat" id="da8e8153-9a8b-4e30-9780-cac48b7b536a" to="jane@example.org/test">
  <subject/>
</message>
21:35:53.293 SENT (0): 
<iq to='test@conference.example.org' id='6RTF3-17' type='set'>
  <query xmlns='http://jabber.org/protocol/muc#owner'>
    <x xmlns='jabber:x:data' type='submit'>
    </x>
  </query>
</iq>
21:35:53.304 RECV (0): 
<iq type="result" id="6RTF3-17" from="test@conference.example.org" to="jane@example.org/test"/>
21:35:53.311 RECV (0): 
<presence to="jane@example.org/test" id="6B6RN-10" from="test@conference.example.org/Jack">
  <priority>
    0
  </priority>
  <c xmlns="http://jabber.org/protocol/caps" hash="sha-1" node="https://igniterealtime.org/projects/smack" ver="lWpWNgqtfynY+MxupmhOr2LZqOg=">
  </c>
  <occupant-id xmlns="urn:xmpp:occupant-id:0" id="f3993338053e990132fb8580aab1f86691b26f5f"/>
  <x xmlns="http://jabber.org/protocol/muc#user">
    <item jid="john@example.org/test" affiliation="none" role="participant"/>
  </x>
</presence>
21:35:53.314 SENT (0): 
<message to='john@example.org/test'>
  <body>
    Direct message from Jane to John
  </body>
</message>
<message to='test@conference.example.org' id='STX8I-13' type='groupchat'>
  <body>
    MUC message (public) from Jane
  </body>
</message>
21:35:53.318 SENT (0): 
<message to='test@conference.example.org/Jack' type='chat'>
  <body>
    MUC message (private) from Jane (as Jill) to John (as Jack).
  </body>
  <thread>
    T5XK-A9UR-8QFF-5
  </thread>
</message>
21:35:53.330 RECV (0): 
<message to="jane@example.org/test" id="STX8I-13" type="groupchat" from="test@conference.example.org/Jill">
  <body>
    MUC message (public) from Jane
  </body>
  <stanza-id xmlns="urn:xmpp:sid:0" id="854ab88d-339a-4eaf-b120-5215d795a6e3" by="test@conference.example.org"/>
  <occupant-id xmlns="urn:xmpp:occupant-id:0" id="997716be2f639961ef8ec032cfa82d0bc57d451d"/>
  <addresses xmlns="http://jabber.org/protocol/address">
    <address type="ofrom" jid="jane@example.org/test"/>
  </addresses>
</message>
21:35:53.334 RECV (0): 
<message to="jane@example.org/test" from="john@example.org/test">
  <body>
    Direct message from John to Jane
  </body>
</message>
21:35:53.339 RECV (0): 
<message to="jane@example.org/test" id="6B6RN-11" type="groupchat" from="test@conference.example.org/Jack">
  <body>
    MUC message (public) from John
  </body>
  <stanza-id xmlns="urn:xmpp:sid:0" id="7fdfc27b-de29-4d2b-a50f-a5a121866804" by="test@conference.example.org"/>
  <occupant-id xmlns="urn:xmpp:occupant-id:0" id="f3993338053e990132fb8580aab1f86691b26f5f"/>
  <addresses xmlns="http://jabber.org/protocol/address">
    <address type="ofrom" jid="john@example.org/test"/>
  </addresses>
</message>
21:35:53.340 RECV (0): 
<message to="jane@example.org/test" type="chat" from="test@conference.example.org/Jack">
  <body>
    MUC message (private) from John (as Jack) to Jane (as Jill).
  </body>
  <thread>
    8QD7-85ZY-Q1UZ-P
  </thread>
  <stanza-id xmlns="urn:xmpp:sid:0" id="0a4d8fe9-1f01-4bec-bd4d-4112dc3b68fd" by="test@conference.example.org"/>
  <occupant-id xmlns="urn:xmpp:occupant-id:0" id="f3993338053e990132fb8580aab1f86691b26f5f"/>
  <addresses xmlns="http://jabber.org/protocol/address">
    <address type="ofrom" jid="john@example.org/test"/>
  </addresses>
</message>
21:35:53.570 SENT (0): 
<iq to='jane@example.org' id='STX8I-14' type='get'>
  <query xmlns='http://jabber.org/protocol/disco#info'>
  </query>
</iq>
21:35:53.573 RECV (0): 
<iq type="result" id="STX8I-14" from="jane@example.org" to="jane@example.org/test">
  <query xmlns="http://jabber.org/protocol/disco#info">
    <identity category="pubsub" type="pep"/>
    <identity category="account" type="registered"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-default"/>
    <feature var="http://jabber.org/protocol/pubsub#purge-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#subscription-options"/>
    <feature var="http://jabber.org/protocol/pubsub#create-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#outcast-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#get-pending"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#presence-notifications"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-nodes"/>
    <feature var="http://jabber.org/protocol/pubsub#config-node"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-items"/>
    <feature var="http://jabber.org/protocol/pubsub#filtered-notifications"/>
    <feature var="http://jabber.org/protocol/pubsub#auto-create"/>
    <feature var="http://jabber.org/protocol/pubsub#delete-items"/>
    <feature var="http://jabber.org/protocol/pubsub#item-ids"/>
    <feature var="http://jabber.org/protocol/pubsub#meta-data"/>
    <feature var="http://jabber.org/protocol/pubsub#multi-items"/>
    <feature var="urn:xmpp:mam:0"/>
    <feature var="http://jabber.org/protocol/pubsub#instant-nodes"/>
    <feature var="urn:xmpp:mam:1"/>
    <feature var="urn:xmpp:mam:2"/>
    <feature var="http://jabber.org/protocol/pubsub#modify-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#persistent-items"/>
    <feature var="http://jabber.org/protocol/pubsub#create-and-configure"/>
    <feature var="http://jabber.org/protocol/pubsub"/>
    <feature var="http://jabber.org/protocol/pubsub#publisher-affiliation"/>
    <feature var="http://jabber.org/protocol/pubsub#access-open"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-affiliations"/>
    <feature var="http://jabber.org/protocol/pubsub#retract-items"/>
    <feature var="http://jabber.org/protocol/pubsub#manage-subscriptions"/>
    <feature var="http://jabber.org/protocol/pubsub#auto-subscribe"/>
    <feature var="http://jabber.org/protocol/pubsub#publish-options"/>
    <feature var="http://jabber.org/protocol/pubsub#publish"/>
    <feature var="http://jabber.org/protocol/pubsub#collections"/>
    <feature var="http://jabber.org/protocol/pubsub#retrieve-subscriptions"/>
    <feature var="urn:xmpp:archive:auto"/>
    <feature var="http://jabber.org/protocol/disco#info"/>
    <feature var="urn:xmpp:bookmarks-conversion:0"/>
  </query>
</iq>
21:35:53.575 SENT (0): 
<iq id='6RTF3-19' type='set'>
  <query xmlns='urn:xmpp:mam:2' queryid='C7YR-XHX8-MW45-B'>
    <x xmlns='jabber:x:data' type='submit'>
      <field var='FORM_TYPE'>
        <value>
          urn:xmpp:mam:2
        </value>
      </field>
    </x>
  </query>
</iq>
21:35:53.585 RECV (0): 
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" id="1">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.316Z"/>
      <message xmlns="jabber:client" to="john@example.org/test" from="jane@example.org/test">
        <body>
          Direct message from Jane to John
        </body>
      </message>
    </forwarded>
  </result>
</message>
21:35:53.595 RECV (0): 
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" id="2">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.318Z"/>
      <message xmlns="jabber:client" to="jane@example.org/test" from="john@example.org/test">
        <body>
          Direct message from John to Jane
        </body>
      </message>
    </forwarded>
  </result>
</message>
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" id="3">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.332Z"/>
      <message xmlns="jabber:client" to="test@conference.example.org" id="STX8I-13" type="groupchat" from="test@conference.example.org/Jill">
        <body>
          MUC message (public) from Jane
        </body>
        <stanza-id xmlns="urn:xmpp:sid:0" id="854ab88d-339a-4eaf-b120-5215d795a6e3" by="test@conference.example.org">
        </stanza-id>
        <occupant-id xmlns="urn:xmpp:occupant-id:0" id="997716be2f639961ef8ec032cfa82d0bc57d451d">
        </occupant-id>
        <addresses xmlns="http://jabber.org/protocol/address">
          <address type="ofrom" jid="jane@example.org/test"/>
        </addresses>
      </message>
    </forwarded>
  </result>
</message>
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" id="5">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.337Z"/>
      <message xmlns="jabber:client" to="test@conference.example.org/Jack" type="chat" from="test@conference.example.org/Jill">
        <body>
          MUC message (private) from Jane (as Jill) to John (as Jack).
        </body>
        <thread>
          T5XK-A9UR-8QFF-5
        </thread>
        <stanza-id xmlns="urn:xmpp:sid:0" id="1d4e89a6-4d34-4e82-8e31-0c275c4d3cb0" by="test@conference.example.org">
        </stanza-id>
        <occupant-id xmlns="urn:xmpp:occupant-id:0" id="997716be2f639961ef8ec032cfa82d0bc57d451d">
        </occupant-id>
        <addresses xmlns="http://jabber.org/protocol/address">
          <address type="ofrom" jid="jane@example.org/test"/>
        </addresses>
      </message>
    </forwarded>
  </result>
</message>
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" id="6">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.338Z"/>
      <message xmlns="jabber:client" to="test@conference.example.org/Jill" type="chat" from="test@conference.example.org/Jack">
        <body>
          MUC message (private) from John (as Jack) to Jane (as Jill).
        </body>
        <thread>
          8QD7-85ZY-Q1UZ-P
        </thread>
        <stanza-id xmlns="urn:xmpp:sid:0" id="0a4d8fe9-1f01-4bec-bd4d-4112dc3b68fd" by="test@conference.example.org">
        </stanza-id>
        <occupant-id xmlns="urn:xmpp:occupant-id:0" id="f3993338053e990132fb8580aab1f86691b26f5f">
        </occupant-id>
        <addresses xmlns="http://jabber.org/protocol/address">
          <address type="ofrom" jid="john@example.org/test"/>
        </addresses>
      </message>
    </forwarded>
  </result>
</message>
<iq type="result" id="6RTF3-19" from="jane@example.org" to="jane@example.org/test">
  <fin xmlns="urn:xmpp:mam:2" queryid="C7YR-XHX8-MW45-B" complete="true">
    <set xmlns="http://jabber.org/protocol/rsm">
      <first>
        1
      </first>
      <last>
        6
      </last>
      <count>
        5
      </count>
    </set>
  </fin>
</iq>
21:35:53.850 SENT (0): 
<iq id='6RTF3-21' type='set'>
  <query xmlns='urn:xmpp:mam:2' queryid='6D7C-GSL4-PG7N-Y'>
    <x xmlns='jabber:x:data' type='submit'>
      <field var='FORM_TYPE'>
        <value>
          urn:xmpp:mam:2
        </value>
      </field>
      <field var='with'>
        <value>
          john@example.org
        </value>
      </field>
    </x>
  </query>
</iq>
21:35:53.854 RECV (0): 
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="6D7C-GSL4-PG7N-Y" id="1">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.316Z"/>
      <message xmlns="jabber:client" to="john@example.org/test" from="jane@example.org/test">
        <body>
          Direct message from Jane to John
        </body>
      </message>
    </forwarded>
  </result>
</message>
21:35:53.855 RECV (0): 
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="6D7C-GSL4-PG7N-Y" id="2">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.318Z"/>
      <message xmlns="jabber:client" to="jane@example.org/test" from="john@example.org/test">
        <body>
          Direct message from John to Jane
        </body>
      </message>
    </forwarded>
  </result>
</message>
21:35:53.856 RECV (0): 
<message to="jane@example.org/test">
  <result xmlns="urn:xmpp:mam:2" queryid="6D7C-GSL4-PG7N-Y" id="6">
    <forwarded xmlns="urn:xmpp:forward:0">
      <delay xmlns="urn:xmpp:delay" stamp="2025-03-31T19:35:53.338Z"/>
      <message xmlns="jabber:client" to="test@conference.example.org/Jill" type="chat" from="test@conference.example.org/Jack">
        <body>
          MUC message (private) from John (as Jack) to Jane (as Jill).
        </body>
        <thread>
          8QD7-85ZY-Q1UZ-P
        </thread>
        <stanza-id xmlns="urn:xmpp:sid:0" id="0a4d8fe9-1f01-4bec-bd4d-4112dc3b68fd" by="test@conference.example.org">
        </stanza-id>
        <occupant-id xmlns="urn:xmpp:occupant-id:0" id="f3993338053e990132fb8580aab1f86691b26f5f">
        </occupant-id>
        <addresses xmlns="http://jabber.org/protocol/address">
          <address type="ofrom" jid="john@example.org/test"/>
        </addresses>
      </message>
    </forwarded>
  </result>
</message>
<iq type="result" id="6RTF3-21" from="jane@example.org" to="jane@example.org/test">
  <fin xmlns="urn:xmpp:mam:2" queryid="6D7C-GSL4-PG7N-Y" complete="true">
    <set xmlns="http://jabber.org/protocol/rsm">
      <first>
        1
      </first>
      <last>
        6
      </last>
      <count>
        3
      </count>
    </set>
  </fin>
</iq>
21:35:54.108 SENT (0): 
<presence id='STX8I-15' type='unavailable'/>
21:35:54.109 SENT (0): 
</stream:stream>
21:35:54.110 RECV (0): 
<presence id="STX8I-15" type="unavailable" from="jane@example.org/test" to="jane@example.org/test"/>
21:35:54.115 RECV (0): 
</stream:stream>
21:35:54.117 XMPPConnection closed (XMPPTCPConnection[jane@example.org/test] (0))

The first query (without the ‘with’ clause) results in 5 messages:

  • Direct message from Jane to John
  • Direct message from John to Jane
  • MUC message (public) from Jane
  • MUC message (private) from Jane (as Jill) to John (as Jack).
  • MUC message (private) from John (as Jack) to Jane (as Jill).

The second query (that does define the ‘with’ clause) results in 3 messages:

  • Direct message from Jane to John
  • Direct message from John to Jane
  • MUC message (private) from John (as Jack) to Jane (as Jill).

One thing (out of possibly multiple issues) that is clearly incorrect is the inconsistency with regards to the inclusion of MUC private messages in the result sets.

The first set contains both the ‘sent’ and ‘received’ message, while the second set only contains the ‘received’ message. That is clearly inconsistent. You’d expect the same messages to be in both result sets.

I have raised the following ticket for this: Inconsistent MUC PM inclusion in queries that use 'with' · Issue #422 · igniterealtime/openfire-monitoring-plugin · GitHub

A proposed fix is available in Fix Inconsistent MUC PM inclusion in queries that use 'with' by guusdk · Pull Request #423 · igniterealtime/openfire-monitoring-plugin · GitHub

I would love your feedback on this.

There is likely at least one other issue here: when the room is semi-anonymous, then the ‘with’ clause (using the ‘real’ JID of a user) probably should not result in private messages received from that user, as in a semi-anonymous room the ‘real’ JID of the user is not visible to the owner of the message archive (unless they’re an admin or something)

In other words: If the room is semi-anonymous, then Jane does not know that the private message received from nickname ‘Jack’ was actually sent by user john@example.org. By returning the private message in the result set to Jane when she asks for all messages with john@example.org, Openfire leaks the information that the MUC participant ‘Jack’ was actually john@example.org.