mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-22 21:30:56 +00:00
fix: taproot multisig
This commit is contained in:
parent
268d4791db
commit
cd5a650465
1
core/.changelog.d/4159.added
Normal file
1
core/.changelog.d/4159.added
Normal file
@ -0,0 +1 @@
|
||||
Taproot Multisig send and spend
|
@ -45,9 +45,10 @@ def verify(public_key: bytes, signature: bytes, digest: bytes) -> bool:
|
||||
def tweak_public_key(
|
||||
public_key: bytes,
|
||||
root_hash: bytes | None = None,
|
||||
) -> bytes:
|
||||
) -> tuple[int, bytes]:
|
||||
"""
|
||||
Tweaks the public key with the specified root_hash.
|
||||
First element of tuple is the parity, second is the tweaked public key.
|
||||
"""
|
||||
|
||||
|
||||
|
@ -551,6 +551,7 @@ class Bitcoin:
|
||||
i,
|
||||
tx_info.tx,
|
||||
self.get_sighash_type(txi),
|
||||
None,
|
||||
)
|
||||
else:
|
||||
return tx_info.sig_hasher.hash143(
|
||||
|
@ -279,7 +279,7 @@ class TestSegwitBip341P2TR(unittest.TestCase):
|
||||
|
||||
for sh in tx["signature_hashes"]:
|
||||
txi = tx["inputs"][sh["index"]]
|
||||
result = hasher.hash341(sh["index"], tx["sign_tx"], sh["hash_type"])
|
||||
result = hasher.hash341(sh["index"], tx["sign_tx"], sh["hash_type"], None)
|
||||
self.assertEqual(
|
||||
result, sh["result"], f"signature_hash tx {i} input {sh['index']}"
|
||||
)
|
||||
|
Loading…
Reference in New Issue
Block a user