Fixed XEP-0065 SOCKS5 socket closing
SCOKS5 SID were removed multiple times from the _sessions dictionary
This commit is contained in:
parent
b95532b68b
commit
f76524fc9f
1 changed files with 7 additions and 1 deletions
|
@ -199,10 +199,15 @@ class XEP_0065(base_plugin):
|
|||
sock = self._sessions.get(sid)
|
||||
if sock:
|
||||
try:
|
||||
# sock.close() will also delete sid from self._sessions (see _connect_proxy)
|
||||
sock.close()
|
||||
except socket.error:
|
||||
pass
|
||||
# Though this should not be neccessary remove the closed session anyway
|
||||
with self._sessions_lock:
|
||||
if sid in self._sessions:
|
||||
log.warn(('SOCKS5 session with sid = "%s" was not ' +
|
||||
'removed from _sessions by sock.close()') % sid)
|
||||
del self._sessions[sid]
|
||||
|
||||
def close(self):
|
||||
|
@ -251,6 +256,7 @@ class XEP_0065(base_plugin):
|
|||
if sid in self._sessions:
|
||||
del self._sessions[sid]
|
||||
_close()
|
||||
log.info('Socket closed.')
|
||||
sock.close = close
|
||||
|
||||
sock.peer_jid = peer
|
||||
|
|
Loading…
Reference in a new issue