we remove agent even if it doesn't reply. Fixes #1756
This commit is contained in:
parent
29f41b223a
commit
1bc78a3818
|
@ -717,16 +717,14 @@ class Connection(ConnectionHandlers):
|
|||
if iq_obj.getTag('error'):
|
||||
# error, probably not a real agent
|
||||
return
|
||||
self.connection.getRoster().delItem(agent)
|
||||
|
||||
def unsubscribe_agent(self, agent):
|
||||
if not self.connection:
|
||||
return
|
||||
iq = common.xmpp.Iq('set', common.xmpp.NS_REGISTER, to = agent)
|
||||
iq.getTag('query').setTag('remove')
|
||||
self.connection.SendAndCallForResponse(iq, self._continue_unsubscribe,
|
||||
{'agent': agent})
|
||||
return
|
||||
self.connection.send(iq)
|
||||
self.connection.getRoster().delItem(agent)
|
||||
|
||||
def update_contact(self, jid, name, groups):
|
||||
'''update roster item on jabber server'''
|
||||
|
|
|
@ -965,6 +965,8 @@ class Interface:
|
|||
#FIXME if it was the only one in its group, remove the group
|
||||
return
|
||||
elif not contacts:
|
||||
if sub == 'remove':
|
||||
return
|
||||
# Add it to roster
|
||||
contact = gajim.contacts.create_contact(jid = jid, name = name,
|
||||
groups = groups, show = 'offline', sub = sub, ask = ask)
|
||||
|
|
Loading…
Reference in New Issue