fix closing listening port
This commit is contained in:
parent
c9f2176ccb
commit
952ea6a9b6
|
@ -93,19 +93,19 @@ class SocksQueue:
|
||||||
sid = fp['sid']
|
sid = fp['sid']
|
||||||
self.type = type # It says whether we are sending or receiving
|
self.type = type # It says whether we are sending or receiving
|
||||||
self.sha_handlers[sha_str] = (sha_handler, sid)
|
self.sha_handlers[sha_str] = (sha_handler, sid)
|
||||||
if self.listener is None:
|
self.listener = Socks5Listener(self.idlequeue, port, fp,
|
||||||
self.listener = Socks5Listener(self.idlequeue, port, fp,
|
|
||||||
fingerprint=fingerprint)
|
fingerprint=fingerprint)
|
||||||
self.listener.queue = self
|
self.listener.queue = self
|
||||||
self.listener.bind()
|
self.listener.bind()
|
||||||
if self.listener.started is False:
|
if self.listener.started is False:
|
||||||
self.listener = None
|
self.listener = None
|
||||||
# We cannot bind port, call error callback and fail
|
# We cannot bind port, call error callback and fail
|
||||||
self.error_cb(_('Unable to bind to port %s.') % port,
|
self.error_cb(_('Unable to bind to port %s.') % port,
|
||||||
_('Maybe you have another running instance of Gajim. File '
|
_('Maybe you have another running instance of Gajim. File '
|
||||||
'Transfer will be cancelled.'))
|
'Transfer will be cancelled.'))
|
||||||
return None
|
return None
|
||||||
self.connected += 1
|
|
||||||
|
self.connected += 1
|
||||||
return self.listener
|
return self.listener
|
||||||
|
|
||||||
def send_success_reply(self, file_props, streamhost):
|
def send_success_reply(self, file_props, streamhost):
|
||||||
|
@ -311,6 +311,12 @@ class SocksQueue:
|
||||||
|
|
||||||
def send_file(self, file_props, account, mode):
|
def send_file(self, file_props, account, mode):
|
||||||
for key in self.senders.keys():
|
for key in self.senders.keys():
|
||||||
|
if self.senders == {}:
|
||||||
|
# Python acts very weird with this. When there is no keys
|
||||||
|
# in the dictionary It says that it has a key.
|
||||||
|
# Maybe it is my machine. Without this there is a KeyError
|
||||||
|
# traceback.
|
||||||
|
return
|
||||||
if file_props['name'] in key and file_props['sid'] in key \
|
if file_props['name'] in key and file_props['sid'] in key \
|
||||||
and self.senders[key].mode == mode:
|
and self.senders[key].mode == mode:
|
||||||
|
|
||||||
|
@ -416,7 +422,7 @@ class SocksQueue:
|
||||||
elif self.progress_transfer_cb is not None:
|
elif self.progress_transfer_cb is not None:
|
||||||
self.progress_transfer_cb(actor.account, actor.file_props)
|
self.progress_transfer_cb(actor.account, actor.file_props)
|
||||||
|
|
||||||
def remove_receiver(self, idx, do_disconnect=True):
|
def remove_receiver(self, idx, do_disconnect=True, remove_all=False):
|
||||||
"""
|
"""
|
||||||
Remove reciver from the list and decrease the number of active
|
Remove reciver from the list and decrease the number of active
|
||||||
connections with 1
|
connections with 1
|
||||||
|
@ -429,14 +435,16 @@ class SocksQueue:
|
||||||
self.idlequeue.remove_timeout(reader.fd)
|
self.idlequeue.remove_timeout(reader.fd)
|
||||||
if do_disconnect:
|
if do_disconnect:
|
||||||
reader.disconnect()
|
reader.disconnect()
|
||||||
break
|
if not remove_all:
|
||||||
|
break
|
||||||
else:
|
else:
|
||||||
if reader.streamhost is not None:
|
if reader.streamhost is not None:
|
||||||
reader.streamhost['state'] = -1
|
reader.streamhost['state'] = -1
|
||||||
del(self.readers[key])
|
del(self.readers[key])
|
||||||
break
|
if not remove_all:
|
||||||
|
break
|
||||||
def remove_sender(self, idx, do_disconnect=True):
|
|
||||||
|
def remove_sender(self, idx, do_disconnect=True, remove_all=False):
|
||||||
"""
|
"""
|
||||||
Remove sender from the list of senders and decrease the number of active
|
Remove sender from the list of senders and decrease the number of active
|
||||||
connections with 1
|
connections with 1
|
||||||
|
@ -447,13 +455,16 @@ class SocksQueue:
|
||||||
sender = self.senders[key]
|
sender = self.senders[key]
|
||||||
if do_disconnect:
|
if do_disconnect:
|
||||||
sender.disconnect()
|
sender.disconnect()
|
||||||
return
|
if not remove_all:
|
||||||
|
break
|
||||||
else:
|
else:
|
||||||
self.idlequeue.unplug_idle(sender.fd)
|
self.idlequeue.unplug_idle(sender.fd)
|
||||||
self.idlequeue.remove_timeout(sender.fd)
|
self.idlequeue.remove_timeout(sender.fd)
|
||||||
del(self.senders[key])
|
del(self.senders[key])
|
||||||
if self.connected > 0:
|
if self.connected > 0:
|
||||||
self.connected -= 1
|
self.connected -= 1
|
||||||
|
if not remove_all:
|
||||||
|
break
|
||||||
if len(self.senders) == 0 and self.listener is not None:
|
if len(self.senders) == 0 and self.listener is not None:
|
||||||
self.listener.disconnect()
|
self.listener.disconnect()
|
||||||
self.listener = None
|
self.listener = None
|
||||||
|
@ -483,6 +494,7 @@ class Socks5:
|
||||||
self.file = None
|
self.file = None
|
||||||
self.connected = False
|
self.connected = False
|
||||||
self.type = ''
|
self.type = ''
|
||||||
|
self.mode = ''
|
||||||
|
|
||||||
|
|
||||||
def _is_connected(self):
|
def _is_connected(self):
|
||||||
|
@ -796,6 +808,8 @@ class Socks5:
|
||||||
self.close_file()
|
self.close_file()
|
||||||
self.idlequeue.remove_timeout(self.fd)
|
self.idlequeue.remove_timeout(self.fd)
|
||||||
self.idlequeue.unplug_idle(self.fd)
|
self.idlequeue.unplug_idle(self.fd)
|
||||||
|
if self.mode == 'server':
|
||||||
|
self.queue.listener.disconnect()
|
||||||
try:
|
try:
|
||||||
self._sock.shutdown(socket.SHUT_RDWR)
|
self._sock.shutdown(socket.SHUT_RDWR)
|
||||||
self._sock.close()
|
self._sock.close()
|
||||||
|
|
|
@ -918,9 +918,10 @@ class Interface:
|
||||||
|
|
||||||
if file_props['type'] == 'r': # we receive a file
|
if file_props['type'] == 'r': # we receive a file
|
||||||
jid = unicode(file_props['sender'])
|
jid = unicode(file_props['sender'])
|
||||||
|
gajim.socks5queue.remove_receiver(file_props['sid'], True, True)
|
||||||
else: # we send a file
|
else: # we send a file
|
||||||
jid = unicode(file_props['receiver'])
|
jid = unicode(file_props['receiver'])
|
||||||
|
gajim.socks5queue.remove_sender(file_props['sid'], True, True)
|
||||||
# End jingle session
|
# End jingle session
|
||||||
if file_props.get('session-type') == 'jingle' and file_props['type'] ==\
|
if file_props.get('session-type') == 'jingle' and file_props['type'] ==\
|
||||||
'r':
|
'r':
|
||||||
|
@ -957,7 +958,7 @@ class Interface:
|
||||||
elif file_props['error'] in (-1, -6):
|
elif file_props['error'] in (-1, -6):
|
||||||
msg_type = 'file-stopped'
|
msg_type = 'file-stopped'
|
||||||
event_type = _('File Transfer Stopped')
|
event_type = _('File Transfer Stopped')
|
||||||
|
|
||||||
if event_type == '':
|
if event_type == '':
|
||||||
# FIXME: ugly workaround (this can happen Gajim sent, Gaim recvs)
|
# FIXME: ugly workaround (this can happen Gajim sent, Gaim recvs)
|
||||||
# this should never happen but it does. see process_result() in
|
# this should never happen but it does. see process_result() in
|
||||||
|
|
Loading…
Reference in New Issue