electrum

Electrum Bitcoin wallet
git clone https://git.parazyd.org/electrum
Log | Files | Refs | Submodules

commit 4fea9edd11f66536c5f6c56f8b0fabaaa18ca612
parent 27012e7394ce5230269a2c59e8a4df12253e75a7
Author: SomberNight <somber.night@protonmail.com>
Date:   Fri,  8 Jun 2018 13:42:41 +0200

distinguish invalid otp from server failure when sending tx

Diffstat:
Mplugins/trustedcoin/kivy.py | 15++++++++++-----
1 file changed, 10 insertions(+), 5 deletions(-)

diff --git a/plugins/trustedcoin/kivy.py b/plugins/trustedcoin/kivy.py @@ -32,7 +32,7 @@ from kivy.clock import Clock from electrum.i18n import _ from electrum.plugins import hook -from .trustedcoin import TrustedCoinPlugin, server, KIVY_DISCLAIMER +from .trustedcoin import TrustedCoinPlugin, server, KIVY_DISCLAIMER, TrustedCoinException @@ -62,10 +62,15 @@ class Plugin(TrustedCoinPlugin): def on_otp(self, wallet, tx, otp, on_success, on_failure): try: wallet.on_otp(tx, otp) - except: - Clock.schedule_once(lambda dt: on_failure(_("Invalid OTP"))) - return - on_success(tx) + except TrustedCoinException as e: + if e.status_code == 400: # invalid OTP + Clock.schedule_once(lambda dt: on_failure(_('Invalid one-time password.'))) + else: + Clock.schedule_once(lambda dt, bound_e=e: on_failure(_('Error') + ':' + str(bound_e))) + except Exception as e: + Clock.schedule_once(lambda dt, bound_e=e: on_failure(_('Error') + ':' + str(bound_e))) + else: + on_success(tx) def accept_terms_of_use(self, wizard): tos = server.get_terms_of_service()