mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-16 17:57:30 -05:00
Make onionshare GUI use separate thread for starting onion service with await_publication=True, to avoid non-responsive window
This commit is contained in:
parent
b7d1a7339c
commit
590edc5d6d
@ -58,6 +58,8 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
start_server_finished = QtCore.pyqtSignal()
|
start_server_finished = QtCore.pyqtSignal()
|
||||||
stop_server_finished = QtCore.pyqtSignal()
|
stop_server_finished = QtCore.pyqtSignal()
|
||||||
starting_server_step2 = QtCore.pyqtSignal()
|
starting_server_step2 = QtCore.pyqtSignal()
|
||||||
|
starting_server_step3 = QtCore.pyqtSignal()
|
||||||
|
starting_server_error = QtCore.pyqtSignal(str)
|
||||||
|
|
||||||
def __init__(self, qtapp, app):
|
def __init__(self, qtapp, app):
|
||||||
super(OnionShareGui, self).__init__()
|
super(OnionShareGui, self).__init__()
|
||||||
@ -90,6 +92,8 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
self.file_selection.file_list.files_updated.connect(self.server_status.update)
|
self.file_selection.file_list.files_updated.connect(self.server_status.update)
|
||||||
self.server_status.url_copied.connect(self.copy_url)
|
self.server_status.url_copied.connect(self.copy_url)
|
||||||
self.starting_server_step2.connect(self.start_server_step2)
|
self.starting_server_step2.connect(self.start_server_step2)
|
||||||
|
self.starting_server_step3.connect(self.start_server_step3)
|
||||||
|
self.starting_server_error.connect(self.start_server_error)
|
||||||
|
|
||||||
# filesize warning
|
# filesize warning
|
||||||
self.filesize_warning = QtWidgets.QLabel()
|
self.filesize_warning = QtWidgets.QLabel()
|
||||||
@ -127,16 +131,6 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
self.timer.timeout.connect(self.check_for_requests)
|
self.timer.timeout.connect(self.check_for_requests)
|
||||||
self.timer.start(500)
|
self.timer.start(500)
|
||||||
|
|
||||||
def start_server_step2(self):
|
|
||||||
"""
|
|
||||||
Step 2 in starting the onionshare server. This displays the large filesize
|
|
||||||
warning, if applicable.
|
|
||||||
"""
|
|
||||||
# warn about sending large files over Tor
|
|
||||||
if web.zip_filesize >= 157286400: # 150mb
|
|
||||||
self.filesize_warning.setText(strings._("large_filesize", True))
|
|
||||||
self.filesize_warning.show()
|
|
||||||
|
|
||||||
def start_server(self):
|
def start_server(self):
|
||||||
"""
|
"""
|
||||||
Start the onionshare server. This uses multiple threads to start the Tor onion
|
Start the onionshare server. This uses multiple threads to start the Tor onion
|
||||||
@ -146,28 +140,39 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
web.download_count = 0
|
web.download_count = 0
|
||||||
web.error404_count = 0
|
web.error404_count = 0
|
||||||
|
|
||||||
# start the onion service
|
# pick an available local port for the http service to listen on
|
||||||
self.status_bar.showMessage(strings._('gui_starting_server1', True))
|
|
||||||
self.app.choose_port()
|
self.app.choose_port()
|
||||||
|
|
||||||
|
# start the onion service in a new thread
|
||||||
|
def start_onion_service(self):
|
||||||
|
self.status_bar.showMessage(strings._('gui_starting_server1', True))
|
||||||
try:
|
try:
|
||||||
self.app.start_onion_service()
|
self.app.start_onion_service()
|
||||||
|
self.starting_server_step2.emit()
|
||||||
|
|
||||||
except onionshare.onion.NoTor as e:
|
except onionshare.onion.NoTor as e:
|
||||||
alert(e.args[0], QtWidgets.QMessageBox.Warning)
|
self.starting_server_error.emit(e.args[0])
|
||||||
self.server_status.stop_server()
|
|
||||||
self.status_bar.clearMessage()
|
|
||||||
return
|
return
|
||||||
|
|
||||||
# start onionshare http service in new thread
|
t1 = threading.Thread(target=start_onion_service, kwargs={'self': self})
|
||||||
t = threading.Thread(target=web.start, args=(self.app.port, self.app.stay_open, self.app.transparent_torification))
|
t1.daemon = True
|
||||||
t.daemon = True
|
t1.start()
|
||||||
t.start()
|
|
||||||
|
|
||||||
|
# start onionshare http service in new thread
|
||||||
|
t2 = threading.Thread(target=web.start, args=(self.app.port, self.app.stay_open, self.app.transparent_torification))
|
||||||
|
t2.daemon = True
|
||||||
|
t2.start()
|
||||||
|
|
||||||
|
def start_server_step2(self):
|
||||||
|
"""
|
||||||
|
Step 2 in starting the onionshare server. Prepare files for serving.
|
||||||
|
"""
|
||||||
# prepare the files for sending in a new thread
|
# prepare the files for sending in a new thread
|
||||||
def finish_starting_server(self):
|
def finish_starting_server(self):
|
||||||
# prepare files to share
|
# prepare files to share
|
||||||
web.set_file_info(self.file_selection.file_list.filenames)
|
web.set_file_info(self.file_selection.file_list.filenames)
|
||||||
self.app.cleanup_filenames.append(web.zip_filename)
|
self.app.cleanup_filenames.append(web.zip_filename)
|
||||||
self.starting_server_step2.emit()
|
self.starting_server_step3.emit()
|
||||||
|
|
||||||
# wait for hs
|
# wait for hs
|
||||||
if not self.app.local_only and not self.app.onion.supports_ephemeral:
|
if not self.app.local_only and not self.app.onion.supports_ephemeral:
|
||||||
@ -182,6 +187,24 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
t.daemon = True
|
t.daemon = True
|
||||||
t.start()
|
t.start()
|
||||||
|
|
||||||
|
def start_server_step3(self):
|
||||||
|
"""
|
||||||
|
Step 3 in starting the onionshare server. This displays the large filesize
|
||||||
|
warning, if applicable.
|
||||||
|
"""
|
||||||
|
# warn about sending large files over Tor
|
||||||
|
if web.zip_filesize >= 157286400: # 150mb
|
||||||
|
self.filesize_warning.setText(strings._("large_filesize", True))
|
||||||
|
self.filesize_warning.show()
|
||||||
|
|
||||||
|
def start_server_error(self, error):
|
||||||
|
"""
|
||||||
|
If there's an error when trying to start the onion service
|
||||||
|
"""
|
||||||
|
alert(error, QtWidgets.QMessageBox.Warning)
|
||||||
|
self.server_status.stop_server()
|
||||||
|
self.status_bar.clearMessage()
|
||||||
|
|
||||||
def stop_server(self):
|
def stop_server(self):
|
||||||
"""
|
"""
|
||||||
Stop the onionshare server.
|
Stop the onionshare server.
|
||||||
|
Loading…
Reference in New Issue
Block a user