file resuming across restarts (partial)
This commit is contained in:
parent
b0e82dfd08
commit
99e8691f0b
3 changed files with 43 additions and 12 deletions
|
@ -76,6 +76,9 @@ class FileTransfer(QtCore.QObject):
|
||||||
def get_friend_number(self):
|
def get_friend_number(self):
|
||||||
return self._friend_number
|
return self._friend_number
|
||||||
|
|
||||||
|
def get_path(self):
|
||||||
|
return self._path
|
||||||
|
|
||||||
def cancel(self):
|
def cancel(self):
|
||||||
self.send_control(TOX_FILE_CONTROL['CANCEL'])
|
self.send_control(TOX_FILE_CONTROL['CANCEL'])
|
||||||
if hasattr(self, '_file'):
|
if hasattr(self, '_file'):
|
||||||
|
@ -224,7 +227,6 @@ class ReceiveTransfer(FileTransfer):
|
||||||
if data is None:
|
if data is None:
|
||||||
self._file.close()
|
self._file.close()
|
||||||
self.state = TOX_FILE_TRANSFER_STATE['FINISHED']
|
self.state = TOX_FILE_TRANSFER_STATE['FINISHED']
|
||||||
self.signal()
|
|
||||||
else:
|
else:
|
||||||
data = bytearray(data)
|
data = bytearray(data)
|
||||||
if self._file_size < position:
|
if self._file_size < position:
|
||||||
|
@ -236,7 +238,7 @@ class ReceiveTransfer(FileTransfer):
|
||||||
if position + l > self._file_size:
|
if position + l > self._file_size:
|
||||||
self._file_size = position + l
|
self._file_size = position + l
|
||||||
self._done += l
|
self._done += l
|
||||||
self.signal()
|
self.signal()
|
||||||
|
|
||||||
|
|
||||||
class ReceiveToBuffer(FileTransfer):
|
class ReceiveToBuffer(FileTransfer):
|
||||||
|
|
|
@ -43,6 +43,7 @@ class Profile(contact.Contact, Singleton):
|
||||||
self._show_online = settings['show_online_friends']
|
self._show_online = settings['show_online_friends']
|
||||||
self._show_avatars = settings['show_avatars']
|
self._show_avatars = settings['show_avatars']
|
||||||
self._friend_item_height = 40 if settings['compact_mode'] else 70
|
self._friend_item_height = 40 if settings['compact_mode'] else 70
|
||||||
|
self._paused_file_transfers = settings['paused_file_transfers']
|
||||||
screen.online_contacts.setCurrentIndex(int(self._show_online))
|
screen.online_contacts.setCurrentIndex(int(self._show_online))
|
||||||
aliases = settings['friends_aliases']
|
aliases = settings['friends_aliases']
|
||||||
data = tox.self_get_friend_list()
|
data = tox.self_get_friend_list()
|
||||||
|
@ -286,6 +287,11 @@ class Profile(contact.Contact, Singleton):
|
||||||
else:
|
else:
|
||||||
self.send_file(data[0], friend_number, True)
|
self.send_file(data[0], friend_number, True)
|
||||||
friend.clear_unsent_files()
|
friend.clear_unsent_files()
|
||||||
|
for key in self._paused_file_transfers:
|
||||||
|
data = self._paused_file_transfers[key]
|
||||||
|
if data[1] == friend_number and not data[2]:
|
||||||
|
self.send_file(data[0], friend_number, True, key)
|
||||||
|
del self._paused_file_transfers[key]
|
||||||
if friend_number == self.get_active_number():
|
if friend_number == self.get_active_number():
|
||||||
self.update()
|
self.update()
|
||||||
except Exception as ex:
|
except Exception as ex:
|
||||||
|
@ -295,11 +301,19 @@ class Profile(contact.Contact, Singleton):
|
||||||
"""
|
"""
|
||||||
Friend with specified number quit
|
Friend with specified number quit
|
||||||
"""
|
"""
|
||||||
# TODO: fix and add full file resuming support
|
|
||||||
self.get_friend_by_number(friend_number).status = None
|
self.get_friend_by_number(friend_number).status = None
|
||||||
self.friend_typing(friend_number, False)
|
self.friend_typing(friend_number, False)
|
||||||
if friend_number in self._call:
|
if friend_number in self._call:
|
||||||
self._call.finish_call(friend_number, True)
|
self._call.finish_call(friend_number, True)
|
||||||
|
for friend_num, file_num in list(self._file_transfers.keys()):
|
||||||
|
if friend_num == friend_number:
|
||||||
|
ft = self._file_transfers[(friend_num, file_num)]
|
||||||
|
if type(ft) is SendTransfer:
|
||||||
|
self._paused_file_transfers[ft.get_file_id()] = [ft.get_path(), friend_num, False]
|
||||||
|
elif type(ft) is ReceiveTransfer:
|
||||||
|
self._paused_file_transfers[ft.get_file_id()] = [ft.get_path(), friend_num, True]
|
||||||
|
ft.cancelled()
|
||||||
|
del self._file_transfers[(friend_num, file_num)]
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Typing notifications
|
# Typing notifications
|
||||||
|
@ -832,6 +846,9 @@ class Profile(contact.Contact, Singleton):
|
||||||
del self._call
|
del self._call
|
||||||
for i in range(len(self._friends)):
|
for i in range(len(self._friends)):
|
||||||
del self._friends[0]
|
del self._friends[0]
|
||||||
|
settings = Settings.get_instance()
|
||||||
|
settings['paused_file_transfers'] = self._paused_file_transfers
|
||||||
|
settings.save()
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# File transfers support
|
# File transfers support
|
||||||
|
@ -849,7 +866,20 @@ class Profile(contact.Contact, Singleton):
|
||||||
friend = self.get_friend_by_number(friend_number)
|
friend = self.get_friend_by_number(friend_number)
|
||||||
auto = settings['allow_auto_accept'] and friend.tox_id in settings['auto_accept_from_friends']
|
auto = settings['allow_auto_accept'] and friend.tox_id in settings['auto_accept_from_friends']
|
||||||
inline = (file_name in ALLOWED_FILES) and settings['allow_inline']
|
inline = (file_name in ALLOWED_FILES) and settings['allow_inline']
|
||||||
if inline and size < 1024 * 1024:
|
file_id = self._tox.file_get_file_id(friend_number, file_number)
|
||||||
|
accepted = True
|
||||||
|
if file_id in self._paused_file_transfers:
|
||||||
|
data = self._paused_file_transfers[file_id]
|
||||||
|
# TODO: check size of file and send seek control
|
||||||
|
self.accept_transfer(None, data[0], friend_number, file_number, size)
|
||||||
|
tm = TransferMessage(MESSAGE_OWNER['FRIEND'],
|
||||||
|
time.time(),
|
||||||
|
TOX_FILE_TRANSFER_STATE['RUNNING'],
|
||||||
|
size,
|
||||||
|
file_name,
|
||||||
|
friend_number,
|
||||||
|
file_number)
|
||||||
|
elif inline and size < 1024 * 1024:
|
||||||
self.accept_transfer(None, '', friend_number, file_number, size, True)
|
self.accept_transfer(None, '', friend_number, file_number, size, True)
|
||||||
tm = TransferMessage(MESSAGE_OWNER['FRIEND'],
|
tm = TransferMessage(MESSAGE_OWNER['FRIEND'],
|
||||||
time.time(),
|
time.time(),
|
||||||
|
@ -877,9 +907,10 @@ class Profile(contact.Contact, Singleton):
|
||||||
file_name,
|
file_name,
|
||||||
friend_number,
|
friend_number,
|
||||||
file_number)
|
file_number)
|
||||||
|
accepted = False
|
||||||
if friend_number == self.get_active_number():
|
if friend_number == self.get_active_number():
|
||||||
item = self.create_file_transfer_item(tm)
|
item = self.create_file_transfer_item(tm)
|
||||||
if (inline and size < 1024 * 1024) or auto:
|
if accepted:
|
||||||
self._file_transfers[(friend_number, file_number)].set_state_changed_handler(item.update)
|
self._file_transfers[(friend_number, file_number)].set_state_changed_handler(item.update)
|
||||||
self._messages.scrollToBottom()
|
self._messages.scrollToBottom()
|
||||||
else:
|
else:
|
||||||
|
@ -933,15 +964,11 @@ class Profile(contact.Contact, Singleton):
|
||||||
"""
|
"""
|
||||||
self.get_friend_by_number(friend_number).update_transfer_data(file_number,
|
self.get_friend_by_number(friend_number).update_transfer_data(file_number,
|
||||||
TOX_FILE_TRANSFER_STATE['RUNNING'])
|
TOX_FILE_TRANSFER_STATE['RUNNING'])
|
||||||
# if (friend_number, file_number) not in self._file_transfers:
|
|
||||||
# print self._file_transfers
|
|
||||||
# print (friend_number, file_number)
|
|
||||||
# return
|
|
||||||
tr = self._file_transfers[(friend_number, file_number)]
|
tr = self._file_transfers[(friend_number, file_number)]
|
||||||
if by_friend:
|
if by_friend:
|
||||||
tr.state = TOX_FILE_TRANSFER_STATE['RUNNING']
|
tr.state = TOX_FILE_TRANSFER_STATE['RUNNING']
|
||||||
tr.signal()
|
tr.signal()
|
||||||
else: # send seek control?
|
else:
|
||||||
tr.send_control(TOX_FILE_CONTROL['RESUME'])
|
tr.send_control(TOX_FILE_CONTROL['RESUME'])
|
||||||
|
|
||||||
def accept_transfer(self, item, path, friend_number, file_number, size, inline=False):
|
def accept_transfer(self, item, path, friend_number, file_number, size, inline=False):
|
||||||
|
@ -1011,12 +1038,13 @@ class Profile(contact.Contact, Singleton):
|
||||||
st.set_state_changed_handler(item.update)
|
st.set_state_changed_handler(item.update)
|
||||||
self._messages.scrollToBottom()
|
self._messages.scrollToBottom()
|
||||||
|
|
||||||
def send_file(self, path, number=None, is_resend=False):
|
def send_file(self, path, number=None, is_resend=False, file_id=None):
|
||||||
"""
|
"""
|
||||||
Send file to current active friend
|
Send file to current active friend
|
||||||
:param path: file path
|
:param path: file path
|
||||||
:param number: friend_number
|
:param number: friend_number
|
||||||
:param is_resend: is 'offline' message
|
:param is_resend: is 'offline' message
|
||||||
|
:param file_id: file id of transfer
|
||||||
"""
|
"""
|
||||||
friend_number = number or self.get_active_number()
|
friend_number = number or self.get_active_number()
|
||||||
friend = self.get_friend_by_number(friend_number)
|
friend = self.get_friend_by_number(friend_number)
|
||||||
|
@ -1028,7 +1056,7 @@ class Profile(contact.Contact, Singleton):
|
||||||
elif friend.status is None and is_resend:
|
elif friend.status is None and is_resend:
|
||||||
print('Error in sending')
|
print('Error in sending')
|
||||||
raise RuntimeError()
|
raise RuntimeError()
|
||||||
st = SendTransfer(path, self._tox, friend_number)
|
st = SendTransfer(path, self._tox, friend_number, TOX_FILE_KIND['DATA'], file_id)
|
||||||
self._file_transfers[(friend_number, st.get_file_number())] = st
|
self._file_transfers[(friend_number, st.get_file_number())] = st
|
||||||
tm = TransferMessage(MESSAGE_OWNER['ME'],
|
tm = TransferMessage(MESSAGE_OWNER['ME'],
|
||||||
time.time(),
|
time.time(),
|
||||||
|
|
|
@ -117,6 +117,7 @@ class Settings(dict, Singleton):
|
||||||
'auto_accept_path': None,
|
'auto_accept_path': None,
|
||||||
'show_online_friends': False,
|
'show_online_friends': False,
|
||||||
'auto_accept_from_friends': [],
|
'auto_accept_from_friends': [],
|
||||||
|
'paused_file_transfers': {},
|
||||||
'friends_aliases': [],
|
'friends_aliases': [],
|
||||||
'show_avatars': False,
|
'show_avatars': False,
|
||||||
'typing_notifications': False,
|
'typing_notifications': False,
|
||||||
|
|
Loading…
Reference in a new issue