Browse Source

Merge pull request #1053 from gre/fix-scan-5-first-mew-even-if-empty-in-middle

Always scan at least 5 MEW address even if user left empty accounts
master
Gaëtan Renaudeau 7 years ago
committed by GitHub
parent
commit
0a8b6c7514
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 13
      src/bridge/EthereumJSBridge.js
  2. 1
      src/helpers/derivations.js

13
src/bridge/EthereumJSBridge.js

@ -176,6 +176,7 @@ const EthereumBridge: WalletBridge<Transaction> = {
index, index,
{ address, path: freshAddressPath, publicKey }, { address, path: freshAddressPath, publicKey },
isStandard, isStandard,
mandatoryCount,
): { account?: Account, complete?: boolean } { ): { account?: Account, complete?: boolean } {
const balance = await api.getAccountBalance(address) const balance = await api.getAccountBalance(address)
if (finished) return { complete: true } if (finished) return { complete: true }
@ -211,6 +212,10 @@ const EthereumBridge: WalletBridge<Transaction> = {
} }
newAccountCount++ newAccountCount++
} }
if (index < mandatoryCount) {
return {}
}
// NB for legacy addresses maybe we will continue at least for the first 10 addresses // NB for legacy addresses maybe we will continue at least for the first 10 addresses
return { complete: true } return { complete: true }
} }
@ -254,7 +259,13 @@ const EthereumBridge: WalletBridge<Transaction> = {
const res = await getAddressCommand const res = await getAddressCommand
.send({ currencyId: currency.id, devicePath: deviceId, path: freshAddressPath }) .send({ currencyId: currency.id, devicePath: deviceId, path: freshAddressPath })
.toPromise() .toPromise()
const r = await stepAddress(index, res, isStandard) const r = await stepAddress(
index,
res,
isStandard,
// $FlowFixMe i know i know, not part of function
derivation.mandatoryCount || 0,
)
if (r.account) o.next(r.account) if (r.account) o.next(r.account)
if (r.complete) { if (r.complete) {
break break

1
src/helpers/derivations.js

@ -8,6 +8,7 @@ type Derivation = ({
}) => string }) => string
const ethLegacyMEW: Derivation = ({ x }) => `44'/60'/0'/${x}` const ethLegacyMEW: Derivation = ({ x }) => `44'/60'/0'/${x}`
ethLegacyMEW.mandatoryCount = 5
const etcLegacyMEW: Derivation = ({ x }) => `44'/60'/160720'/${x}'/0` const etcLegacyMEW: Derivation = ({ x }) => `44'/60'/160720'/${x}'/0`

Loading…
Cancel
Save