From f0fe84d959d16c090cfd793efebf6af7d2d06a04 Mon Sep 17 00:00:00 2001 From: ThomasV Date: Thu, 14 Sep 2017 14:38:19 +0200 Subject: [PATCH] check xkey type when we add the keystore, so that we cover all cases --- lib/base_wizard.py | 17 +++++++++-------- lib/bitcoin.py | 3 +++ 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/lib/base_wizard.py b/lib/base_wizard.py index d81810918..5fcb136c7 100644 --- a/lib/base_wizard.py +++ b/lib/base_wizard.py @@ -160,15 +160,8 @@ class BaseWizard(object): ]) self.add_xpub_dialog(title=title, message=message, run_next=self.on_restore_from_key, is_valid=v) else: - def check_xkey_type(x): - if keystore.is_xpub(x): - return bitcoin.deserialize_xpub(x)[0] == self.seed_type - elif keystore.is_xprv(x): - return bitcoin.deserialize_xprv(x)[0] == self.seed_type - else: - return False i = len(self.keystores) + 1 - self.add_cosigner_dialog(index=i, run_next=self.on_restore_from_key, is_valid=check_xkey_type) + self.add_cosigner_dialog(index=i, run_next=self.on_restore_from_key, is_valid=keystore.is_bip32_key) def on_restore_from_key(self, text): k = keystore.from_keys(text) @@ -317,6 +310,14 @@ class BaseWizard(object): self.show_error(_('Error: duplicate master public key')) self.run('choose_keystore') return + from .bitcoin import xpub_type + if len(self.keystores)>0: + t1 = xpub_type(k.xpub) + t2 = xpub_type(self.keystores[0].xpub) + if t1 != t2: + self.show_error(_('Cannot add this cosigner:') + '\n' + "Their key type is '%s', we are '%s'"%(t1, t2)) + self.run('choose_keystore') + return self.keystores.append(k) if len(self.keystores) == 1: xpub = k.get_master_public_key() diff --git a/lib/bitcoin.py b/lib/bitcoin.py index a52d968ef..09323b58d 100644 --- a/lib/bitcoin.py +++ b/lib/bitcoin.py @@ -869,6 +869,9 @@ def deserialize_xpub(xkey): def deserialize_xprv(xkey): return deserialize_xkey(xkey, True) +def xpub_type(x): + return deserialize_xpub(x)[0] + def is_xpub(text): try: