connects when server can't resume stream
This commit is contained in:
parent
2090b9b900
commit
7194260f98
|
@ -535,7 +535,7 @@ class XMPPDispatcher(PlugIn):
|
||||||
if self._owner._registered_name and not stanza.getAttr('from'):
|
if self._owner._registered_name and not stanza.getAttr('from'):
|
||||||
stanza.setAttr('from', self._owner._registered_name)
|
stanza.setAttr('from', self._owner._registered_name)
|
||||||
|
|
||||||
if self.sm:
|
if self.sm and self.sm.enabled:
|
||||||
self.sm.uqueue.append(stanza)
|
self.sm.uqueue.append(stanza)
|
||||||
self.sm.out_h = self.sm.out_h + 1
|
self.sm.out_h = self.sm.out_h + 1
|
||||||
if len(self.sm.uqueue) > self.sm.max_queue:
|
if len(self.sm.uqueue) > self.sm.max_queue:
|
||||||
|
|
|
@ -24,7 +24,8 @@ class Smacks():
|
||||||
self.max_queue = 5
|
self.max_queue = 5
|
||||||
self._owner = None
|
self._owner = None
|
||||||
self.resuming = False
|
self.resuming = False
|
||||||
|
self.enabled = False # If SM is enabled
|
||||||
|
|
||||||
def set_owner(self, owner):
|
def set_owner(self, owner):
|
||||||
self._owner = owner
|
self._owner = owner
|
||||||
|
|
||||||
|
@ -50,6 +51,8 @@ class Smacks():
|
||||||
|
|
||||||
if r == 'false' or r == 'False' or r == '0':
|
if r == 'false' or r == 'False' or r == '0':
|
||||||
self.negociate(False)
|
self.negociate(False)
|
||||||
|
|
||||||
|
self.enabled = True
|
||||||
|
|
||||||
def negociate(self, resume=True):
|
def negociate(self, resume=True):
|
||||||
# Every time we attempt to negociate, we must erase all previous info
|
# Every time we attempt to negociate, we must erase all previous info
|
||||||
|
@ -69,7 +72,7 @@ class Smacks():
|
||||||
log.error('Attempted to resume without a valid session id ')
|
log.error('Attempted to resume without a valid session id ')
|
||||||
return
|
return
|
||||||
resume = Acks()
|
resume = Acks()
|
||||||
resume.buildResume(self.in_h, self.session_id)
|
resume.buildResume(self.in_h, None)#self.session_id)
|
||||||
self._owner.Connection.send(resume, True)
|
self._owner.Connection.send(resume, True)
|
||||||
|
|
||||||
def send_ack(self, disp, stanza):
|
def send_ack(self, disp, stanza):
|
||||||
|
@ -105,17 +108,28 @@ class Smacks():
|
||||||
for i in self.uqueue:
|
for i in self.uqueue:
|
||||||
self._owner.Connection.send(i, False)
|
self._owner.Connection.send(i, False)
|
||||||
|
|
||||||
def error_handling(self, disp, stanza): # NEEDS TESTING
|
def error_handling(self, disp, stanza):
|
||||||
|
|
||||||
tag = stanza.getTag('item-not-found')
|
|
||||||
# If the server doesn't recognize previd, forget about resuming
|
# If the server doesn't recognize previd, forget about resuming
|
||||||
# Ask for service discovery, etc..
|
# Ask for service discovery, etc..
|
||||||
if tag:
|
if stanza.getTag('item-not-found'):
|
||||||
self.negociate()
|
self.enabled = False
|
||||||
self.resuming = False
|
self.resuming = False
|
||||||
|
self.negociate()
|
||||||
self.con._discover_server_at_connection(self.con.connection)
|
self.con._discover_server_at_connection(self.con.connection)
|
||||||
|
return
|
||||||
|
|
||||||
tag = stanza.getTag('feature-not-implemented')
|
|
||||||
# Doesn't support resumption
|
# Doesn't support resumption
|
||||||
if tag:
|
if stanza.getTag('feature-not-implemented'):
|
||||||
self.negociate(False)
|
self.enabled = False
|
||||||
|
self.negociate(False)
|
||||||
|
return
|
||||||
|
|
||||||
|
if stanza.getTag('unexpected-request'):
|
||||||
|
self.enabled = False
|
||||||
|
log.error('Gajim failed to negociate Stream Management')
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue