mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-13 00:09:38 -05:00
Allow canceling share in Windows
This commit is contained in:
parent
64c7f4e5b8
commit
ead2825327
@ -33,7 +33,8 @@
|
||||
"gui_show_url_qr_code": "Show QR Code",
|
||||
"gui_qr_code_dialog_title": "OnionShare QR Code",
|
||||
"gui_waiting_to_start": "Scheduled to start in {}. Click to cancel.",
|
||||
"gui_please_wait": "Starting…",
|
||||
"gui_please_wait_no_button": "Starting…",
|
||||
"gui_please_wait": "Starting… Click to cancel.",
|
||||
"error_rate_limit": "Someone has made too many wrong attempts to guess your password, so OnionShare has stopped the server. Start sharing again and send the recipient a new address to share.",
|
||||
"zip_progress_bar_format": "Compressing: %p%",
|
||||
"gui_settings_window_title": "Settings",
|
||||
|
@ -158,9 +158,16 @@ class Mode(QtWidgets.QWidget):
|
||||
)
|
||||
)
|
||||
else:
|
||||
self.server_status.server_button.setText(
|
||||
strings._("gui_please_wait")
|
||||
)
|
||||
if self.common.platform == "Windows" or self.settings.get(
|
||||
"general", "autostart_timer"
|
||||
):
|
||||
self.server_status.server_button.setText(
|
||||
strings._("gui_please_wait")
|
||||
)
|
||||
else:
|
||||
self.server_status.server_button.setText(
|
||||
strings._("gui_please_wait_no_button")
|
||||
)
|
||||
|
||||
# If the auto-stop timer has stopped, stop the server
|
||||
if self.server_status.status == ServerStatus.STATUS_STARTED:
|
||||
@ -354,6 +361,19 @@ class Mode(QtWidgets.QWidget):
|
||||
self.app.onion.scheduled_key = None
|
||||
self.app.onion.scheduled_auth_cookie = None
|
||||
self.startup_thread.quit()
|
||||
|
||||
# Canceling only works in Windows
|
||||
# https://github.com/micahflee/onionshare/issues/1371
|
||||
if self.common.platform == "Windows":
|
||||
if self.onion_thread:
|
||||
self.common.log("Mode", "cancel_server: quitting onion thread")
|
||||
self.onion_thread.terminate()
|
||||
self.onion_thread.wait()
|
||||
if self.web_thread:
|
||||
self.common.log("Mode", "cancel_server: quitting web thread")
|
||||
self.web_thread.terminate()
|
||||
self.web_thread.wait()
|
||||
|
||||
self.stop_server()
|
||||
|
||||
def cancel_server_custom(self):
|
||||
|
@ -306,13 +306,18 @@ class ServerStatus(QtWidgets.QWidget):
|
||||
)
|
||||
)
|
||||
else:
|
||||
self.server_button.setText(strings._("gui_please_wait"))
|
||||
if self.common.platform == "Windows":
|
||||
self.server_button.setText(strings._("gui_please_wait"))
|
||||
else:
|
||||
self.server_button.setText(
|
||||
strings._("gui_please_wait_no_button")
|
||||
)
|
||||
else:
|
||||
self.server_button.setStyleSheet(
|
||||
self.common.gui.css["server_status_button_working"]
|
||||
)
|
||||
self.server_button.setEnabled(False)
|
||||
self.server_button.setText(strings._("gui_please_wait"))
|
||||
self.server_button.setText(strings._("gui_please_wait_no_button"))
|
||||
|
||||
def server_button_clicked(self):
|
||||
"""
|
||||
@ -379,7 +384,10 @@ class ServerStatus(QtWidgets.QWidget):
|
||||
self.start_server()
|
||||
elif self.status == self.STATUS_STARTED:
|
||||
self.stop_server()
|
||||
elif self.status == self.STATUS_WORKING and self.settings.get("general", "autostart_timer"):
|
||||
elif self.status == self.STATUS_WORKING and (
|
||||
self.common.platform == "Windows"
|
||||
or self.settings.get("general", "autostart_timer")
|
||||
):
|
||||
self.cancel_server()
|
||||
self.button_clicked.emit()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user