Browse Source

fixes for master keys

283
ThomasV 11 years ago
parent
commit
98ae202d80
  1. 10
      lib/wallet.py

10
lib/wallet.py

@ -375,7 +375,7 @@ class Wallet:
def create_master_keys(self, account_type, password): def create_master_keys(self, account_type, password):
master_k, master_c, master_K, master_cK = bip32_init(self.get_seed(None)) master_k, master_c, master_K, master_cK = bip32_init(self.get_seed(password))
if account_type == '1': if account_type == '1':
k0, c0, K0, cK0 = bip32_private_derivation(master_k, master_c, "m/", "m/0'/") k0, c0, K0, cK0 = bip32_private_derivation(master_k, master_c, "m/", "m/0'/")
self.master_public_keys["m/0'/"] = (c0, K0, cK0) self.master_public_keys["m/0'/"] = (c0, K0, cK0)
@ -426,9 +426,9 @@ class Wallet:
def deseed_branch(self, k): def deseed_branch(self, k):
# check that parent has no seed # check that parent has no seed
# assert self.seed == '' # assert self.seed == ''
k = self.master_private_keys.pop(k) self.master_private_keys.pop(k)
self.storage.put('master_private_keys', self.master_private_keys, True) self.storage.put('master_private_keys', self.master_private_keys, True)
return k
def is_watching_only(self): def is_watching_only(self):
return (self.seed == '') and (self.master_private_keys == {}) return (self.seed == '') and (self.master_private_keys == {})
@ -608,7 +608,9 @@ class Wallet:
return repr((c, K)) return repr((c, K))
def get_master_private_key(self, account, password): def get_master_private_key(self, account, password):
master_k = pw_decode( self.master_private_keys[account], password) k = self.master_private_keys.get(account)
if not k: return
master_k = pw_decode( k, password)
master_c, master_K, master_Kc = self.master_public_keys[account] master_c, master_K, master_Kc = self.master_public_keys[account]
try: try:
K, Kc = get_pubkeys_from_secret(master_k.decode('hex')) K, Kc = get_pubkeys_from_secret(master_k.decode('hex'))

Loading…
Cancel
Save