Browse Source

Merge pull request #6838 from SomberNight/202012_seed_type_old_2fa

mnemonic: tighten seed_type check for old "2fa" type seeds
patch-4
ThomasV 4 years ago
committed by GitHub
parent
commit
567130f4a3
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      electrum/mnemonic.py
  2. 27
      electrum/plugins/trustedcoin/trustedcoin.py

8
electrum/mnemonic.py

@ -241,13 +241,17 @@ def is_old_seed(seed: str) -> bool:
def seed_type(x: str) -> str: def seed_type(x: str) -> str:
num_words = len(x.split())
if is_old_seed(x): if is_old_seed(x):
return 'old' return 'old'
elif is_new_seed(x): elif is_new_seed(x, version.SEED_PREFIX):
return 'standard' return 'standard'
elif is_new_seed(x, version.SEED_PREFIX_SW): elif is_new_seed(x, version.SEED_PREFIX_SW):
return 'segwit' return 'segwit'
elif is_new_seed(x, version.SEED_PREFIX_2FA): elif is_new_seed(x, version.SEED_PREFIX_2FA) and (num_words == 12 or num_words >= 20):
# Note: in Electrum 2.7, there was a breaking change in key derivation
# for this seed type. Unfortunately the seed version/prefix was reused,
# and now we can only distinguish them based on number of words. :(
return '2fa' return '2fa'
elif is_new_seed(x, version.SEED_PREFIX_2FA_SW): elif is_new_seed(x, version.SEED_PREFIX_2FA_SW):
return '2fa_segwit' return '2fa_segwit'

27
electrum/plugins/trustedcoin/trustedcoin.py

@ -575,20 +575,25 @@ class TrustedCoinPlugin(BasePlugin):
raise Exception(f'unexpected seed type: {t}') raise Exception(f'unexpected seed type: {t}')
words = seed.split() words = seed.split()
n = len(words) n = len(words)
# old version use long seed phrases if t == '2fa':
if n >= 20: if n >= 20: # old scheme
# note: pre-2.7 2fa seeds were typically 24-25 words, however they # note: pre-2.7 2fa seeds were typically 24-25 words, however they
# could probabilistically be arbitrarily shorter due to a bug. (see #3611) # could probabilistically be arbitrarily shorter due to a bug. (see #3611)
# the probability of it being < 20 words is about 2^(-(256+12-19*11)) = 2^(-59) # the probability of it being < 20 words is about 2^(-(256+12-19*11)) = 2^(-59)
if passphrase != '': if passphrase != '':
raise Exception('old 2fa seed cannot have passphrase') raise Exception('old 2fa seed cannot have passphrase')
xprv1, xpub1 = self.get_xkeys(' '.join(words[0:12]), t, '', "m/") xprv1, xpub1 = self.get_xkeys(' '.join(words[0:12]), t, '', "m/")
xprv2, xpub2 = self.get_xkeys(' '.join(words[12:]), t, '', "m/") xprv2, xpub2 = self.get_xkeys(' '.join(words[12:]), t, '', "m/")
elif not t == '2fa' or n == 12: elif n == 12: # new scheme
xprv1, xpub1 = self.get_xkeys(seed, t, passphrase, "m/0'/")
xprv2, xpub2 = self.get_xkeys(seed, t, passphrase, "m/1'/")
else:
raise Exception(f'unrecognized seed length for "2fa" seed: {n}')
elif t == '2fa_segwit':
xprv1, xpub1 = self.get_xkeys(seed, t, passphrase, "m/0'/") xprv1, xpub1 = self.get_xkeys(seed, t, passphrase, "m/0'/")
xprv2, xpub2 = self.get_xkeys(seed, t, passphrase, "m/1'/") xprv2, xpub2 = self.get_xkeys(seed, t, passphrase, "m/1'/")
else: else:
raise Exception('unrecognized seed length: {} words'.format(n)) raise Exception(f'unexpected seed type: {t}')
return xprv1, xpub1, xprv2, xpub2 return xprv1, xpub1, xprv2, xpub2
def create_keystore(self, wizard, seed, passphrase): def create_keystore(self, wizard, seed, passphrase):

Loading…
Cancel
Save