@ethereumjs/wallet
Version:
Utilities for handling Ethereum keys
72 lines (61 loc) • 1.97 kB
text/typescript
import { mnemonicToSeedSync } from 'ethereum-cryptography/bip39/index.js'
import { HDKey } from 'ethereum-cryptography/hdkey.js'
import { Wallet } from './wallet.js'
export class EthereumHDKey {
/**
* Creates an instance based on a seed.
*/
public static fromMasterSeed(seedBuffer: Uint8Array): EthereumHDKey {
return new EthereumHDKey(HDKey.fromMasterSeed(seedBuffer))
}
/**
* Creates an instance based on BIP39 mnemonic phrases
*/
public static fromMnemonic(mnemonic: string, passphrase?: string): EthereumHDKey {
return EthereumHDKey.fromMasterSeed(mnemonicToSeedSync(mnemonic, passphrase))
}
/**
* Create an instance based on a BIP32 extended private or public key.
*/
public static fromExtendedKey(base58Key: string): EthereumHDKey {
return new EthereumHDKey(HDKey.fromExtendedKey(base58Key))
}
constructor(private readonly _hdkey: HDKey) {}
/**
* Returns a BIP32 extended private key (xprv)
*/
public privateExtendedKey(): string {
if (!this._hdkey.privateExtendedKey) {
throw new Error('This is a public key only wallet')
}
return this._hdkey.privateExtendedKey
}
/**
* Return a BIP32 extended public key (xpub)
*/
public publicExtendedKey(): string {
return this._hdkey.publicExtendedKey
}
/**
* Derives a node based on a path (e.g. m/44'/0'/0/1)
*/
public derivePath(path: string): EthereumHDKey {
return new EthereumHDKey(this._hdkey.derive(path))
}
/**
* Derive a node based on a child index
*/
public deriveChild(index: number): EthereumHDKey {
return new EthereumHDKey(this._hdkey.deriveChild(index))
}
/**
* Return a `Wallet` instance as seen above
*/
public getWallet(): Wallet {
if (this._hdkey.privateKey) {
return Wallet.fromPrivateKey(this._hdkey.privateKey)
}
if (!this._hdkey.publicKey) throw new Error('No hdkey')
return Wallet.fromPublicKey(this._hdkey.publicKey, true)
}
}