Browse Source

Implement BIP-LI01.

No more need to randomly place change.
283
Neil Booth 10 years ago
parent
commit
98bea614d8
  1. 4
      lib/transaction.py
  2. 15
      lib/wallet.py

4
lib/transaction.py

@ -626,6 +626,10 @@ class Transaction:
return script return script
def BIP_LI01_sort(self):
# See https://github.com/kristovatlas/rfc/blob/master/bips/bip-li01.mediawiki
self.inputs.sort(key = lambda i: (i['prevout_hash'], i['prevout_n']))
self.outputs.sort(key = lambda o: (o[2], self.pay_script(o[0], o[1])))
def serialize(self, for_sig=None): def serialize(self, for_sig=None):
inputs = self.inputs inputs = self.inputs

15
lib/wallet.py

@ -898,27 +898,26 @@ class Abstract_Wallet(object):
# if change is above dust threshold, add a change output. # if change is above dust threshold, add a change output.
change_amount = total - ( amount + fee ) change_amount = total - ( amount + fee )
if fixed_fee is not None and change_amount > 0: if fixed_fee is not None and change_amount > 0:
# Insert the change output at a random position in the outputs tx.outputs.append(('address', change_addr, change_amount))
posn = random.randint(0, len(tx.outputs))
tx.outputs[posn:posn] = [( 'address', change_addr, change_amount)]
elif change_amount > DUST_THRESHOLD: elif change_amount > DUST_THRESHOLD:
# Insert the change output at a random position in the outputs tx.outputs.append(('address', change_addr, change_amount))
posn = random.randint(0, len(tx.outputs))
tx.outputs[posn:posn] = [( 'address', change_addr, change_amount)]
# recompute fee including change output # recompute fee including change output
fee = self.estimated_fee(tx) fee = self.estimated_fee(tx)
# remove change output # remove change output
tx.outputs.pop(posn) tx.outputs.pop()
# if change is still above dust threshold, re-add change output. # if change is still above dust threshold, re-add change output.
change_amount = total - ( amount + fee ) change_amount = total - ( amount + fee )
if change_amount > DUST_THRESHOLD: if change_amount > DUST_THRESHOLD:
tx.outputs[posn:posn] = [( 'address', change_addr, change_amount)] tx.outputs.append(('address', change_addr, change_amount))
print_error('change', change_amount) print_error('change', change_amount)
else: else:
print_error('not keeping dust', change_amount) print_error('not keeping dust', change_amount)
else: else:
print_error('not keeping dust', change_amount) print_error('not keeping dust', change_amount)
# Sort the inputs and outputs deterministically
tx.BIP_LI01_sort()
run_hook('make_unsigned_transaction', tx) run_hook('make_unsigned_transaction', tx)
return tx return tx

Loading…
Cancel
Save