|
@ -19,7 +19,7 @@ |
|
|
from electrum import WalletStorage |
|
|
from electrum import WalletStorage |
|
|
from electrum.plugins import run_hook |
|
|
from electrum.plugins import run_hook |
|
|
from util import PrintError |
|
|
from util import PrintError |
|
|
from wallet import Wallet |
|
|
from wallet import Wallet, wallet_types |
|
|
from i18n import _ |
|
|
from i18n import _ |
|
|
|
|
|
|
|
|
MSG_GENERATING_WAIT = _("Electrum is generating your addresses, please wait...") |
|
|
MSG_GENERATING_WAIT = _("Electrum is generating your addresses, please wait...") |
|
@ -64,10 +64,10 @@ class WizardBase(PrintError): |
|
|
raise NotImplementedError |
|
|
raise NotImplementedError |
|
|
|
|
|
|
|
|
def query_create_or_restore(self, wallet_kinds): |
|
|
def query_create_or_restore(self, wallet_kinds): |
|
|
"""Ask the user what they want to do, and to what wallet kind. |
|
|
"""Ask the user what they want to do, and which wallet kind. |
|
|
wallet_kinds is an array of tuples (kind, description). |
|
|
wallet_kinds is an array of translated wallet descriptions. |
|
|
Return a tuple (action, kind). Action is 'create' or 'restore', |
|
|
Return a a tuple (action, kind_index). Action is 'create' or |
|
|
and kind is one of the wallet kinds passed.""" |
|
|
'restore', and kind the index of the wallet kind chosen.""" |
|
|
raise NotImplementedError |
|
|
raise NotImplementedError |
|
|
|
|
|
|
|
|
def query_multisig(self, action): |
|
|
def query_multisig(self, action): |
|
@ -186,21 +186,25 @@ class WizardBase(PrintError): |
|
|
a wallet and return it.''' |
|
|
a wallet and return it.''' |
|
|
self.remove_from_recently_open(storage.path) |
|
|
self.remove_from_recently_open(storage.path) |
|
|
|
|
|
|
|
|
action, kind = self.query_create_or_restore(WizardBase.wallet_kinds) |
|
|
# Filter out any unregistered wallet kinds |
|
|
|
|
|
registered_kinds = zip(*wallet_types)[0] |
|
|
|
|
|
kinds, descriptions = zip(*[pair for pair in WizardBase.wallet_kinds |
|
|
|
|
|
if pair[0] in registered_kinds]) |
|
|
|
|
|
action, kind_index = self.query_create_or_restore(descriptions) |
|
|
|
|
|
|
|
|
assert action in WizardBase.user_actions |
|
|
assert action in WizardBase.user_actions |
|
|
assert kind in [k for k, desc in WizardBase.wallet_kinds] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kind = kinds[kind_index] |
|
|
if kind == 'multisig': |
|
|
if kind == 'multisig': |
|
|
wallet_type = self.query_multisig(action) |
|
|
wallet_type = self.query_multisig(action) |
|
|
elif kind == 'hardware': |
|
|
elif kind == 'hardware': |
|
|
wallet_types, choices = self.plugins.hardware_wallets(action) |
|
|
hw_wallet_types, choices = self.plugins.hardware_wallets(action) |
|
|
if action == 'create': |
|
|
if action == 'create': |
|
|
msg = _('Select the hardware wallet to create') |
|
|
msg = _('Select the hardware wallet to create') |
|
|
else: |
|
|
else: |
|
|
msg = _('Select the hardware wallet to restore') |
|
|
msg = _('Select the hardware wallet to restore') |
|
|
choice = self.query_choice(msg, choices) |
|
|
choice = self.query_choice(msg, choices) |
|
|
wallet_type = wallet_types[choice] |
|
|
wallet_type = hw_wallet_types[choice] |
|
|
elif kind == 'twofactor': |
|
|
elif kind == 'twofactor': |
|
|
wallet_type = '2fa' |
|
|
wallet_type = '2fa' |
|
|
else: |
|
|
else: |
|
|