Browse Source

trezor: print more info, in order to fix issue #1306

283
ThomasV 10 years ago
parent
commit
e994736bf5
  1. 23
      plugins/trezor.py

23
plugins/trezor.py

@ -80,18 +80,13 @@ class Plugin(BasePlugin):
def compare_version(self, major, minor=0, patch=0): def compare_version(self, major, minor=0, patch=0):
features = self.get_client().features features = self.get_client().features
return cmp([features.major_version, features.minor_version, features.patch_version], [major, minor, patch]) v = [features.major_version, features.minor_version, features.patch_version]
self.print_error('firmware version', v)
return cmp(v, [major, minor, patch])
def atleast_version(self, major, minor=0, patch=0): def atleast_version(self, major, minor=0, patch=0):
return self.compare_version(major, minor, patch) >= 0 return self.compare_version(major, minor, patch) >= 0
def trezor_is_connected(self):
try:
self.get_client().ping('t')
except:
return False
return True
def get_client(self): def get_client(self):
if not TREZOR: if not TREZOR:
give_error('please install github.com/trezor/python-trezor') give_error('please install github.com/trezor/python-trezor')
@ -106,6 +101,7 @@ class Plugin(BasePlugin):
self.client.set_tx_api(self) self.client.set_tx_api(self)
self.client.bad = False self.client.bad = False
if not self.atleast_version(1, 2, 1): if not self.atleast_version(1, 2, 1):
self.client = None
give_error('Outdated Trezor firmware. Please update the firmware from https://www.mytrezor.com') give_error('Outdated Trezor firmware. Please update the firmware from https://www.mytrezor.com')
return self.client return self.client
@ -135,13 +131,16 @@ class Plugin(BasePlugin):
if self.handler is None: if self.handler is None:
self.handler = TrezorQtHandler(self.window.app) self.handler = TrezorQtHandler(self.window.app)
if self.trezor_is_connected(): try:
self.get_client().ping('t')
except BaseException as e:
QMessageBox.information(self.window, _('Error'), _("Trezor device not detected.\nContinuing in watching-only mode." + '\n\nReason:\n' + str(e)), _('OK'))
self.wallet.force_watching_only = True
return
if self.wallet.addresses() and not self.wallet.check_proper_device(): if self.wallet.addresses() and not self.wallet.check_proper_device():
QMessageBox.information(self.window, _('Error'), _("This wallet does not match your Trezor device"), _('OK')) QMessageBox.information(self.window, _('Error'), _("This wallet does not match your Trezor device"), _('OK'))
self.wallet.force_watching_only = True self.wallet.force_watching_only = True
else:
QMessageBox.information(self.window, _('Error'), _("Trezor device not detected.\nContinuing in watching-only mode."), _('OK'))
self.wallet.force_watching_only = True
@hook @hook
def installwizard_load_wallet(self, wallet, window): def installwizard_load_wallet(self, wallet, window):

Loading…
Cancel
Save