2017-04-18 00:26:35 -03:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
OnionShare | https://onionshare.org/
|
|
|
|
|
2018-04-24 14:07:59 -03:00
|
|
|
Copyright (C) 2014-2018 Micah Lee <micah@micahflee.com>
|
2017-04-18 00:26:35 -03:00
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
"""
|
|
|
|
from PyQt5 import QtCore, QtWidgets, QtGui
|
|
|
|
|
2018-03-08 15:18:31 -03:00
|
|
|
from onionshare import strings
|
2017-04-18 00:49:50 -03:00
|
|
|
from onionshare.onion import *
|
2017-04-18 00:26:35 -03:00
|
|
|
|
2018-04-25 12:43:40 -03:00
|
|
|
from .widgets import Alert
|
2017-05-14 21:46:54 -04:00
|
|
|
|
2017-04-18 00:26:35 -03:00
|
|
|
class TorConnectionDialog(QtWidgets.QProgressDialog):
|
|
|
|
"""
|
|
|
|
Connecting to Tor dialog.
|
|
|
|
"""
|
2017-05-14 21:46:54 -04:00
|
|
|
open_settings = QtCore.pyqtSignal()
|
|
|
|
|
2018-03-13 07:28:47 -03:00
|
|
|
def __init__(self, common, qtapp, onion, custom_settings=False):
|
2017-04-18 00:26:35 -03:00
|
|
|
super(TorConnectionDialog, self).__init__(None)
|
2018-03-08 15:18:31 -03:00
|
|
|
|
|
|
|
self.common = common
|
|
|
|
|
2018-03-13 07:28:47 -03:00
|
|
|
if custom_settings:
|
|
|
|
self.settings = custom_settings
|
|
|
|
else:
|
|
|
|
self.settings = self.common.settings
|
|
|
|
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionDialog', '__init__')
|
2017-05-16 14:31:52 -04:00
|
|
|
|
2017-05-16 16:09:27 -04:00
|
|
|
self.qtapp = qtapp
|
2017-04-18 00:49:50 -03:00
|
|
|
self.onion = onion
|
2017-04-18 00:26:35 -03:00
|
|
|
|
2017-05-16 20:30:54 -04:00
|
|
|
self.setWindowTitle("OnionShare")
|
2018-03-08 15:18:31 -03:00
|
|
|
self.setWindowIcon(QtGui.QIcon(self.common.get_resource_path('images/logo.png')))
|
2017-04-18 00:26:35 -03:00
|
|
|
self.setModal(True)
|
2017-05-14 20:27:05 -04:00
|
|
|
self.setFixedSize(400, 150)
|
2017-04-18 00:26:35 -03:00
|
|
|
|
|
|
|
# Label
|
2018-09-30 21:47:10 -03:00
|
|
|
self.setLabelText(strings._('connecting_to_tor'))
|
2017-04-18 00:26:35 -03:00
|
|
|
|
|
|
|
# Progress bar ticks from 0 to 100
|
|
|
|
self.setRange(0, 100)
|
2017-04-18 00:49:50 -03:00
|
|
|
# Don't show if connection takes less than 100ms (for non-bundled tor)
|
|
|
|
self.setMinimumDuration(100)
|
2017-04-18 00:26:35 -03:00
|
|
|
|
2017-05-16 14:44:34 -04:00
|
|
|
# Start displaying the status at 0
|
2017-05-16 16:09:27 -04:00
|
|
|
self._tor_status_update(0, '')
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-04-18 00:49:50 -03:00
|
|
|
def start(self):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionDialog', 'start')
|
2017-05-16 14:31:52 -04:00
|
|
|
|
2018-03-13 07:28:47 -03:00
|
|
|
t = TorConnectionThread(self.common, self.settings, self, self.onion)
|
2018-01-14 03:42:27 -03:00
|
|
|
t.tor_status_update.connect(self._tor_status_update)
|
|
|
|
t.connected_to_tor.connect(self._connected_to_tor)
|
|
|
|
t.canceled_connecting_to_tor.connect(self._canceled_connecting_to_tor)
|
|
|
|
t.error_connecting_to_tor.connect(self._error_connecting_to_tor)
|
|
|
|
t.start()
|
|
|
|
|
|
|
|
# The main thread needs to remain active, and checking for Qt events,
|
2017-05-16 16:09:27 -04:00
|
|
|
# until the thread is finished. Otherwise it won't be able to handle
|
|
|
|
# accepting signals.
|
|
|
|
self.active = True
|
|
|
|
while self.active:
|
|
|
|
time.sleep(0.1)
|
|
|
|
self.qtapp.processEvents()
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 16:09:27 -04:00
|
|
|
def _tor_status_update(self, progress, summary):
|
2017-05-16 14:44:34 -04:00
|
|
|
self.setValue(int(progress))
|
2018-09-30 21:47:10 -03:00
|
|
|
self.setLabelText("<strong>{}</strong><br>{}".format(strings._('connecting_to_tor'), summary))
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 16:09:27 -04:00
|
|
|
def _connected_to_tor(self):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionDialog', '_connected_to_tor')
|
2017-05-16 16:09:27 -04:00
|
|
|
self.active = False
|
2017-05-16 14:44:34 -04:00
|
|
|
|
|
|
|
# Close the dialog after connecting
|
|
|
|
self.setValue(self.maximum())
|
|
|
|
|
2017-05-16 16:09:27 -04:00
|
|
|
def _canceled_connecting_to_tor(self):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionDialog', '_canceled_connecting_to_tor')
|
2017-05-16 16:09:27 -04:00
|
|
|
self.active = False
|
2017-12-21 00:08:13 -03:00
|
|
|
self.onion.cleanup()
|
2017-05-16 14:44:34 -04:00
|
|
|
|
|
|
|
# Cancel connecting to Tor
|
2017-05-16 19:50:33 -04:00
|
|
|
QtCore.QTimer.singleShot(1, self.cancel)
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 16:09:27 -04:00
|
|
|
def _error_connecting_to_tor(self, msg):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionDialog', '_error_connecting_to_tor')
|
2017-05-16 16:09:27 -04:00
|
|
|
self.active = False
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 19:50:33 -04:00
|
|
|
def alert_and_open_settings():
|
|
|
|
# Display the exception in an alert box
|
2018-09-30 21:47:10 -03:00
|
|
|
Alert(self.common, "{}\n\n{}".format(msg, strings._('gui_tor_connection_error_settings')), QtWidgets.QMessageBox.Warning)
|
2017-05-16 19:50:33 -04:00
|
|
|
|
|
|
|
# Open settings
|
|
|
|
self.open_settings.emit()
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 19:50:33 -04:00
|
|
|
QtCore.QTimer.singleShot(1, alert_and_open_settings)
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2017-05-16 19:50:33 -04:00
|
|
|
# Cancel connecting to Tor
|
|
|
|
QtCore.QTimer.singleShot(1, self.cancel)
|
2017-05-16 14:44:34 -04:00
|
|
|
|
|
|
|
class TorConnectionThread(QtCore.QThread):
|
|
|
|
tor_status_update = QtCore.pyqtSignal(str, str)
|
|
|
|
connected_to_tor = QtCore.pyqtSignal()
|
|
|
|
canceled_connecting_to_tor = QtCore.pyqtSignal()
|
2017-05-16 14:50:13 -04:00
|
|
|
error_connecting_to_tor = QtCore.pyqtSignal(str)
|
2017-05-16 14:44:34 -04:00
|
|
|
|
2018-03-13 07:28:47 -03:00
|
|
|
def __init__(self, common, settings, dialog, onion):
|
2017-05-16 14:44:34 -04:00
|
|
|
super(TorConnectionThread, self).__init__()
|
2018-03-08 15:18:31 -03:00
|
|
|
|
|
|
|
self.common = common
|
|
|
|
|
|
|
|
self.common.log('TorConnectionThread', '__init__')
|
2017-05-16 14:44:34 -04:00
|
|
|
|
|
|
|
self.settings = settings
|
2018-03-13 07:28:47 -03:00
|
|
|
|
|
|
|
self.dialog = dialog
|
2017-05-16 14:44:34 -04:00
|
|
|
self.onion = onion
|
|
|
|
|
|
|
|
def run(self):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionThread', 'run')
|
2017-04-18 00:26:35 -03:00
|
|
|
|
|
|
|
# Connect to the Onion
|
|
|
|
try:
|
2017-11-12 03:53:23 -03:00
|
|
|
self.onion.connect(self.settings, False, self._tor_status_update)
|
2017-12-21 00:08:13 -03:00
|
|
|
if self.onion.connected_to_tor:
|
2017-05-16 16:09:27 -04:00
|
|
|
self.connected_to_tor.emit()
|
|
|
|
else:
|
2017-05-16 19:50:33 -04:00
|
|
|
self.canceled_connecting_to_tor.emit()
|
2017-05-14 21:30:45 -04:00
|
|
|
|
2017-04-18 00:49:50 -03:00
|
|
|
except BundledTorCanceled as e:
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionThread', 'run', 'caught exception: BundledTorCanceled')
|
2017-05-16 19:50:33 -04:00
|
|
|
self.canceled_connecting_to_tor.emit()
|
2017-05-14 21:46:54 -04:00
|
|
|
|
2017-04-18 00:49:50 -03:00
|
|
|
except Exception as e:
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common.log('TorConnectionThread', 'run', 'caught exception: {}'.format(e.args[0]))
|
2017-05-17 14:36:32 -04:00
|
|
|
self.error_connecting_to_tor.emit(str(e.args[0]))
|
2017-04-18 00:26:35 -03:00
|
|
|
|
2017-05-16 14:44:34 -04:00
|
|
|
def _tor_status_update(self, progress, summary):
|
|
|
|
self.tor_status_update.emit(progress, summary)
|
2017-05-14 21:30:45 -04:00
|
|
|
|
|
|
|
# Return False if the dialog was canceled
|
2017-05-16 14:44:34 -04:00
|
|
|
return not self.dialog.wasCanceled()
|