ZIP 244: Add hash_type to transparent_sig_digest

This commit is contained in:
Jack Grigg 2022-01-06 16:51:32 +00:00
parent bda224b133
commit fe666c2b94
1 changed files with 25 additions and 2 deletions

View File

@ -243,6 +243,7 @@ def transparent_sig_digest(tx, t_inputs, nHashType, txin):
digest = blake2b(digest_size=32, person=b'ZTxIdTranspaHash') digest = blake2b(digest_size=32, person=b'ZTxIdTranspaHash')
if len(tx.vin) + len(tx.vout) > 0: if len(tx.vin) + len(tx.vout) > 0:
digest.update(hash_type(tx, nHashType, txin))
digest.update(prevouts_sig_digest(tx, nHashType)) digest.update(prevouts_sig_digest(tx, nHashType))
digest.update(amounts_sig_digest(t_inputs, nHashType)) digest.update(amounts_sig_digest(t_inputs, nHashType))
digest.update(script_codes_sig_digest(t_inputs, nHashType)) digest.update(script_codes_sig_digest(t_inputs, nHashType))
@ -252,6 +253,23 @@ def transparent_sig_digest(tx, t_inputs, nHashType, txin):
return digest.digest() return digest.digest()
def hash_type(tx, nHashType, txin):
if txin is None:
# Sapling Spend or Orchard Action
assert nHashType == SIGHASH_ALL
else:
# Transparent input
assert nHashType in [
SIGHASH_ALL,
SIGHASH_NONE,
SIGHASH_SINGLE,
SIGHASH_ALL | SIGHASH_ANYONECANPAY,
SIGHASH_NONE | SIGHASH_ANYONECANPAY,
SIGHASH_SINGLE | SIGHASH_ANYONECANPAY,
]
assert (nHashType & 0x1f) != SIGHASH_SINGLE or 0 <= txin.nIn and txin.nIn < len(tx.vout)
return struct.pack('B', nHashType)
def prevouts_sig_digest(tx, nHashType): def prevouts_sig_digest(tx, nHashType):
# If the SIGHASH_ANYONECANPAY flag is not set: # If the SIGHASH_ANYONECANPAY flag is not set:
if not (nHashType & SIGHASH_ANYONECANPAY): if not (nHashType & SIGHASH_ANYONECANPAY):
@ -344,14 +362,19 @@ def main():
sighash_shielded = signature_digest(tx, t_inputs, SIGHASH_ALL, None) sighash_shielded = signature_digest(tx, t_inputs, SIGHASH_ALL, None)
other_sighashes = { other_sighashes = {
nHashType: None if txin is None else signature_digest(tx, t_inputs, nHashType, txin) nHashType: None if txin is None else signature_digest(tx, t_inputs, nHashType, txin)
for nHashType in [ for nHashType in ([
SIGHASH_ALL, SIGHASH_ALL,
SIGHASH_NONE, SIGHASH_NONE,
SIGHASH_SINGLE, SIGHASH_SINGLE,
SIGHASH_ALL | SIGHASH_ANYONECANPAY, SIGHASH_ALL | SIGHASH_ANYONECANPAY,
SIGHASH_NONE | SIGHASH_ANYONECANPAY, SIGHASH_NONE | SIGHASH_ANYONECANPAY,
SIGHASH_SINGLE | SIGHASH_ANYONECANPAY, SIGHASH_SINGLE | SIGHASH_ANYONECANPAY,
] ] if txin is None or txin.nIn < len(tx.vout) else [
SIGHASH_ALL,
SIGHASH_NONE,
SIGHASH_ALL | SIGHASH_ANYONECANPAY,
SIGHASH_NONE | SIGHASH_ANYONECANPAY,
])
} }
test_vectors.append({ test_vectors.append({