1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-05 04:50:57 +00:00

core/sign_tx: Add write_tx_output() to signer class and override it in Decred.

This commit is contained in:
Andrew Kozlik 2020-05-05 09:58:09 +02:00 committed by Andrew Kozlik
parent bdd1d25979
commit dccf415e0b
4 changed files with 19 additions and 8 deletions

View File

@ -226,7 +226,7 @@ class Bitcoin:
elif not await helpers.confirm_output(txo, self.coin): elif not await helpers.confirm_output(txo, self.coin):
raise SigningError(FailureType.ActionCancelled, "Output cancelled") raise SigningError(FailureType.ActionCancelled, "Output cancelled")
writers.write_tx_output(self.h_confirmed, txo_bin) self.write_tx_output(self.h_confirmed, txo_bin)
self.hash143_add_output(txo_bin) self.hash143_add_output(txo_bin)
self.total_out += txo_bin.amount self.total_out += txo_bin.amount
@ -345,8 +345,8 @@ class Bitcoin:
txo = await helpers.request_tx_output(self.tx_req, i, self.coin) txo = await helpers.request_tx_output(self.tx_req, i, self.coin)
txo_bin.amount = txo.amount txo_bin.amount = txo.amount
txo_bin.script_pubkey = self.output_derive_script(txo) txo_bin.script_pubkey = self.output_derive_script(txo)
writers.write_tx_output(h_check, txo_bin) self.write_tx_output(h_check, txo_bin)
writers.write_tx_output(h_sign, txo_bin) self.write_tx_output(h_sign, txo_bin)
writers.write_uint32(h_sign, self.tx.lock_time) writers.write_uint32(h_sign, self.tx.lock_time)
writers.write_uint32(h_sign, self.get_hash_type()) writers.write_uint32(h_sign, self.get_hash_type())
@ -376,7 +376,7 @@ class Bitcoin:
txo_bin = TxOutputBinType() txo_bin = TxOutputBinType()
txo_bin.amount = txo.amount txo_bin.amount = txo.amount
txo_bin.script_pubkey = self.output_derive_script(txo) txo_bin.script_pubkey = self.output_derive_script(txo)
writers.write_tx_output(self.serialized_tx, txo_bin) self.write_tx_output(self.serialized_tx, txo_bin)
async def get_prevtx_output_value(self, prev_hash: bytes, prev_index: int) -> int: async def get_prevtx_output_value(self, prev_hash: bytes, prev_index: int) -> int:
amount_out = 0 # output amount amount_out = 0 # output amount
@ -407,7 +407,7 @@ class Bitcoin:
txo_bin = await helpers.request_tx_output( txo_bin = await helpers.request_tx_output(
self.tx_req, i, self.coin, prev_hash self.tx_req, i, self.coin, prev_hash
) )
writers.write_tx_output(txh, txo_bin) self.write_tx_output(txh, txo_bin)
if i == prev_index: if i == prev_index:
amount_out = txo_bin.amount amount_out = txo_bin.amount
self.check_prevtx_output(txo_bin) self.check_prevtx_output(txo_bin)
@ -437,6 +437,9 @@ class Bitcoin:
def write_tx_input(self, w: writers.Writer, txi: TxInputType) -> None: def write_tx_input(self, w: writers.Writer, txi: TxInputType) -> None:
writers.write_tx_input(w, txi) writers.write_tx_input(w, txi)
def write_tx_output(self, w: writers.Writer, txo_bin: TxOutputBinType) -> None:
writers.write_tx_output(w, txo_bin)
def write_tx_header( def write_tx_header(
self, w: writers.Writer, tx: Union[SignTx, TransactionType], has_segwit: bool self, w: writers.Writer, tx: Union[SignTx, TransactionType], has_segwit: bool
) -> None: ) -> None:

View File

@ -44,7 +44,7 @@ class Bitcoinlike(Bitcoin):
# serialize input with correct signature # serialize input with correct signature
gc.collect() gc.collect()
txi.script_sig = self.input_derive_script(txi, public_key, signature) txi.script_sig = self.input_derive_script(txi, public_key, signature)
writers.write_tx_input(self.serialized_tx, txi) self.write_tx_input(self.serialized_tx, txi)
self.set_serialized_signature(i_sign, signature) self.set_serialized_signature(i_sign, signature)
async def sign_nonsegwit_input(self, i_sign: int) -> None: async def sign_nonsegwit_input(self, i_sign: int) -> None:

View File

@ -68,7 +68,7 @@ class Decred(Bitcoin):
) )
txo_bin.decred_script_version = txo.decred_script_version txo_bin.decred_script_version = txo.decred_script_version
await super().confirm_output(i, txo, txo_bin) await super().confirm_output(i, txo, txo_bin)
writers.write_tx_output(self.serialized_tx, txo_bin) self.write_tx_output(self.serialized_tx, txo_bin)
async def step4_serialize_inputs(self) -> None: async def step4_serialize_inputs(self) -> None:
writers.write_varint(self.serialized_tx, self.tx.inputs_count) writers.write_varint(self.serialized_tx, self.tx.inputs_count)
@ -154,11 +154,14 @@ class Decred(Bitcoin):
writers.write_tx_input_decred(self.h_prefix, txi) writers.write_tx_input_decred(self.h_prefix, txi)
def hash143_add_output(self, txo_bin: TxOutputBinType) -> None: def hash143_add_output(self, txo_bin: TxOutputBinType) -> None:
writers.write_tx_output(self.h_prefix, txo_bin) writers.write_tx_output_decred(self.h_prefix, txo_bin)
def write_tx_input(self, w: writers.Writer, txi: TxInputType) -> None: def write_tx_input(self, w: writers.Writer, txi: TxInputType) -> None:
writers.write_tx_input_decred(w, txi) writers.write_tx_input_decred(w, txi)
def write_tx_output(self, w: writers.Writer, txo_bin: TxOutputBinType) -> None:
writers.write_tx_output_decred(w, txo_bin)
def write_tx_header( def write_tx_header(
self, w: writers.Writer, tx: Union[SignTx, TransactionType], has_segwit: bool self, w: writers.Writer, tx: Union[SignTx, TransactionType], has_segwit: bool
) -> None: ) -> None:

View File

@ -65,6 +65,11 @@ def write_tx_input_decred_witness(w: Writer, i: TxInputType) -> None:
def write_tx_output(w: Writer, o: TxOutputBinType) -> None: def write_tx_output(w: Writer, o: TxOutputBinType) -> None:
write_uint64(w, o.amount)
write_bytes_prefixed(w, o.script_pubkey)
def write_tx_output_decred(w: Writer, o: TxOutputBinType) -> None:
write_uint64(w, o.amount) write_uint64(w, o.amount)
if o.decred_script_version is not None: if o.decred_script_version is not None:
write_uint16(w, o.decred_script_version) write_uint16(w, o.decred_script_version)