|
@ -1,6 +1,7 @@ |
|
|
// @flow
|
|
|
// @flow
|
|
|
import { Observable } from 'rxjs' |
|
|
import { Observable } from 'rxjs' |
|
|
import { BigNumber } from 'bignumber.js' |
|
|
import { BigNumber } from 'bignumber.js' |
|
|
|
|
|
import logger from 'logger' |
|
|
import React from 'react' |
|
|
import React from 'react' |
|
|
import FeesField from 'components/FeesField/EthereumKind' |
|
|
import FeesField from 'components/FeesField/EthereumKind' |
|
|
import AdvancedOptions from 'components/AdvancedOptions/EthereumKind' |
|
|
import AdvancedOptions from 'components/AdvancedOptions/EthereumKind' |
|
@ -184,7 +185,7 @@ const EthereumBridge: WalletBridge<Transaction> = { |
|
|
index, |
|
|
index, |
|
|
{ address, path: freshAddressPath, publicKey }, |
|
|
{ address, path: freshAddressPath, publicKey }, |
|
|
isStandard, |
|
|
isStandard, |
|
|
mandatoryCount, |
|
|
shouldSkipEmpty, |
|
|
): { 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 } |
|
@ -221,7 +222,7 @@ const EthereumBridge: WalletBridge<Transaction> = { |
|
|
newAccountCount++ |
|
|
newAccountCount++ |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (index < mandatoryCount) { |
|
|
if (shouldSkipEmpty) { |
|
|
return {} |
|
|
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
|
|
@ -262,6 +263,8 @@ const EthereumBridge: WalletBridge<Transaction> = { |
|
|
const last = derivations[derivations.length - 1] |
|
|
const last = derivations[derivations.length - 1] |
|
|
for (const derivation of derivations) { |
|
|
for (const derivation of derivations) { |
|
|
const isStandard = last === derivation |
|
|
const isStandard = last === derivation |
|
|
|
|
|
let emptyCount = 0 |
|
|
|
|
|
const mandatoryEmptyAccountSkip = derivation.mandatoryEmptyAccountSkip || 0 |
|
|
for (let index = 0; index < 255; index++) { |
|
|
for (let index = 0; index < 255; index++) { |
|
|
const freshAddressPath = derivation({ currency, x: index, segwit: false }) |
|
|
const freshAddressPath = derivation({ currency, x: index, segwit: false }) |
|
|
const res = await getAddressCommand |
|
|
const res = await getAddressCommand |
|
@ -271,10 +274,18 @@ const EthereumBridge: WalletBridge<Transaction> = { |
|
|
index, |
|
|
index, |
|
|
res, |
|
|
res, |
|
|
isStandard, |
|
|
isStandard, |
|
|
// $FlowFixMe i know i know, not part of function
|
|
|
emptyCount < mandatoryEmptyAccountSkip, |
|
|
derivation.mandatoryCount || 0, |
|
|
|
|
|
) |
|
|
) |
|
|
if (r.account) o.next(r.account) |
|
|
logger.log( |
|
|
|
|
|
`scanning ${currency.id} at ${freshAddressPath}: ${res.address} resulted of ${ |
|
|
|
|
|
r.account ? `Account with ${r.account.operations.length} txs` : 'no account' |
|
|
|
|
|
}. ${r.complete ? 'ALL SCANNED' : ''}`,
|
|
|
|
|
|
) |
|
|
|
|
|
if (r.account) { |
|
|
|
|
|
o.next(r.account) |
|
|
|
|
|
} else { |
|
|
|
|
|
emptyCount++ |
|
|
|
|
|
} |
|
|
if (r.complete) { |
|
|
if (r.complete) { |
|
|
break |
|
|
break |
|
|
} |
|
|
} |
|
|