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

1. Do not create a roster item when processing an unsubscribed presence packet. JM-478

2. Refactoring of NoSuchRouteException. JM-476

git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@3136 b35dd754-fafc-0310-a699-88a17e54d16e
parent f350a02c
/** /**
* $RCSfile$ * $RCSfile: PresenceSubscribeHandler.java,v $
* $Revision$ * $Revision$
* $Date$ * $Date$
* *
...@@ -135,10 +135,15 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand ...@@ -135,10 +135,15 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand
// Session the packet will be routed to the client. If a route cannot be found // Session the packet will be routed to the client. If a route cannot be found
// then the packet will be delivered based on its recipient and sender. // then the packet will be delivered based on its recipient and sender.
ChannelHandler handler = routingTable.getRoute(recipientJID); ChannelHandler handler = routingTable.getRoute(recipientJID);
Presence presenteToSend = presence.createCopy(); if (handler != null) {
// Stamp the presence with the user's bare JID as the 'from' address Presence presenteToSend = presence.createCopy();
presenteToSend.setFrom(senderJID.toBareJID()); // Stamp the presence with the user's bare JID as the 'from' address
handler.process(presenteToSend); presenteToSend.setFrom(senderJID.toBareJID());
handler.process(presenteToSend);
}
else {
deliverer.deliver(presence.createCopy());
}
if (type == Presence.Type.subscribed) { if (type == Presence.Type.subscribed) {
// Send the presence of the local user to the remote user. The remote user // Send the presence of the local user to the remote user. The remote user
...@@ -153,9 +158,6 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand ...@@ -153,9 +158,6 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand
presenceManager.sendUnavailableFromSessions(recipientJID, senderJID); presenceManager.sendUnavailableFromSessions(recipientJID, senderJID);
} }
} }
catch (NoSuchRouteException e) {
deliverer.deliver(presence.createCopy());
}
catch (SharedGroupException e) { catch (SharedGroupException e) {
Presence result = presence.createCopy(); Presence result = presence.createCopy();
JID sender = result.getFrom(); JID sender = result.getFrom();
...@@ -220,6 +222,11 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand ...@@ -220,6 +222,11 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand
item = roster.getRosterItem(target); item = roster.getRosterItem(target);
} }
else { else {
if (Presence.Type.unsubscribed == type) {
// Do not create a roster item when processing a confirmation of
// an unsubscription
return false;
}
item = roster.createRosterItem(target); item = roster.createRosterItem(target);
} }
// Get a snapshot of the item state // Get a snapshot of the item state
......
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