forked from cerc-io/plugeth
accounts/usbwallet, signer/core: show accounts from ledger legacy derivation paths (#21517)
* accounts/usbwallet, signer/core: un-hide accounts from ledger legacy derivation paths * Update accounts/usbwallet/wallet.go * Update signer/core/api.go * Update signer/core/api.go
This commit is contained in:
parent
d54f2f2e5e
commit
8327d1fdfc
@ -368,18 +368,22 @@ func (w *wallet) selfDerive() {
|
|||||||
w.log.Warn("USB wallet nonce retrieval failed", "err", err)
|
w.log.Warn("USB wallet nonce retrieval failed", "err", err)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
// If the next account is empty, stop self-derivation, but add for the last base path
|
// We've just self-derived a new account, start tracking it locally
|
||||||
|
// unless the account was empty.
|
||||||
|
path := make(accounts.DerivationPath, len(nextPaths[i]))
|
||||||
|
copy(path[:], nextPaths[i][:])
|
||||||
if balance.Sign() == 0 && nonce == 0 {
|
if balance.Sign() == 0 && nonce == 0 {
|
||||||
empty = true
|
empty = true
|
||||||
|
// If it indeed was empty, make a log output for it anyway. In the case
|
||||||
|
// of legacy-ledger, the first account on the legacy-path will
|
||||||
|
// be shown to the user, even if we don't actively track it
|
||||||
if i < len(nextAddrs)-1 {
|
if i < len(nextAddrs)-1 {
|
||||||
|
w.log.Info("Skipping trakcking first account on legacy path, use personal.deriveAccount(<url>,<path>, false) to track",
|
||||||
|
"path", path, "address", nextAddrs[i])
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// We've just self-derived a new account, start tracking it locally
|
|
||||||
path := make(accounts.DerivationPath, len(nextPaths[i]))
|
|
||||||
copy(path[:], nextPaths[i][:])
|
|
||||||
paths = append(paths, path)
|
paths = append(paths, path)
|
||||||
|
|
||||||
account := accounts.Account{
|
account := accounts.Account{
|
||||||
Address: nextAddrs[i],
|
Address: nextAddrs[i],
|
||||||
URL: accounts.URL{Scheme: w.url.Scheme, Path: fmt.Sprintf("%s/%s", w.url.Path, path)},
|
URL: accounts.URL{Scheme: w.url.Scheme, Path: fmt.Sprintf("%s/%s", w.url.Path, path)},
|
||||||
|
@ -346,20 +346,29 @@ func (api *SignerAPI) startUSBListener() {
|
|||||||
case accounts.WalletOpened:
|
case accounts.WalletOpened:
|
||||||
status, _ := event.Wallet.Status()
|
status, _ := event.Wallet.Status()
|
||||||
log.Info("New wallet appeared", "url", event.Wallet.URL(), "status", status)
|
log.Info("New wallet appeared", "url", event.Wallet.URL(), "status", status)
|
||||||
|
var derive = func(numToDerive int, base accounts.DerivationPath) {
|
||||||
// Derive first N accounts, hardcoded for now
|
// Derive first N accounts, hardcoded for now
|
||||||
var nextPath = make(accounts.DerivationPath, len(accounts.DefaultBaseDerivationPath))
|
var nextPath = make(accounts.DerivationPath, len(base))
|
||||||
copy(nextPath[:], accounts.DefaultBaseDerivationPath[:])
|
copy(nextPath[:], base[:])
|
||||||
|
|
||||||
for i := 0; i < numberOfAccountsToDerive; i++ {
|
for i := 0; i < numToDerive; i++ {
|
||||||
acc, err := event.Wallet.Derive(nextPath, true)
|
acc, err := event.Wallet.Derive(nextPath, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Warn("account derivation failed", "error", err)
|
log.Warn("Account derivation failed", "error", err)
|
||||||
} else {
|
} else {
|
||||||
log.Info("derived account", "address", acc.Address)
|
log.Info("Derived account", "address", acc.Address, "path", nextPath)
|
||||||
}
|
}
|
||||||
nextPath[len(nextPath)-1]++
|
nextPath[len(nextPath)-1]++
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
if event.Wallet.URL().Scheme == "ledger" {
|
||||||
|
log.Info("Deriving ledger default paths")
|
||||||
|
derive(numberOfAccountsToDerive/2, accounts.DefaultBaseDerivationPath)
|
||||||
|
log.Info("Deriving ledger legacy paths")
|
||||||
|
derive(numberOfAccountsToDerive/2, accounts.LegacyLedgerBaseDerivationPath)
|
||||||
|
} else {
|
||||||
|
derive(numberOfAccountsToDerive, accounts.DefaultBaseDerivationPath)
|
||||||
|
}
|
||||||
case accounts.WalletDropped:
|
case accounts.WalletDropped:
|
||||||
log.Info("Old wallet dropped", "url", event.Wallet.URL())
|
log.Info("Old wallet dropped", "url", event.Wallet.URL())
|
||||||
event.Wallet.Close()
|
event.Wallet.Close()
|
||||||
|
Loading…
Reference in New Issue
Block a user