synthetix-mintr
synthetix-mintr copied to clipboard
Add Live Derivation path for Ledger
Ledger derives ETH addresses from two different paths:
- Ledger Live:
m/44'/60'/0'/0
- Chrome apps/ Mew:
m/44'/60'/0'
Right now we're only using Chrome/MEW. Ledger Live derivation needs to be added. I've recently made the change into synthetix-js so the Ledger constructor is able to take a custom derivation path parameter.
const LEDGER_DERIVATION_PATH = "44'/60'/0'/";
class LedgerSigner extends Signer {
constructor({ provider, chainId, addressIndex, derivationPath } = {}) {
super();
...
this.derivationPath = derivationPath || LEDGER_DERIVATION_PATH;
}
So it is now possible to do something like:
const signer = new snxJSConnector.signers['Ledger']({derivationPath: 'xx/xx/xx'})
Here's the design which means to be implemented in the Wallet selection screen:
data:image/s3,"s3://crabby-images/b1b70/b1b7086df95d6763dbe70ef7dd504a16ee484af5" alt="Screen Shot 2019-11-18 at 1 57 28 pm"
@bachstatter I would say this one is probably highest priority as we've got lots of users asking for it in Discord.
data:image/s3,"s3://crabby-images/41d3f/41d3f38bd225c0371ca07b9900222fd153cbf89e" alt="Screen Shot 2019-11-18 at 2 11 35 pm"
@bachstatter here's the copy (I don't think it needs translation).
I've tested minted and burning on both page one and page 2 with a trezor and it all seems to work fine!