Browse Source

Merge pull request #1044 from LedgerHQ/ledger

New firmware integration
283
ThomasV 10 years ago
parent
commit
5ee4a87f29
  1. 6
      plugins/btchipwallet.py

6
plugins/btchipwallet.py

@ -158,7 +158,7 @@ class BTChipWallet(BIP32_HD_Wallet):
d.setWaitImpl(DongleWaitQT(d)) d.setWaitImpl(DongleWaitQT(d))
self.client = btchip(d) self.client = btchip(d)
firmware = self.client.getFirmwareVersion()['version'].split(".") firmware = self.client.getFirmwareVersion()['version'].split(".")
if (not checkFirmware(firmware)) or (int(firmware[0]) <> 1) or (int(firmware[1]) <> 4) or (int(firmware[2]) < 9): if not checkFirmware(firmware):
d.close() d.close()
try: try:
updateFirmware() updateFirmware()
@ -307,11 +307,13 @@ class BTChipWallet(BIP32_HD_Wallet):
self.device_checked = False self.device_checked = False
self.get_client(True) self.get_client(True)
signature = self.get_client().signMessageSign(pin) signature = self.get_client().signMessageSign(pin)
except Exception, e: except BTChipException, e:
if e.sw == 0x6a80: if e.sw == 0x6a80:
self.give_error("Unfortunately, this message cannot be signed by BTChip. Only alphanumerical messages shorter than 140 characters are supported. Please remove any extra characters (tab, carriage return) and retry.") self.give_error("Unfortunately, this message cannot be signed by BTChip. Only alphanumerical messages shorter than 140 characters are supported. Please remove any extra characters (tab, carriage return) and retry.")
else: else:
self.give_error(e, True) self.give_error(e, True)
except Exception, e:
self.give_error(e, True)
finally: finally:
if waitDialog.waiting: if waitDialog.waiting:
waitDialog.emit(SIGNAL('dongle_done')) waitDialog.emit(SIGNAL('dongle_done'))

Loading…
Cancel
Save