Browse Source

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

seed_v14
ThomasV 7 years ago
parent
commit
0dbb976baf
  1. 5
      lib/bitcoin.py
  2. 13
      lib/keystore.py
  3. 6
      lib/wallet.py

5
lib/bitcoin.py

@ -363,6 +363,11 @@ def redeem_script_to_address(txin_type, redeem_script):
raise NotImplementedError(txin_type) 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): def address_to_script(addr):
witver, witprog = segwit_addr.decode(SEGWIT_HRP, addr) witver, witprog = segwit_addr.decode(SEGWIT_HRP, addr)

13
lib/keystore.py

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

6
lib/wallet.py

@ -1364,6 +1364,9 @@ class Imported_Wallet(Abstract_Wallet):
def load_addresses(self): def load_addresses(self):
self.addresses = self.storage.get('addresses', {}) 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): def save_addresses(self):
self.storage.put('addresses', self.addresses) self.storage.put('addresses', self.addresses)
@ -1467,8 +1470,7 @@ class Imported_Wallet(Abstract_Wallet):
def add_input_sig_info(self, txin, address): def add_input_sig_info(self, txin, address):
if self.is_watching_only(): if self.is_watching_only():
addrtype, hash160 = b58_address_to_hash160(address) x_pubkey = 'fd' + address_to_script(address)
x_pubkey = 'fd' + bh2u(bytes([addrtype]) + hash160)
txin['x_pubkeys'] = [x_pubkey] txin['x_pubkeys'] = [x_pubkey]
txin['signatures'] = [None] txin['signatures'] = [None]
return return

Loading…
Cancel
Save