Commit b36238e5 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Added support for probing presence of components.

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@4339 b35dd754-fafc-0310-a699-88a17e54d16e
parent c7868ebd
...@@ -44,8 +44,9 @@ ...@@ -44,8 +44,9 @@
Presence Plugin Changelog Presence Plugin Changelog
</h1> </h1>
<p><b>1.2.1</b> -- June ??, 2006</p> <p><b>1.3.0</b> -- July 10, 2006</p>
<ul> <ul>
<li>Added support for probing presence of components.
<li>Fixed minor problem in readme.html -- the example Apache redirect was incorrect. <li>Fixed minor problem in readme.html -- the example Apache redirect was incorrect.
</ul> </ul>
......
...@@ -5,8 +5,8 @@ ...@@ -5,8 +5,8 @@
<name>Presence Service</name> <name>Presence Service</name>
<description>Exposes presence information through HTTP.</description> <description>Exposes presence information through HTTP.</description>
<author>Jive Software</author> <author>Jive Software</author>
<version>1.2.0</version> <version>1.3.0</version>
<date>4/19/2006</date> <date>7/10/2006</date>
<minServerVersion>2.5.1</minServerVersion> <minServerVersion>2.5.1</minServerVersion>
<adminconsole> <adminconsole>
......
...@@ -58,7 +58,7 @@ Presence Plugin Readme ...@@ -58,7 +58,7 @@ Presence Plugin Readme
<p> <p>
The presence plugin is a service that provides simple presence information over HTTP. The presence plugin is a service that provides simple presence information over HTTP.
It can be used to display an online status icon for a user on a web page or to It can be used to display an online status icon for a user or component on a web page or to
poll for presence information from a web service. poll for presence information from a web service.
</p> </p>
......
...@@ -12,7 +12,6 @@ ...@@ -12,7 +12,6 @@
package org.jivesoftware.wildfire.plugin; package org.jivesoftware.wildfire.plugin;
import org.jivesoftware.util.JiveGlobals; import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.jivesoftware.wildfire.PresenceManager; import org.jivesoftware.wildfire.PresenceManager;
import org.jivesoftware.wildfire.XMPPServer; import org.jivesoftware.wildfire.XMPPServer;
import org.jivesoftware.wildfire.container.Plugin; import org.jivesoftware.wildfire.container.Plugin;
...@@ -20,20 +19,20 @@ import org.jivesoftware.wildfire.container.PluginManager; ...@@ -20,20 +19,20 @@ import org.jivesoftware.wildfire.container.PluginManager;
import org.jivesoftware.wildfire.user.User; import org.jivesoftware.wildfire.user.User;
import org.jivesoftware.wildfire.user.UserManager; import org.jivesoftware.wildfire.user.UserManager;
import org.jivesoftware.wildfire.user.UserNotFoundException; import org.jivesoftware.wildfire.user.UserNotFoundException;
import org.xmpp.component.Component;
import org.xmpp.component.ComponentManager; import org.xmpp.component.ComponentManager;
import org.xmpp.component.ComponentManagerFactory; import org.xmpp.component.ComponentManagerFactory;
import org.xmpp.component.Component;
import org.xmpp.packet.JID; import org.xmpp.packet.JID;
import org.xmpp.packet.Presence;
import org.xmpp.packet.Packet; import org.xmpp.packet.Packet;
import org.xmpp.packet.Presence;
import java.io.File; import java.io.File;
import java.util.HashMap; import java.util.Map;
import java.lang.Thread; import java.util.concurrent.ConcurrentHashMap;
/** /**
* Plugin that includes a servlet that provides information about the presence type of the * Plugin that includes a servlet that provides information about users' and components'
* users in the server. For security reasons, the XMPP spec does not allow anyone to see * presence in the server. For security reasons, the XMPP spec does not allow anyone to see
* the presence of any user. Only the users that are subscribed to the presence of other * the presence of any user. Only the users that are subscribed to the presence of other
* users may see their presences.<p/> * users may see their presences.<p/>
* *
...@@ -41,19 +40,25 @@ import java.lang.Thread; ...@@ -41,19 +40,25 @@ import java.lang.Thread;
* so that anyone or only the users that are subscribed to a user presence may see the presence * so that anyone or only the users that are subscribed to a user presence may see the presence
* of other users.<p/> * of other users.<p/>
* *
* Currently, the servlet provides information about user presences in two formats. In XML format * Currently, the servlet provides presence information in two formats: 1) In XML format
* or using images. * and 2) using images.<p>
*
* The presence plugin is also a component so that it can probe presences of other components.
* The new component will use <tt>presence</tt> as the subdomain subdomain.
* *
* @author Gaston Dombiak * @author Gaston Dombiak
*/ */
public class PresencePlugin implements Plugin, Component { public class PresencePlugin implements Plugin, Component {
private static final String subdomain = "presence";
private UserManager userManager; private UserManager userManager;
private PresenceManager presenceManager; private PresenceManager presenceManager;
private PluginManager pluginManager; private PluginManager pluginManager;
private ComponentManager componentManager; private ComponentManager componentManager;
private String hostname; private String hostname;
private HashMap<String, Presence> probedPresence; private Map<String, Presence> probedPresence;
private JID componentJID;
public void initializePlugin(PluginManager manager, File pluginDirectory) { public void initializePlugin(PluginManager manager, File pluginDirectory) {
pluginManager = manager; pluginManager = manager;
...@@ -61,11 +66,12 @@ public class PresencePlugin implements Plugin, Component { ...@@ -61,11 +66,12 @@ public class PresencePlugin implements Plugin, Component {
userManager = server.getUserManager(); userManager = server.getUserManager();
presenceManager = server.getPresenceManager(); presenceManager = server.getPresenceManager();
hostname = server.getServerInfo().getName(); hostname = server.getServerInfo().getName();
probedPresence = new HashMap<String, Presence>(); probedPresence = new ConcurrentHashMap<String, Presence>();
componentJID = new JID(subdomain + "." + hostname);
// Register new component
componentManager = ComponentManagerFactory.getComponentManager(); componentManager = ComponentManagerFactory.getComponentManager();
try { try {
componentManager.addComponent("presence", this); componentManager.addComponent(subdomain, this);
} }
catch (Exception e) { catch (Exception e) {
componentManager.getLog().error(e); componentManager.getLog().error(e);
...@@ -75,9 +81,9 @@ public class PresencePlugin implements Plugin, Component { ...@@ -75,9 +81,9 @@ public class PresencePlugin implements Plugin, Component {
public void destroyPlugin() { public void destroyPlugin() {
userManager = null; userManager = null;
presenceManager = null; presenceManager = null;
// Remove presence plugin component
try { try {
componentManager.removeComponent("presence"); componentManager.removeComponent(subdomain);
componentManager = null; componentManager = null;
} }
catch (Exception e) { catch (Exception e) {
...@@ -103,9 +109,14 @@ public class PresencePlugin implements Plugin, Component { ...@@ -103,9 +109,14 @@ public class PresencePlugin implements Plugin, Component {
} }
public void processPacket(Packet packet) { public void processPacket(Packet packet) {
// Check that we are getting an answer to a presence probe
if (packet instanceof Presence) { if (packet instanceof Presence) {
Presence presence = (Presence) packet; Presence presence = (Presence) packet;
probedPresence.put(presence.getFrom().toString(), presence); if (presence.isAvailable() || presence.getType() == Presence.Type.unavailable ||
presence.getType() == Presence.Type.error) {
// Store answer of presence probes
probedPresence.put(presence.getFrom().toString(), presence);
}
} }
} }
...@@ -152,29 +163,30 @@ public class PresencePlugin implements Plugin, Component { ...@@ -152,29 +163,30 @@ public class PresencePlugin implements Plugin, Component {
if (!hostname.equals(targetJID.getDomain())) { if (!hostname.equals(targetJID.getDomain())) {
// Sender is requesting information about component presence, so we send a // Sender is requesting information about component presence, so we send a
// presence probe to the component. // presence probe to the component.
presenceManager.probePresence(new JID("presence." + hostname), targetJID); presenceManager.probePresence(componentJID, targetJID);
// Wait 30 seconds until we get the probe presence result
int count = 0; int count = 0;
while (!probedPresence.containsKey(jid)) { Presence presence = probedPresence.get(jid);
while (presence == null) {
if (count > 300) {
// After 30 seconds, timeout
throw new UserNotFoundException(
"Request for component presence has timed-out.");
}
try { try {
Thread.sleep(100); Thread.sleep(100);
} }
catch (InterruptedException e) { catch (InterruptedException e) {
// don't care! // don't care!
} }
presence = probedPresence.get(jid);
count++; count++;
if (count > 300) {
// After 30 seconds, timeout
throw new UserNotFoundException("Request for user presence has timed-out.");
}
} }
// Clean-up probe presence result
// Clean-up
Presence presence = probedPresence.get(jid);
probedPresence.remove(jid); probedPresence.remove(jid);
// Return component presence
return presence; return presence;
} }
if (targetJID.getNode() == null || if (targetJID.getNode() == null ||
......
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