update unsigned tx format, so that imported wallets can sign all address types

This commit is contained in:
ThomasV 2017-10-14 15:47:36 +02:00
parent d472156dcd
commit 0dbb976baf
3 changed files with 13 additions and 11 deletions

View File

@ -363,6 +363,11 @@ def redeem_script_to_address(txin_type, redeem_script):
raise NotImplementedError(txin_type)
def script_to_address(script):
from .transaction import get_address_from_output_script
t, addr = get_address_from_output_script(bfh(script))
assert t == TYPE_ADDRESS
return addr
def address_to_script(addr):
witver, witprog = segwit_addr.decode(SEGWIT_HRP, addr)

View File

@ -162,11 +162,9 @@ class Imported_KeyStore(Software_KeyStore):
if x_pubkey in self.keypairs.keys():
return x_pubkey
elif x_pubkey[0:2] == 'fd':
# fixme: this assumes p2pkh
_, addr = xpubkey_to_address(x_pubkey)
for pubkey in self.keypairs.keys():
if public_key_to_p2pkh(bfh(pubkey)) == addr:
return pubkey
addr = bitcoin.script_to_address(x_pubkey[2:])
if addr in self.addresses:
return self.addresses[addr].get('pubkey')
def update_password(self, old_password, new_password):
self.check_password(old_password)
@ -594,10 +592,7 @@ def parse_xpubkey(x_pubkey):
def xpubkey_to_address(x_pubkey):
if x_pubkey[0:2] == 'fd':
# TODO: check that ord() is OK here
addrtype = ord(bfh(x_pubkey[2:4]))
hash160 = bfh(x_pubkey[4:])
address = bitcoin.hash160_to_b58_address(hash160, addrtype)
address = bitcoin.script_to_address(x_pubkey[2:])
return x_pubkey, address
if x_pubkey[0:2] in ['02', '03', '04']:
pubkey = x_pubkey

View File

@ -1364,6 +1364,9 @@ class Imported_Wallet(Abstract_Wallet):
def load_addresses(self):
self.addresses = self.storage.get('addresses', {})
# fixme: a reference to addresses is needed
if self.keystore:
self.keystore.addresses = self.addresses
def save_addresses(self):
self.storage.put('addresses', self.addresses)
@ -1467,8 +1470,7 @@ class Imported_Wallet(Abstract_Wallet):
def add_input_sig_info(self, txin, address):
if self.is_watching_only():
addrtype, hash160 = b58_address_to_hash160(address)
x_pubkey = 'fd' + bh2u(bytes([addrtype]) + hash160)
x_pubkey = 'fd' + address_to_script(address)
txin['x_pubkeys'] = [x_pubkey]
txin['signatures'] = [None]
return