Browse Source

fixes for install wizard

283
ThomasV 9 years ago
parent
commit
2bb08aa280
  1. 21
      lib/base_wizard.py
  2. 32
      plugins/trustedcoin/trustedcoin.py

21
lib/base_wizard.py

@ -43,17 +43,18 @@ class BaseWizard(object):
self.wallet = None self.wallet = None
self.stack = [] self.stack = []
def run(self, action, *args): def run(self, *args):
action = args[0]
args = args[1:]
self.stack.append((action, args)) self.stack.append((action, args))
if not action: if not action:
return return
if hasattr(self.wallet, 'plugin'): if hasattr(self.wallet, 'plugin') and hasattr(self.wallet.plugin, action):
if hasattr(self.wallet.plugin, action): f = getattr(self.wallet.plugin, action)
f = getattr(self.wallet.plugin, action) apply(f, (self.wallet, self) + args)
apply(f, (self.wallet, self) + args)
elif hasattr(self, action): elif hasattr(self, action):
f = getattr(self, action) f = getattr(self, action)
apply(f, *args) apply(f, args)
else: else:
raise BaseException("unknown action", action) raise BaseException("unknown action", action)
@ -236,7 +237,7 @@ class BaseWizard(object):
def show_xpub_and_add_cosigners(self, password): def show_xpub_and_add_cosigners(self, password):
xpub = self.wallet.master_public_keys.get('x1/') xpub = self.wallet.master_public_keys.get('x1/')
self.show_xpub_dialog(xpub=xpub, run_next=lambda x: self.run('add_cosigners', (password,))) self.show_xpub_dialog(xpub=xpub, run_next=lambda x: self.run('add_cosigners', password))
def add_cosigners(self, password): def add_cosigners(self, password):
i = self.wallet.get_missing_cosigner() i = self.wallet.get_missing_cosigner()
@ -247,7 +248,7 @@ class BaseWizard(object):
self.wallet.add_cosigner('x%d/'%i, text, password) self.wallet.add_cosigner('x%d/'%i, text, password)
i = self.wallet.get_missing_cosigner() i = self.wallet.get_missing_cosigner()
if i: if i:
self.run('add_cosigners', (password,)) self.run('add_cosigners', password)
else: else:
self.create_addresses() self.create_addresses()
@ -255,6 +256,7 @@ class BaseWizard(object):
def task(): def task():
self.wallet.create_main_account() self.wallet.create_main_account()
self.wallet.synchronize() self.wallet.synchronize()
self.wallet.storage.write()
self.terminate() self.terminate()
msg = _("Electrum is generating your addresses, please wait.") msg = _("Electrum is generating your addresses, please wait.")
self.waiting_dialog(task, msg) self.waiting_dialog(task, msg)
@ -265,9 +267,8 @@ class BaseWizard(object):
self.show_seed_dialog(run_next=self.confirm_seed, seed_text=seed) self.show_seed_dialog(run_next=self.confirm_seed, seed_text=seed)
def confirm_seed(self, seed): def confirm_seed(self, seed):
assert Wallet.is_seed(seed)
self.confirm_seed_dialog(run_next=self.add_password, is_valid=lambda x: x==seed) self.confirm_seed_dialog(run_next=self.add_password, is_valid=lambda x: x==seed)
def add_password(self, text): def add_password(self, text):
f = lambda x: self.create_wallet(text, x) f = lambda pw: self.run('create_wallet', text, pw)
self.request_password(run_next=f) self.request_password(run_next=f)

32
plugins/trustedcoin/trustedcoin.py

@ -349,21 +349,9 @@ class TrustedCoinPlugin(BasePlugin):
self.wallet = wallet self.wallet = wallet
self.wizard = wizard self.wizard = wizard
seed = wallet.make_seed() seed = wallet.make_seed()
f = lambda x: wizard.run('confirm_seed', x) self.wizard.show_seed_dialog(run_next=wizard.confirm_seed, seed_text=seed)
self.wizard.show_seed_dialog(run_next=f, message="z", seed_text=seed)
def confirm_seed(self, wallet, wizard, seed): def create_wallet(self, wallet, wizard, seed, password):
title = _('Confirm Seed')
msg = _('Please retype your seed phrase, to confirm that you properly saved it')
f = lambda x: wizard.run('add_password', x)
self.wizard.enter_seed_dialog(run_next=f, title=title, message=msg, is_valid=lambda x: x==seed)
def add_password(self, wallet, wizard, seed):
f = lambda x: self.create_wallet(seed, x)
self.wizard.request_password(run_next=f)
def create_wallet(self, seed, password):
wallet = self.wallet
wallet.storage.put('seed_version', wallet.seed_version) wallet.storage.put('seed_version', wallet.seed_version)
wallet.storage.put('use_encryption', password is not None) wallet.storage.put('use_encryption', password is not None)
words = seed.split() words = seed.split()
@ -381,8 +369,8 @@ class TrustedCoinPlugin(BasePlugin):
_('If you are online, click on "%s" to continue.') % _('Next') _('If you are online, click on "%s" to continue.') % _('Next')
] ]
msg = '\n\n'.join(msg) msg = '\n\n'.join(msg)
self.wizard.confirm(msg) wizard.confirm(msg)
return wallet wizard.run('create_remote_key')
@hook @hook
def do_clear(self, window): def do_clear(self, window):
@ -411,11 +399,9 @@ class TrustedCoinPlugin(BasePlugin):
email = self.accept_terms_of_use(window) email = self.accept_terms_of_use(window)
xpub_hot = wallet.master_public_keys["x1/"] xpub_hot = wallet.master_public_keys["x1/"]
xpub_cold = wallet.master_public_keys["x2/"] xpub_cold = wallet.master_public_keys["x2/"]
# Generate third key deterministically. # Generate third key deterministically.
long_user_id, short_id = wallet.get_user_id() long_user_id, short_id = wallet.get_user_id()
xpub3 = make_xpub(signing_xpub, long_user_id) xpub3 = make_xpub(signing_xpub, long_user_id)
# secret must be sent by the server # secret must be sent by the server
try: try:
r = server.create(xpub_hot, xpub_cold, email) r = server.create(xpub_hot, xpub_cold, email)
@ -427,7 +413,6 @@ class TrustedCoinPlugin(BasePlugin):
r = None r = None
else: else:
raise e raise e
if r is None: if r is None:
otp_secret = None otp_secret = None
else: else:
@ -443,7 +428,8 @@ class TrustedCoinPlugin(BasePlugin):
except Exception as e: except Exception as e:
window.show_message(str(e)) window.show_message(str(e))
return return
if not self.setup_google_auth(window, short_id, otp_secret):
if self.setup_google_auth(window, short_id, otp_secret): window.show_message("otp error")
wallet.add_master_public_key('x3/', xpub3) return
wallet.create_main_account() wallet.add_master_public_key('x3/', xpub3)
window.run('create_addresses')

Loading…
Cancel
Save