From 4110767a713f9ab7b5852c34ebb1bb459c758101 Mon Sep 17 00:00:00 2001 From: levoncrypto Date: Tue, 2 Jul 2024 15:49:06 +0400 Subject: [PATCH] Fix transaction sign with Ledger hw --- electrum_dash/plugins/ledger/ledger.py | 37 ++++++++++---------------- 1 file changed, 14 insertions(+), 23 deletions(-) diff --git a/electrum_dash/plugins/ledger/ledger.py b/electrum_dash/plugins/ledger/ledger.py index b3f71ae41d..a96cc4e02e 100644 --- a/electrum_dash/plugins/ledger/ledger.py +++ b/electrum_dash/plugins/ledger/ledger.py @@ -137,34 +137,24 @@ def getTrustedInput(self, transaction, index): self.dongle.exchange(bytearray(apdu)) offset += dataLength - #Sending the lockTime and the extraPayload - blockLength = 255 - buffer = [] - writeVarint(len(transaction.extra_data), buffer) - offset = blockLength - len(transaction.lockTime) - len(buffer) - apdu = [self.BTCHIP_CLA, self.BTCHIP_INS_GET_TRUSTED_INPUT, 0x80, 0x00, blockLength] + params = [] + if transaction.extra_data: + if len(transaction.extra_data) > 255 - len(transaction.lockTime): + # for now the size should be sufficient + raise Exception('The size of the DIP2 extra data block has exceeded the limit.') + + writeVarint(len(transaction.extra_data), params) + params.extend(transaction.extra_data) + + apdu = [self.BTCHIP_CLA, self.BTCHIP_INS_GET_TRUSTED_INPUT, 0x80, 0x00, len(transaction.lockTime) + len(params)] + # Locktime apdu.extend(transaction.lockTime) - apdu.extend(buffer) - if offset > len(transaction.extra_data): - offset = len(transaction.extra_data) - apdu.extend(transaction.extra_data[0: offset]) + apdu.extend(params) response = self.dongle.exchange(bytearray(apdu)) - while (offset < len(transaction.extra_data)): - blockLength = 255 - if ((offset + blockLength) < len(transaction.extra_data)): - dataLength = blockLength - else: - dataLength = len(transaction.extra_data) - offset - apdu = [self.BTCHIP_CLA, self.BTCHIP_INS_GET_TRUSTED_INPUT, 0x80, 0x00, dataLength] - apdu.extend(transaction.extra_data[offset: offset + dataLength]) - response = self.dongle.exchange(bytearray(apdu)) - offset += dataLength - result['trustedInput'] = True result['value'] = response return result - class Ledger_Client(HardwareClientBase): def __init__(self, hidDevice, *, product_key: Tuple[int, int], plugin: HW_PluginBase): @@ -297,6 +287,7 @@ def perform_hw1_preflight(self): self.dongleObject.verifyPin(pin) if self.canAlternateCoinVersions: self.dongleObject.setAlternateCoinVersions(constants.net.ADDRTYPE_P2PKH, + constants.net.ADDRTYPE_EXP2PKH, constants.net.ADDRTYPE_P2SH) except BTChipException as e: if (e.sw == 0x6faa): @@ -531,7 +522,7 @@ def sign_transaction(self, tx, password): output = txout.address if not self.get_client_electrum().canAlternateCoinVersions: v, h = b58_address_to_hash160(output) - if v == constants.net.ADDRTYPE_P2PKH: + if v == constants.net.ADDRTYPE_P2PKH or v == constants.net.ADDRTYPE_EXP2PKH: output = hash160_to_b58_address(h, 0) self.handler.show_message(_("Confirm Transaction on your Ledger device..."))