Commit 8a1f3890 authored by Robin Collier's avatar Robin Collier Committed by rcollier

OF-7 Reply now only returns the subscriptions for the node when it is specified.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@11276 b35dd754-fafc-0310-a699-88a17e54d16e
parent 377b5d85
...@@ -843,11 +843,22 @@ public class PubSubEngine { ...@@ -843,11 +843,22 @@ public class PubSubEngine {
private void getSubscriptions(PubSubService service, IQ iq, Element childElement) { private void getSubscriptions(PubSubService service, IQ iq, Element childElement) {
// TODO Assuming that owner is the bare JID (as defined in the JEP). This can be replaced with an explicit owner specified in the packet // TODO Assuming that owner is the bare JID (as defined in the JEP). This can be replaced with an explicit owner specified in the packet
JID owner = new JID(iq.getFrom().toBareJID()); JID owner = new JID(iq.getFrom().toBareJID());
// Collect subscriptions of owner for all nodes at the service Element subscriptionsElement = childElement.element("subscriptions");
String nodeID = subscriptionsElement.attributeValue("node");
Collection<NodeSubscription> subscriptions = new ArrayList<NodeSubscription>(); Collection<NodeSubscription> subscriptions = new ArrayList<NodeSubscription>();
if (nodeID == null)
{
// Collect subscriptions of owner for all nodes at the service
for (Node node : service.getNodes()) { for (Node node : service.getNodes()) {
subscriptions.addAll(node.getSubscriptions(owner)); subscriptions.addAll(node.getSubscriptions(owner));
} }
}
else
{
subscriptions.addAll(service.getNode(nodeID).getSubscriptions(owner));
}
// Create reply to send // Create reply to send
IQ reply = IQ.createResultIQ(iq); IQ reply = IQ.createResultIQ(iq);
Element replyChildElement = childElement.createCopy(); Element replyChildElement = childElement.createCopy();
...@@ -859,7 +870,8 @@ public class PubSubEngine { ...@@ -859,7 +870,8 @@ public class PubSubEngine {
Node node = subscription.getNode(); Node node = subscription.getNode();
NodeAffiliate nodeAffiliate = subscription.getAffiliate(); NodeAffiliate nodeAffiliate = subscription.getAffiliate();
// Do not include the node id when node is the root collection node // Do not include the node id when node is the root collection node
if (!node.isRootCollectionNode()) { // or the results are for a specific node
if (!node.isRootCollectionNode() && (nodeID == null)) {
subElement.addAttribute("node", node.getNodeID()); subElement.addAttribute("node", node.getNodeID());
} }
subElement.addAttribute("jid", subscription.getJID().toString()); subElement.addAttribute("jid", subscription.getJID().toString());
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment