mirror of
https://github.com/onionshare/onionshare.git
synced 2024-12-27 16:29:41 -05:00
Revert the cancel feature that causes issues at least on macOS (#637)
This commit is contained in:
parent
9f0adc0fb9
commit
cff267c09c
@ -488,8 +488,8 @@ class Onion(object):
|
|||||||
auth_cookie = list(res.client_auth.values())[0]
|
auth_cookie = list(res.client_auth.values())[0]
|
||||||
self.auth_string = 'HidServAuth {} {}'.format(onion_host, auth_cookie)
|
self.auth_string = 'HidServAuth {} {}'.format(onion_host, auth_cookie)
|
||||||
|
|
||||||
if onion_host is not None:
|
|
||||||
self.settings.save()
|
self.settings.save()
|
||||||
|
if onion_host is not None:
|
||||||
return onion_host
|
return onion_host
|
||||||
else:
|
else:
|
||||||
raise TorErrorProtocolError(strings._('error_tor_protocol_error'))
|
raise TorErrorProtocolError(strings._('error_tor_protocol_error'))
|
||||||
@ -500,16 +500,10 @@ class Onion(object):
|
|||||||
"""
|
"""
|
||||||
common.log('Onion', 'cleanup')
|
common.log('Onion', 'cleanup')
|
||||||
|
|
||||||
# Cleanup the ephemeral onion services, if we have any
|
# Cleanup the ephemeral onion service
|
||||||
|
if self.service_id:
|
||||||
try:
|
try:
|
||||||
onions = self.c.list_ephemeral_hidden_services()
|
self.c.remove_ephemeral_hidden_service(self.service_id)
|
||||||
for onion in onions:
|
|
||||||
try:
|
|
||||||
common.log('Onion', 'cleanup', 'trying to remove onion {}'.format(onion))
|
|
||||||
self.c.remove_ephemeral_hidden_service(onion)
|
|
||||||
except:
|
|
||||||
common.log('Onion', 'cleanup', 'could not remove onion {}.. moving on anyway'.format(onion))
|
|
||||||
pass
|
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
self.service_id = None
|
self.service_id = None
|
||||||
|
@ -78,7 +78,6 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
self.server_status.server_stopped.connect(self.stop_server)
|
self.server_status.server_stopped.connect(self.stop_server)
|
||||||
self.server_status.server_stopped.connect(self.update_server_status_indicator)
|
self.server_status.server_stopped.connect(self.update_server_status_indicator)
|
||||||
self.server_status.server_stopped.connect(self.update_primary_action)
|
self.server_status.server_stopped.connect(self.update_primary_action)
|
||||||
self.server_status.server_canceled.connect(self.cancel_server)
|
|
||||||
self.start_server_finished.connect(self.clear_message)
|
self.start_server_finished.connect(self.clear_message)
|
||||||
self.start_server_finished.connect(self.server_status.start_server_finished)
|
self.start_server_finished.connect(self.server_status.start_server_finished)
|
||||||
self.start_server_finished.connect(self.update_server_status_indicator)
|
self.start_server_finished.connect(self.update_server_status_indicator)
|
||||||
@ -399,10 +398,9 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
# wait for modules in thread to load, preventing a thread-related cx_Freeze crash
|
# wait for modules in thread to load, preventing a thread-related cx_Freeze crash
|
||||||
time.sleep(0.2)
|
time.sleep(0.2)
|
||||||
|
|
||||||
common.log('OnionshareGui', 'start_server', 'Starting an onion thread')
|
t = threading.Thread(target=start_onion_service, kwargs={'self': self})
|
||||||
self.t = OnionThread(function=start_onion_service, kwargs={'self': self})
|
t.daemon = True
|
||||||
self.t.daemon = True
|
t.start()
|
||||||
self.t.start()
|
|
||||||
|
|
||||||
def start_server_step2(self):
|
def start_server_step2(self):
|
||||||
"""
|
"""
|
||||||
@ -485,14 +483,6 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
self._zip_progress_bar = None
|
self._zip_progress_bar = None
|
||||||
self.status_bar.clearMessage()
|
self.status_bar.clearMessage()
|
||||||
|
|
||||||
def cancel_server(self):
|
|
||||||
"""
|
|
||||||
Cancel the server while it is preparing to start
|
|
||||||
"""
|
|
||||||
if self.t:
|
|
||||||
self.t.terminate()
|
|
||||||
self.stop_server()
|
|
||||||
|
|
||||||
def stop_server(self):
|
def stop_server(self):
|
||||||
"""
|
"""
|
||||||
Stop the onionshare server.
|
Stop the onionshare server.
|
||||||
@ -787,26 +777,3 @@ class ZipProgressBar(QtWidgets.QProgressBar):
|
|||||||
self.setValue(100)
|
self.setValue(100)
|
||||||
else:
|
else:
|
||||||
self.setValue(0)
|
self.setValue(0)
|
||||||
|
|
||||||
|
|
||||||
class OnionThread(QtCore.QThread):
|
|
||||||
"""
|
|
||||||
A QThread for starting our Onion Service.
|
|
||||||
By using QThread rather than threading.Thread, we are able
|
|
||||||
to call quit() or terminate() on the startup if the user
|
|
||||||
decided to cancel (in which case do not proceed with obtaining
|
|
||||||
the Onion address and starting the web server).
|
|
||||||
"""
|
|
||||||
def __init__(self, function, kwargs=None):
|
|
||||||
super(OnionThread, self).__init__()
|
|
||||||
common.log('OnionThread', '__init__')
|
|
||||||
self.function = function
|
|
||||||
if not kwargs:
|
|
||||||
self.kwargs = {}
|
|
||||||
else:
|
|
||||||
self.kwargs = kwargs
|
|
||||||
|
|
||||||
def run(self):
|
|
||||||
common.log('OnionThread', 'run')
|
|
||||||
|
|
||||||
self.function(**self.kwargs)
|
|
||||||
|
@ -29,7 +29,6 @@ class ServerStatus(QtWidgets.QWidget):
|
|||||||
"""
|
"""
|
||||||
server_started = QtCore.pyqtSignal()
|
server_started = QtCore.pyqtSignal()
|
||||||
server_stopped = QtCore.pyqtSignal()
|
server_stopped = QtCore.pyqtSignal()
|
||||||
server_canceled = QtCore.pyqtSignal()
|
|
||||||
button_clicked = QtCore.pyqtSignal()
|
button_clicked = QtCore.pyqtSignal()
|
||||||
url_copied = QtCore.pyqtSignal()
|
url_copied = QtCore.pyqtSignal()
|
||||||
hidservauth_copied = QtCore.pyqtSignal()
|
hidservauth_copied = QtCore.pyqtSignal()
|
||||||
@ -191,7 +190,7 @@ class ServerStatus(QtWidgets.QWidget):
|
|||||||
self.server_button.setToolTip(strings._('gui_stop_server_shutdown_timeout_tooltip', True).format(self.timeout))
|
self.server_button.setToolTip(strings._('gui_stop_server_shutdown_timeout_tooltip', True).format(self.timeout))
|
||||||
elif self.status == self.STATUS_WORKING:
|
elif self.status == self.STATUS_WORKING:
|
||||||
self.server_button.setStyleSheet(button_working_style)
|
self.server_button.setStyleSheet(button_working_style)
|
||||||
self.server_button.setEnabled(True)
|
self.server_button.setEnabled(False)
|
||||||
self.server_button.setText(strings._('gui_please_wait'))
|
self.server_button.setText(strings._('gui_please_wait'))
|
||||||
if self.settings.get('shutdown_timeout'):
|
if self.settings.get('shutdown_timeout'):
|
||||||
self.shutdown_timeout_container.hide()
|
self.shutdown_timeout_container.hide()
|
||||||
@ -219,8 +218,6 @@ class ServerStatus(QtWidgets.QWidget):
|
|||||||
self.start_server()
|
self.start_server()
|
||||||
elif self.status == self.STATUS_STARTED:
|
elif self.status == self.STATUS_STARTED:
|
||||||
self.stop_server()
|
self.stop_server()
|
||||||
elif self.status == self.STATUS_WORKING:
|
|
||||||
self.cancel_server()
|
|
||||||
self.button_clicked.emit()
|
self.button_clicked.emit()
|
||||||
|
|
||||||
def start_server(self):
|
def start_server(self):
|
||||||
@ -248,16 +245,6 @@ class ServerStatus(QtWidgets.QWidget):
|
|||||||
self.update()
|
self.update()
|
||||||
self.server_stopped.emit()
|
self.server_stopped.emit()
|
||||||
|
|
||||||
def cancel_server(self):
|
|
||||||
"""
|
|
||||||
Cancel the server.
|
|
||||||
"""
|
|
||||||
common.log('ServerStatus', 'cancel_server', 'Canceling the server mid-startup')
|
|
||||||
self.status = self.STATUS_WORKING
|
|
||||||
self.shutdown_timeout_reset()
|
|
||||||
self.update()
|
|
||||||
self.server_canceled.emit()
|
|
||||||
|
|
||||||
def stop_server_finished(self):
|
def stop_server_finished(self):
|
||||||
"""
|
"""
|
||||||
The server has finished stopping.
|
The server has finished stopping.
|
||||||
|
@ -52,7 +52,7 @@
|
|||||||
"gui_copied_hidservauth": "The HidServAuth line has been copied to clipboard",
|
"gui_copied_hidservauth": "The HidServAuth line has been copied to clipboard",
|
||||||
"gui_starting_server1": "Starting Tor onion service...",
|
"gui_starting_server1": "Starting Tor onion service...",
|
||||||
"gui_starting_server2": "Crunching files...",
|
"gui_starting_server2": "Crunching files...",
|
||||||
"gui_please_wait": "Starting... Click to cancel",
|
"gui_please_wait": "Please wait...",
|
||||||
"error_hs_dir_cannot_create": "Cannot create onion service dir {0:s}",
|
"error_hs_dir_cannot_create": "Cannot create onion service dir {0:s}",
|
||||||
"error_hs_dir_not_writable": "onion service dir {0:s} is not writable",
|
"error_hs_dir_not_writable": "onion service dir {0:s} is not writable",
|
||||||
"using_ephemeral": "Starting ephemeral Tor onion service and awaiting publication",
|
"using_ephemeral": "Starting ephemeral Tor onion service and awaiting publication",
|
||||||
|
Loading…
Reference in New Issue
Block a user