fix sending multiple files at the same time
This commit is contained in:
parent
952ea6a9b6
commit
b85f96b929
|
@ -373,6 +373,9 @@ class JingleFileTransfer(JingleContent):
|
||||||
|
|
||||||
def start_transfer(self):
|
def start_transfer(self):
|
||||||
|
|
||||||
|
# We start the transfer, session negociation is over.
|
||||||
|
self.session.state = 0 # STATE 0 SESSION_ENDED
|
||||||
|
|
||||||
self.state = STATE_TRANSFERING
|
self.state = STATE_TRANSFERING
|
||||||
|
|
||||||
# It tells wether we start the transfer as client or server
|
# It tells wether we start the transfer as client or server
|
||||||
|
|
|
@ -243,10 +243,15 @@ class JingleSession(object):
|
||||||
elif content and self.weinitiate:
|
elif content and self.weinitiate:
|
||||||
self.__content_accept(content)
|
self.__content_accept(content)
|
||||||
elif self.state == JingleStates.active:
|
elif self.state == JingleStates.active:
|
||||||
# We can either send a content-add or a content-accept
|
# We can either send a content-add or a content-accept. However, if
|
||||||
|
# we are sending a file we can only use session_initiate.
|
||||||
if not content:
|
if not content:
|
||||||
return
|
return
|
||||||
if (content.creator == 'initiator') == self.weinitiate:
|
we_created_content = (content.creator == 'initiator') \
|
||||||
|
== self.weinitiate
|
||||||
|
if we_created_content and content.media == 'file':
|
||||||
|
self.__session_initiate()
|
||||||
|
if we_created_content:
|
||||||
# We initiated this content. It's a pending content-add.
|
# We initiated this content. It's a pending content-add.
|
||||||
self.__content_add(content)
|
self.__content_add(content)
|
||||||
else:
|
else:
|
||||||
|
@ -694,7 +699,6 @@ class JingleSession(object):
|
||||||
self.connection.connection.send(stanza)
|
self.connection.connection.send(stanza)
|
||||||
|
|
||||||
def _session_terminate(self, reason=None):
|
def _session_terminate(self, reason=None):
|
||||||
assert self.state != JingleStates.ended
|
|
||||||
stanza, jingle = self.__make_jingle('session-terminate', reason=reason)
|
stanza, jingle = self.__make_jingle('session-terminate', reason=reason)
|
||||||
self.__broadcast_all(stanza, jingle, None, 'session-terminate-sent')
|
self.__broadcast_all(stanza, jingle, None, 'session-terminate-sent')
|
||||||
if self.connection.connection and self.connection.connected >= 2:
|
if self.connection.connection and self.connection.connected >= 2:
|
||||||
|
|
|
@ -93,6 +93,7 @@ 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 or self.listener.connections == []:
|
||||||
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
|
||||||
|
@ -104,6 +105,10 @@ class SocksQueue:
|
||||||
_('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
|
||||||
|
else:
|
||||||
|
# There is already a listener, we update the file's information
|
||||||
|
# on the new connection.
|
||||||
|
self.listener.file_props = fp
|
||||||
|
|
||||||
self.connected += 1
|
self.connected += 1
|
||||||
return self.listener
|
return self.listener
|
||||||
|
@ -724,6 +729,7 @@ class Socks5:
|
||||||
"""
|
"""
|
||||||
Read file contents from socket and write them to file
|
Read file contents from socket and write them to file
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if self.file_props is None or ('file-name' in self.file_props) is False:
|
if self.file_props is None or ('file-name' in self.file_props) is False:
|
||||||
self.file_props['error'] = -2
|
self.file_props['error'] = -2
|
||||||
return None
|
return None
|
||||||
|
@ -773,14 +779,14 @@ class Socks5:
|
||||||
# Transfer stopped somehow:
|
# Transfer stopped somehow:
|
||||||
# reset, paused or network error
|
# reset, paused or network error
|
||||||
self.rem_fd(fd)
|
self.rem_fd(fd)
|
||||||
self.disconnect(False)
|
self.disconnect()
|
||||||
self.file_props['error'] = -1
|
self.file_props['error'] = -1
|
||||||
return 0
|
return 0
|
||||||
try:
|
try:
|
||||||
fd.write(buff)
|
fd.write(buff)
|
||||||
except IOError, e:
|
except IOError, e:
|
||||||
self.rem_fd(fd)
|
self.rem_fd(fd)
|
||||||
self.disconnect(False)
|
self.disconnect()
|
||||||
self.file_props['error'] = -6 # file system error
|
self.file_props['error'] = -6 # file system error
|
||||||
return 0
|
return 0
|
||||||
if self.file_props['received-len'] >= int(self.file_props['size']):
|
if self.file_props['received-len'] >= int(self.file_props['size']):
|
||||||
|
@ -809,6 +815,11 @@ class Socks5:
|
||||||
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':
|
if self.mode == 'server':
|
||||||
|
try:
|
||||||
|
self.queue.listener.connections.remove(self._sock)
|
||||||
|
except ValueError:
|
||||||
|
pass # Not in list
|
||||||
|
if self.queue.listener.connections == []:
|
||||||
self.queue.listener.disconnect()
|
self.queue.listener.disconnect()
|
||||||
try:
|
try:
|
||||||
self._sock.shutdown(socket.SHUT_RDWR)
|
self._sock.shutdown(socket.SHUT_RDWR)
|
||||||
|
@ -1127,6 +1138,7 @@ class Socks5Server(Socks5):
|
||||||
|
|
||||||
|
|
||||||
def pollin(self):
|
def pollin(self):
|
||||||
|
self.idlequeue.remove_timeout(self.fd)
|
||||||
if self.connected:
|
if self.connected:
|
||||||
try:
|
try:
|
||||||
if self.state < 5:
|
if self.state < 5:
|
||||||
|
@ -1426,6 +1438,7 @@ class Socks5Listener(IdleObject):
|
||||||
self.fd = -1
|
self.fd = -1
|
||||||
self.fingerprint = fingerprint
|
self.fingerprint = fingerprint
|
||||||
self.file_props = fp
|
self.file_props = fp
|
||||||
|
self.connections = []
|
||||||
|
|
||||||
def bind(self):
|
def bind(self):
|
||||||
for ai in self.ais:
|
for ai in self.ais:
|
||||||
|
@ -1501,6 +1514,7 @@ class Socks5Listener(IdleObject):
|
||||||
"""
|
"""
|
||||||
_sock = self._serv.accept()
|
_sock = self._serv.accept()
|
||||||
_sock[0].setblocking(False)
|
_sock[0].setblocking(False)
|
||||||
|
self.connections.append(_sock[0])
|
||||||
return _sock
|
return _sock
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue