Commit 8b283d59 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gaston

Do not send subscription requests to local users that already approved the...

Do not send subscription requests to local users that already approved the presence subscription. JM-288


git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@1576 b35dd754-fafc-0310-a699-88a17e54d16e
parent fa7f742e
...@@ -105,6 +105,31 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand ...@@ -105,6 +105,31 @@ public class PresenceSubscribeHandler extends BasicModule implements ChannelHand
// and the recipient user has not changed its subscription state. // and the recipient user has not changed its subscription state.
if (!(type == Presence.Type.subscribed && recipientRoster != null && if (!(type == Presence.Type.subscribed && recipientRoster != null &&
!recipientSubChanged)) { !recipientSubChanged)) {
// If the user is already subscribed to the *local* user's presence then do not
// forward the subscription request and instead send an auto-reply on behalf
// of the user
if (type == Presence.Type.subscribe && recipientRoster != null &&
!recipientSubChanged) {
try {
RosterItem.SubType subType = recipientRoster.getRosterItem(senderJID)
.getSubStatus();
if (subType == RosterItem.SUB_FROM || subType == RosterItem.SUB_BOTH) {
// auto-reply by sending a presence stanza of type "subscribed"
// to the contact on behalf of the user
Presence reply = new Presence();
reply.setTo(senderJID);
reply.setFrom(recipientJID);
reply.setType(Presence.Type.subscribed);
deliverer.deliver(reply);
return;
}
}
catch (UserNotFoundException e) {
// Weird case: Roster item does not exist. Should never happen
}
}
// Try to obtain a handler for the packet based on the routes. If the handler is // Try to obtain a handler for the packet based on the routes. If the handler is
// a module, the module will be able to handle the packet. If the handler is a // a module, the module will be able to handle the packet. If the handler is a
// 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
......
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