Browse Source

Merge pull request #3444 from SomberNight/2fa_tos_catch_exc

Catch exception when retrieving 2FA TOS
3.0.x
ThomasV 7 years ago
committed by GitHub
parent
commit
a03a5c00e3
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 22
      plugins/trustedcoin/qt.py

22
plugins/trustedcoin/qt.py

@ -42,6 +42,7 @@ from .trustedcoin import TrustedCoinPlugin, server
class TOS(QTextEdit): class TOS(QTextEdit):
tos_signal = pyqtSignal() tos_signal = pyqtSignal()
error_signal = pyqtSignal(object)
class Plugin(TrustedCoinPlugin): class Plugin(TrustedCoinPlugin):
@ -195,6 +196,7 @@ class Plugin(TrustedCoinPlugin):
tos_e = TOS() tos_e = TOS()
tos_e.setReadOnly(True) tos_e.setReadOnly(True)
vbox.addWidget(tos_e) vbox.addWidget(tos_e)
tos_received = False
vbox.addWidget(QLabel(_("Please enter your e-mail address"))) vbox.addWidget(QLabel(_("Please enter your e-mail address")))
email_e = QLineEdit() email_e = QLineEdit()
@ -205,17 +207,33 @@ class Plugin(TrustedCoinPlugin):
next_button.setText(_('Accept')) next_button.setText(_('Accept'))
def request_TOS(): def request_TOS():
tos = server.get_terms_of_service() try:
tos = server.get_terms_of_service()
except Exception as e:
import traceback
traceback.print_exc(file=sys.stderr)
tos_e.error_signal.emit(_('Could not retrieve Terms of Service:')
+ '\n' + str(e))
return
self.TOS = tos self.TOS = tos
tos_e.tos_signal.emit() tos_e.tos_signal.emit()
def on_result(): def on_result():
tos_e.setText(self.TOS) tos_e.setText(self.TOS)
nonlocal tos_received
tos_received = True
set_enabled()
def on_error(msg):
window.show_error(str(msg))
window.terminate()
def set_enabled(): def set_enabled():
next_button.setEnabled(re.match(regexp,email_e.text()) is not None) valid_email = re.match(regexp, email_e.text()) is not None
next_button.setEnabled(tos_received and valid_email)
tos_e.tos_signal.connect(on_result) tos_e.tos_signal.connect(on_result)
tos_e.error_signal.connect(on_error)
t = Thread(target=request_TOS) t = Thread(target=request_TOS)
t.setDaemon(True) t.setDaemon(True)
t.start() t.start()

Loading…
Cancel
Save