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

Fixed NPE when trying to remove an item that does not exist. JM-392

git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@2798 b35dd754-fafc-0310-a699-88a17e54d16e
parent 6d4a7cfb
...@@ -329,41 +329,49 @@ public class Roster implements Cacheable { ...@@ -329,41 +329,49 @@ public class Roster implements Cacheable {
throw new SharedGroupException("Cannot remove contact that belongs to a shared group"); throw new SharedGroupException("Cannot remove contact that belongs to a shared group");
} }
RosterItem.SubType subType = itemToRemove.getSubStatus(); if (itemToRemove != null) {
// Cancel any existing presence subscription between the user and the contact RosterItem.SubType subType = itemToRemove.getSubStatus();
if (subType == RosterItem.SUB_TO || subType == RosterItem.SUB_BOTH) {
Presence presence = new Presence(); // Cancel any existing presence subscription between the user and the contact
presence.setFrom(server.createJID(username, null)); if (subType == RosterItem.SUB_TO || subType == RosterItem.SUB_BOTH) {
presence.setTo(itemToRemove.getJid()); Presence presence = new Presence();
presence.setType(Presence.Type.unsubscribe); presence.setFrom(server.createJID(username, null));
server.getPacketRouter().route(presence); presence.setTo(itemToRemove.getJid());
} presence.setType(Presence.Type.unsubscribe);
// cancel any existing presence subscription between the contact and the user server.getPacketRouter().route(presence);
if (subType == RosterItem.SUB_FROM || subType == RosterItem.SUB_BOTH) {
Presence presence = new Presence();
presence.setFrom(server.createJID(username, null));
presence.setTo(itemToRemove.getJid());
presence.setType(Presence.Type.unsubscribed);
server.getPacketRouter().route(presence);
}
// If removing the user was successful, remove the user from the subscriber list:
RosterItem item = rosterItems.remove(user.toBareJID());
if (item != null) {
// Delete the item from the provider if the item is persistent. RosteItems that only
// belong to shared groups won't be persistent
if (item.getID() > 0) {
// If removing the user was successful, remove the user from the backend store
rosterItemProvider.deleteItem(username, item.getID());
} }
// Broadcast the update to the user // cancel any existing presence subscription between the contact and the user
org.xmpp.packet.Roster roster = new org.xmpp.packet.Roster(); if (subType == RosterItem.SUB_FROM || subType == RosterItem.SUB_BOTH) {
roster.setType(IQ.Type.set); Presence presence = new Presence();
roster.addItem(user, org.xmpp.packet.Roster.Subscription.remove); presence.setFrom(server.createJID(username, null));
broadcast(roster); presence.setTo(itemToRemove.getJid());
presence.setType(Presence.Type.unsubscribed);
server.getPacketRouter().route(presence);
}
// If removing the user was successful, remove the user from the subscriber list:
RosterItem item = rosterItems.remove(user.toBareJID());
if (item != null) {
// Delete the item from the provider if the item is persistent. RosteItems that only
// belong to shared groups won't be persistent
if (item.getID() > 0) {
// If removing the user was successful, remove the user from the backend store
rosterItemProvider.deleteItem(username, item.getID());
}
// Broadcast the update to the user
org.xmpp.packet.Roster roster = new org.xmpp.packet.Roster();
roster.setType(IQ.Type.set);
roster.addItem(user, org.xmpp.packet.Roster.Subscription.remove);
broadcast(roster);
}
return item;
} }
return item;
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