Browse Source

fix: witness serialization

seed_v14
ThomasV 7 years ago
parent
commit
8683d71711
  1. 1
      lib/bitcoin.py
  2. 7
      lib/transaction.py

1
lib/bitcoin.py

@ -230,7 +230,6 @@ def op_push(i):
def push_script(x): def push_script(x):
return op_push(len(x)//2) + x return op_push(len(x)//2) + x
def sha256(x): def sha256(x):
x = to_bytes(x, 'utf8') x = to_bytes(x, 'utf8')
return bytes(hashlib.sha256(x).digest()) return bytes(hashlib.sha256(x).digest())

7
lib/transaction.py

@ -443,10 +443,10 @@ def parse_witness(vds, txin):
txin['witnessScript'] = witnessScript txin['witnessScript'] = witnessScript
else: else:
txin['num_sig'] = 1 txin['num_sig'] = 1
txin['x_pubkeys'] = [w[1]]
txin['pubkeys'] = [w[1]] txin['pubkeys'] = [w[1]]
txin['signatures'] = parse_sig([w[0]]) txin['signatures'] = parse_sig([w[0]])
def parse_output(vds, i): def parse_output(vds, i):
d = {} d = {}
d['value'] = vds.read_int64() d['value'] = vds.read_int64()
@ -637,15 +637,16 @@ class Transaction:
@classmethod @classmethod
def serialize_witness(self, txin): def serialize_witness(self, txin):
add_w = lambda x: var_int(len(x)//2) + x
if not self.is_segwit_input(txin): if not self.is_segwit_input(txin):
return '00' return '00'
pubkeys, sig_list = self.get_siglist(txin) pubkeys, sig_list = self.get_siglist(txin)
if txin['type'] in ['p2wpkh', 'p2wpkh-p2sh']: if txin['type'] in ['p2wpkh', 'p2wpkh-p2sh']:
witness = var_int(2) + push_script(sig_list[0]) + push_script(pubkeys[0]) witness = var_int(2) + add_w(sig_list[0]) + add_w(pubkeys[0])
elif txin['type'] in ['p2wsh', 'p2wsh-p2sh']: elif txin['type'] in ['p2wsh', 'p2wsh-p2sh']:
n = len(sig_list) + 2 n = len(sig_list) + 2
witness_script = multisig_script(pubkeys, txin['num_sig']) witness_script = multisig_script(pubkeys, txin['num_sig'])
witness = var_int(n) + '00' + ''.join(var_int(len(x)//2) + x for x in sig_list) + var_int(len(witness_script)//2) + witness_script witness = var_int(n) + '00' + ''.join(add_w(x) for x in sig_list) + add_w(witness_script)
else: else:
raise BaseException('wrong txin type') raise BaseException('wrong txin type')
value_field = '' if self.is_txin_complete(txin) else var_int(0xffffffff) + int_to_hex(txin['value'], 8) value_field = '' if self.is_txin_complete(txin) else var_int(0xffffffff) + int_to_hex(txin['value'], 8)

Loading…
Cancel
Save