Browse Source

account key must be a string (json)

283
ThomasV 11 years ago
parent
commit
3a5f64fcc7
  1. 19
      lib/wallet.py

19
lib/wallet.py

@ -229,7 +229,7 @@ class Abstract_Wallet(object):
d = self.storage.get('accounts', {}) d = self.storage.get('accounts', {})
for k, v in d.items(): for k, v in d.items():
if k == 0: if self.wallet_type == 'old' and k in [0, '0']:
v['mpk'] = self.storage.get('master_public_key') v['mpk'] = self.storage.get('master_public_key')
self.accounts[k] = OldAccount(v) self.accounts[k] = OldAccount(v)
elif v.get('imported'): elif v.get('imported'):
@ -1124,6 +1124,9 @@ class Deterministic_Wallet(Abstract_Wallet):
if n > nmax: nmax = n if n > nmax: nmax = n
return nmax + 1 return nmax + 1
def default_account(self):
return self.accounts['0']
def create_new_address(self, account=None, for_change=0): def create_new_address(self, account=None, for_change=0):
if account is None: if account is None:
account = self.default_account() account = self.default_account()
@ -1231,9 +1234,6 @@ class BIP32_Wallet(Deterministic_Wallet):
self.master_private_keys = storage.get('master_private_keys', {}) self.master_private_keys = storage.get('master_private_keys', {})
self.gap_limit = 20 self.gap_limit = 20
def default_account(self):
return self.accounts['0']
def is_watching_only(self): def is_watching_only(self):
return not bool(self.master_private_keys) return not bool(self.master_private_keys)
@ -1483,9 +1483,7 @@ class Wallet_2of3(Wallet_2of2):
class OldWallet(Deterministic_Wallet): class OldWallet(Deterministic_Wallet):
wallet_type = 'old'
def default_account(self):
return self.accounts[0]
def make_seed(self): def make_seed(self):
import mnemonic import mnemonic
@ -1526,7 +1524,7 @@ class OldWallet(Deterministic_Wallet):
self.create_account(mpk) self.create_account(mpk)
def create_account(self, mpk): def create_account(self, mpk):
self.accounts[0] = OldAccount({'mpk':mpk, 0:[], 1:[]}) self.accounts['0'] = OldAccount({'mpk':mpk, 0:[], 1:[]})
self.save_accounts() self.save_accounts()
def create_watching_only_wallet(self, mpk): def create_watching_only_wallet(self, mpk):
@ -1541,7 +1539,7 @@ class OldWallet(Deterministic_Wallet):
def check_password(self, password): def check_password(self, password):
seed = self.get_seed(password) seed = self.get_seed(password)
self.accounts[0].check_seed(seed) self.accounts['0'].check_seed(seed)
def get_mnemonic(self, password): def get_mnemonic(self, password):
import mnemonic import mnemonic
@ -1572,6 +1570,7 @@ class Wallet(object):
config = storage.config config = storage.config
self.wallet_types = [ self.wallet_types = [
('old', ("Old wallet"), OldWallet),
('standard', ("Standard wallet"), NewWallet), ('standard', ("Standard wallet"), NewWallet),
('imported', ("Imported wallet"), Imported_Wallet), ('imported', ("Imported wallet"), Imported_Wallet),
('2of2', ("Multisig wallet (2 of 2)"), Wallet_2of2), ('2of2', ("Multisig wallet (2 of 2)"), Wallet_2of2),
@ -1596,7 +1595,7 @@ class Wallet(object):
return NewWallet(storage) return NewWallet(storage)
else: else:
msg = "This wallet seed is not supported." msg = "This wallet seed is not supported."
if seed_version in [5]: if seed_version in [5, 7]:
msg += "\nTo open this wallet, try 'git checkout seed_v%d'"%seed_version msg += "\nTo open this wallet, try 'git checkout seed_v%d'"%seed_version
print msg print msg
sys.exit(1) sys.exit(1)

Loading…
Cancel
Save