mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-11-22 14:22:05 +01:00
Improved Roster(Push|Result)Listener
This commit is contained in:
parent
d7d4c8a4fd
commit
525fece291
1 changed files with 7 additions and 9 deletions
|
@ -1023,8 +1023,6 @@ public class Roster {
|
||||||
// Non-empty roster result. This stanza contains all the roster elements.
|
// Non-empty roster result. This stanza contains all the roster elements.
|
||||||
RosterPacket rosterPacket = (RosterPacket) packet;
|
RosterPacket rosterPacket = (RosterPacket) packet;
|
||||||
|
|
||||||
String version = rosterPacket.getVersion();
|
|
||||||
|
|
||||||
// Ignore items without valid subscription type
|
// Ignore items without valid subscription type
|
||||||
ArrayList<Item> validItems = new ArrayList<RosterPacket.Item>();
|
ArrayList<Item> validItems = new ArrayList<RosterPacket.Item>();
|
||||||
for (RosterPacket.Item item : rosterPacket.getRosterItems()) {
|
for (RosterPacket.Item item : rosterPacket.getRosterItems()) {
|
||||||
|
@ -1052,6 +1050,7 @@ public class Roster {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rosterStore != null) {
|
if (rosterStore != null) {
|
||||||
|
String version = rosterPacket.getVersion();
|
||||||
rosterStore.resetEntries(validItems, version);
|
rosterStore.resetEntries(validItems, version);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1086,15 +1085,13 @@ public class Roster {
|
||||||
public void processPacket(Packet packet) throws NotConnectedException {
|
public void processPacket(Packet packet) throws NotConnectedException {
|
||||||
RosterPacket rosterPacket = (RosterPacket) packet;
|
RosterPacket rosterPacket = (RosterPacket) packet;
|
||||||
|
|
||||||
String version = rosterPacket.getVersion();
|
|
||||||
|
|
||||||
// Roster push (RFC 6121, 2.1.6)
|
// Roster push (RFC 6121, 2.1.6)
|
||||||
// A roster push with a non-empty from not matching our address MUST be ignored
|
// A roster push with a non-empty from not matching our address MUST be ignored
|
||||||
String jid = XmppStringUtils.parseBareJid(connection.getUser());
|
String jid = XmppStringUtils.parseBareJid(connection.getUser());
|
||||||
if (rosterPacket.getFrom() != null &&
|
String from = rosterPacket.getFrom();
|
||||||
!rosterPacket.getFrom().equals(jid)) {
|
if (from != null && !from.equals(jid)) {
|
||||||
LOGGER.warning("Ignoring roster push with a non matching 'from' ourJid=" + jid
|
LOGGER.warning("Ignoring roster push with a non matching 'from' ourJid='" + jid + "' from='" + from
|
||||||
+ " from=" + rosterPacket.getFrom());
|
+ "'");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1110,11 +1107,12 @@ public class Roster {
|
||||||
Collection<String> deletedEntries = new ArrayList<String>();
|
Collection<String> deletedEntries = new ArrayList<String>();
|
||||||
Collection<String> unchangedEntries = new ArrayList<String>();
|
Collection<String> unchangedEntries = new ArrayList<String>();
|
||||||
|
|
||||||
// We assured abouve that the size of items is exaclty 1, therefore we are able to
|
// We assured above that the size of items is exaclty 1, therefore we are able to
|
||||||
// safely retrieve this single item here.
|
// safely retrieve this single item here.
|
||||||
Item item = items.iterator().next();
|
Item item = items.iterator().next();
|
||||||
RosterEntry entry = new RosterEntry(item.getUser(), item.getName(),
|
RosterEntry entry = new RosterEntry(item.getUser(), item.getName(),
|
||||||
item.getItemType(), item.getItemStatus(), Roster.this, connection);
|
item.getItemType(), item.getItemStatus(), Roster.this, connection);
|
||||||
|
String version = rosterPacket.getVersion();
|
||||||
|
|
||||||
if (item.getItemType().equals(RosterPacket.ItemType.remove)) {
|
if (item.getItemType().equals(RosterPacket.ItemType.remove)) {
|
||||||
deleteEntry(deletedEntries, entry);
|
deleteEntry(deletedEntries, entry);
|
||||||
|
|
Loading…
Reference in a new issue