Browse Source

follow-up prev: avoid storage key collision with old 'lightning_privkey'

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
SomberNight 6 years ago
committed by ThomasV
parent
commit
f3dd7ce615
  1. 4
      electrum/lnworker.py

4
electrum/lnworker.py

@ -62,13 +62,13 @@ class LNWorker(PrintError):
asyncio.run_coroutine_threadsafe(self.network.main_taskgroup.spawn(self.main_loop()), self.network.asyncio_loop) asyncio.run_coroutine_threadsafe(self.network.main_taskgroup.spawn(self.main_loop()), self.network.asyncio_loop)
def _read_ln_keystore(self) -> BIP32_KeyStore: def _read_ln_keystore(self) -> BIP32_KeyStore:
xprv = self.wallet.storage.get('lightning_privkey') xprv = self.wallet.storage.get('lightning_privkey2')
if xprv is None: if xprv is None:
# TODO derive this deterministically from wallet.keystore at keystore generation time # TODO derive this deterministically from wallet.keystore at keystore generation time
# probably along a hardened path ( lnd-equivalent would be m/1017'/coinType'/ ) # probably along a hardened path ( lnd-equivalent would be m/1017'/coinType'/ )
seed = os.urandom(32) seed = os.urandom(32)
xprv, xpub = bitcoin.bip32_root(seed, xtype='standard') xprv, xpub = bitcoin.bip32_root(seed, xtype='standard')
self.wallet.storage.put('lightning_privkey', xprv) self.wallet.storage.put('lightning_privkey2', xprv)
self.wallet.storage.write() self.wallet.storage.write()
return keystore.from_xprv(xprv) return keystore.from_xprv(xprv)

Loading…
Cancel
Save