Commit 40a79314 authored by Armando Jagucki's avatar Armando Jagucki Committed by ajagucki

Access models become respected for user disco#items results. "Contact Service...

Access models become respected for user disco#items results. "Contact Service Discovery" section of XEP-0163 is completely implemented now.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/branches@8782 b35dd754-fafc-0310-a699-88a17e54d16e
parent 693a5ae6
...@@ -22,9 +22,11 @@ import org.jivesoftware.openfire.disco.ServerIdentitiesProvider; ...@@ -22,9 +22,11 @@ import org.jivesoftware.openfire.disco.ServerIdentitiesProvider;
import org.jivesoftware.openfire.disco.UserIdentitiesProvider; import org.jivesoftware.openfire.disco.UserIdentitiesProvider;
import org.jivesoftware.openfire.disco.UserItemsProvider; import org.jivesoftware.openfire.disco.UserItemsProvider;
import org.jivesoftware.openfire.handler.IQHandler; import org.jivesoftware.openfire.handler.IQHandler;
import org.jivesoftware.openfire.pubsub.CollectionNode;
import org.jivesoftware.openfire.pubsub.LeafNode; import org.jivesoftware.openfire.pubsub.LeafNode;
import org.jivesoftware.openfire.pubsub.Node; import org.jivesoftware.openfire.pubsub.Node;
import org.jivesoftware.openfire.pubsub.PubSubEngine; import org.jivesoftware.openfire.pubsub.PubSubEngine;
import org.jivesoftware.openfire.pubsub.models.AccessModel;
import org.jivesoftware.openfire.user.UserManager; import org.jivesoftware.openfire.user.UserManager;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
...@@ -173,12 +175,11 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider, ...@@ -173,12 +175,11 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider,
if (pepService.getNode(nodeID) == null) { if (pepService.getNode(nodeID) == null) {
// Create the node // Create the node
JID creator = new JID(jidFrom); JID creator = new JID(jidFrom);
LeafNode newNode = new LeafNode(pepService, pepService.getRootCollectionNode(), LeafNode newNode = new LeafNode(pepService, null, nodeID, creator);
nodeID, creator);
newNode.addOwner(creator); newNode.addOwner(creator);
newNode.saveToDB(); newNode.saveToDB();
if (Log.isDebugEnabled()) { if (Log.isDebugEnabled()) {
Log.debug("PEP: Created node ('" + nodeID + "') for " + jidFrom); Log.debug("PEP: Created node ('" + newNode.getNodeID() + "') for " + jidFrom);
} }
} }
} }
...@@ -251,6 +252,10 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider, ...@@ -251,6 +252,10 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider,
return XMPPServer.getInstance().getPubSubModule().getFeatures(null, null, null); return XMPPServer.getInstance().getPubSubModule().getFeatures(null, null, null);
} }
/**
* Implements UserItemsProvider, adding PEP related items to a disco#items
* result.
*/
public Iterator<Element> getUserItems(String name, JID senderJID) { public Iterator<Element> getUserItems(String name, JID senderJID) {
ArrayList<Element> items = new ArrayList<Element>(); ArrayList<Element> items = new ArrayList<Element>();
...@@ -258,14 +263,25 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider, ...@@ -258,14 +263,25 @@ public class IQPEPHandler extends IQHandler implements ServerIdentitiesProvider,
PEPService pepService = pepServices.get(recipientJID); PEPService pepService = pepServices.get(recipientJID);
if (pepService != null) { if (pepService != null) {
CollectionNode rootNode = pepService.getRootCollectionNode();
Element defaultItem = DocumentHelper.createElement("item"); Element defaultItem = DocumentHelper.createElement("item");
defaultItem.addAttribute("jid", recipientJID); defaultItem.addAttribute("jid", recipientJID);
for (Node node : pepService.getNodes()) { for (Node node : pepService.getNodes()) {
// Do not include the root node.
if (node == rootNode) {
continue;
}
AccessModel accessModel = node.getAccessModel();
if (accessModel.canAccessItems(node, senderJID, new JID(recipientJID))) {
Element item = defaultItem.createCopy(); Element item = defaultItem.createCopy();
item.addAttribute("node", node.getNodeID()); item.addAttribute("node", node.getNodeID());
items.add(item); items.add(item);
} }
} }
}
return items.iterator(); return items.iterator();
} }
......
...@@ -161,7 +161,7 @@ public class PEPService implements PubSubService { ...@@ -161,7 +161,7 @@ public class PEPService implements PubSubService {
if (leafDefaultConfiguration == null) { if (leafDefaultConfiguration == null) {
// Create and save default configuration for leaf nodes; // Create and save default configuration for leaf nodes;
leafDefaultConfiguration = new DefaultNodeConfiguration(true); leafDefaultConfiguration = new DefaultNodeConfiguration(true);
leafDefaultConfiguration.setAccessModel(AccessModel.open); leafDefaultConfiguration.setAccessModel(AccessModel.presence);
leafDefaultConfiguration.setPublisherModel(PublisherModel.publishers); leafDefaultConfiguration.setPublisherModel(PublisherModel.publishers);
leafDefaultConfiguration.setDeliverPayloads(true); leafDefaultConfiguration.setDeliverPayloads(true);
leafDefaultConfiguration.setLanguage("English"); leafDefaultConfiguration.setLanguage("English");
......
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