Commit fa2fe8b2 authored by Derek DeMoro's avatar Derek DeMoro Committed by derek

Updating with Component Probing


git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@335 b35dd754-fafc-0310-a699-88a17e54d16e
parent dd820b34
package org.jivesoftware.messenger; package org.jivesoftware.messenger;
import java.util.Map; import java.util.Map;
import java.util.Iterator;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import org.jivesoftware.util.StringUtils; import org.jivesoftware.util.StringUtils;
import org.jivesoftware.messenger.spi.PresenceImpl;
public class ComponentManager { public class ComponentManager {
private Map<String, Component> components = new ConcurrentHashMap<String, Component>(); private Map<String, Component> components = new ConcurrentHashMap<String, Component>();
private Map<XMPPAddress, XMPPAddress> presenceMap = new ConcurrentHashMap<XMPPAddress, XMPPAddress>();
static private ComponentManager singleton; static private ComponentManager singleton;
private final static Object LOCK = new Object(); private final static Object LOCK = new Object();
...@@ -38,6 +41,9 @@ public class ComponentManager { ...@@ -38,6 +41,9 @@ public class ComponentManager {
public void addComponent(String jid, Component component){ public void addComponent(String jid, Component component){
jid = validateJID(jid); jid = validateJID(jid);
components.put(jid, component); components.put(jid, component);
// Check for potential interested users.
checkPresences();
} }
public void removeComponent(String jid){ public void removeComponent(String jid){
...@@ -63,4 +69,22 @@ public class ComponentManager { ...@@ -63,4 +69,22 @@ public class ComponentManager {
jid = jid.trim().toLowerCase(); jid = jid.trim().toLowerCase();
return jid; return jid;
} }
public void addPresenceRequest(XMPPAddress prober, XMPPAddress probee){
presenceMap.put(prober, probee);
}
private void checkPresences(){
for(XMPPAddress prober : presenceMap.keySet()){
XMPPAddress probee = presenceMap.get(prober);
Component component = getComponent(probee.toBareStringPrep());
if(component != null){
Presence presence = new PresenceImpl();
presence.setSender(prober);
presence.setRecipient(probee);
component.processPacket(presence);
}
}
}
} }
...@@ -11,18 +11,20 @@ ...@@ -11,18 +11,20 @@
package org.jivesoftware.messenger.spi; package org.jivesoftware.messenger.spi;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import org.jivesoftware.messenger.*;
import org.jivesoftware.messenger.auth.UnauthorizedException;
import org.jivesoftware.messenger.container.BasicModule; import org.jivesoftware.messenger.container.BasicModule;
import org.jivesoftware.messenger.container.Container; import org.jivesoftware.messenger.container.Container;
import org.jivesoftware.messenger.container.TrackInfo; import org.jivesoftware.messenger.container.TrackInfo;
import org.jivesoftware.util.Cache;
import org.jivesoftware.util.*;
import org.jivesoftware.messenger.*;
import org.jivesoftware.messenger.auth.UnauthorizedException;
import org.jivesoftware.messenger.user.User; import org.jivesoftware.messenger.user.User;
import org.jivesoftware.messenger.user.UserManager; import org.jivesoftware.messenger.user.UserManager;
import org.jivesoftware.messenger.user.UserNotFoundException; import org.jivesoftware.messenger.user.UserNotFoundException;
import java.util.*; import org.jivesoftware.util.Cache;
import java.util.concurrent.ConcurrentHashMap; import org.jivesoftware.util.JiveConstants;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
/** /**
* Simple in memory implementation of the PresenceManager interface. * Simple in memory implementation of the PresenceManager interface.
...@@ -31,8 +33,8 @@ import java.util.concurrent.ConcurrentHashMap; ...@@ -31,8 +33,8 @@ import java.util.concurrent.ConcurrentHashMap;
*/ */
public class PresenceManagerImpl extends BasicModule implements PresenceManager { public class PresenceManagerImpl extends BasicModule implements PresenceManager {
private Map<String,Presence> onlineGuests; private Map<String, Presence> onlineGuests;
private Map<String,Presence> onlineUsers; private Map<String, Presence> onlineUsers;
/** /**
* table: key jid.getUserJid().toLowerCase() (String); value Presence * table: key jid.getUserJid().toLowerCase() (String); value Presence
...@@ -59,8 +61,8 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -59,8 +61,8 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
// create caches - no size limit and never expire for presence caches // create caches - no size limit and never expire for presence caches
long HOUR = JiveConstants.HOUR; long HOUR = JiveConstants.HOUR;
onlineGuests = new ConcurrentHashMap<String,Presence>(); onlineGuests = new ConcurrentHashMap<String, Presence>();
onlineUsers = new ConcurrentHashMap<String,Presence>(); onlineUsers = new ConcurrentHashMap<String, Presence>();
foreignUserCache = new Cache("Foreign Users", foreignCacheSize, HOUR); foreignUserCache = new Cache("Foreign Users", foreignCacheSize, HOUR);
} }
...@@ -110,50 +112,53 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -110,50 +112,53 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
} }
switch (sortField) { switch (sortField) {
case PresenceManager.SORT_ONLINE_TIME: { case PresenceManager.SORT_ONLINE_TIME:
Collections.sort(presences, new Comparator() { {
public int compare(Object object1, Object object2) { Collections.sort(presences, new Comparator() {
Presence presence1 = (Presence)object1; public int compare(Object object1, Object object2) {
Presence presence2 = (Presence)object2; Presence presence1 = (Presence)object1;
if (ascending) { Presence presence2 = (Presence)object2;
return presence1.getLoginTime().compareTo(presence2.getLoginTime()); if (ascending) {
} return presence1.getLoginTime().compareTo(presence2.getLoginTime());
else { }
return presence2.getLoginTime().compareTo(presence1.getLoginTime()); else {
} return presence2.getLoginTime().compareTo(presence1.getLoginTime());
} }
});
break;
}
case PresenceManager.SORT_USERNAME: {
Collections.sort(presences, new Comparator() {
public int compare(Object object1, Object object2) {
Presence presence1 = (Presence)object1;
Presence presence2 = (Presence)object2;
String presenceUser1 = "";
String presenceUser2 = "";
try {
presenceUser1 =
userManager.getUser(presence1.getUsername()).getUsername();
presenceUser2 =
userManager.getUser(presence2.getUsername()).getUsername();
}
catch (UserNotFoundException e) {
Log.error(LocaleUtils.getLocalizedString("admin.error"), e);
}
if (ascending) {
return presenceUser1.compareTo(presenceUser2);
} }
else { });
return presenceUser2.compareTo(presenceUser1); break;
}
case PresenceManager.SORT_USERNAME:
{
Collections.sort(presences, new Comparator() {
public int compare(Object object1, Object object2) {
Presence presence1 = (Presence)object1;
Presence presence2 = (Presence)object2;
String presenceUser1 = "";
String presenceUser2 = "";
try {
presenceUser1 =
userManager.getUser(presence1.getUsername()).getUsername();
presenceUser2 =
userManager.getUser(presence2.getUsername()).getUsername();
}
catch (UserNotFoundException e) {
Log.error(LocaleUtils.getLocalizedString("admin.error"), e);
}
if (ascending) {
return presenceUser1.compareTo(presenceUser2);
}
else {
return presenceUser2.compareTo(presenceUser1);
}
} }
} });
}); break;
break; }
} default:
default: { {
// ignore invalid sort field // ignore invalid sort field
} }
} }
List<User> users = new ArrayList<User>(); List<User> users = new ArrayList<User>();
...@@ -272,14 +277,13 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -272,14 +277,13 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
public void probePresence(String prober, XMPPAddress probee) { public void probePresence(String prober, XMPPAddress probee) {
try { try {
Component component = getPresenceComponent(probee);
if (server.isLocal(probee)) { if (server.isLocal(probee)) {
if (probee.getNamePrep() != null && !"".equals(probee.getNamePrep())) { if (probee.getNamePrep() != null && !"".equals(probee.getNamePrep())) {
Iterator sessionIter = Iterator sessionIter = sessionManager.getSessions(probee.getNamePrep());
sessionManager.getSessions(probee.getNamePrep());
while (sessionIter.hasNext()) { while (sessionIter.hasNext()) {
Session session = (Session)sessionIter.next(); Session session = (Session)sessionIter.next();
Presence presencePacket = Presence presencePacket = (Presence)session.getPresence().createDeepCopy();
(Presence)session.getPresence().createDeepCopy();
presencePacket.setSender(session.getAddress()); presencePacket.setSender(session.getAddress());
try { try {
sessionManager.userBroadcast(prober, presencePacket); sessionManager.userBroadcast(prober, presencePacket);
...@@ -290,9 +294,15 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -290,9 +294,15 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
} }
} }
} }
else if (component != null) {
Presence presence = new PresenceImpl();
presence.setType(Presence.PROBE);
presence.setSender(server.createAddress(prober, ""));
presence.setRecipient(probee);
component.processPacket(presence);
}
else { else {
Presence presence = Presence presence = (Presence)foreignUserCache.get(probee.toBareStringPrep());
(Presence)foreignUserCache.get(probee.toBareStringPrep());
if (presence != null) { if (presence != null) {
Presence presencePacket = (Presence)presence.createDeepCopy(); Presence presencePacket = (Presence)presence.createDeepCopy();
presencePacket.setSender(probee); presencePacket.setSender(probee);
...@@ -303,6 +313,10 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -303,6 +313,10 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
Log.error(LocaleUtils.getLocalizedString("admin.error"), e); Log.error(LocaleUtils.getLocalizedString("admin.error"), e);
} }
} }
else {
XMPPAddress proberAddress = server.createAddress(prober, "");
componentManager.addPresenceRequest(proberAddress, probee);
}
} }
} }
catch (UnauthorizedException e) { catch (UnauthorizedException e) {
...@@ -367,10 +381,10 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager ...@@ -367,10 +381,10 @@ public class PresenceManagerImpl extends BasicModule implements PresenceManager
return trackInfo; return trackInfo;
} }
public Component getPresenceComponent(XMPPAddress probee){ public Component getPresenceComponent(XMPPAddress probee) {
// Check for registered components // Check for registered components
Component component = componentManager.getComponent(probee.toBareStringPrep()); Component component = componentManager.getComponent(probee.toBareStringPrep());
if(component != null){ if (component != null) {
return component; return component;
} }
return null; return 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