@exodus/key-utils
v3.7.0
Published
Utilities to manage derivation paths and key identifier aspects.
Downloads
15,171
Readme
@exodus/key-utils
Utilities to manage derivation paths and key identifier aspects.
Usage
assertKeyIdentifierParameters
can be used to verify that getKeyIdentifer
is supplied with the right arguments.
import { assertKeyIdentifierParameters } from '@exodus/key-utils'
export function createGetKeyIdentifier({
bip44,
assetName,
derivationAlgorithm = 'BIP32',
keyType = 'secp256k1',
}) {
return (params = {}) => {
params = { accountIndex: 0, addressIndex: 0, chainIndex: 0, ...params }
assertKeyIdentifierParameters(params)
// ...
}
}
This library also comes with a getKeyIdentifier
factory, that is configurable and should be able to fit most assets needs:
const getKeyIdentifier = createGetKeyIdentifier({
bip44: assets.solana.bip44,
validationRules: { allowedChainIndices: [0, 1] },
})
// or for assets that support purpose 84, 86 as well
const getKeyIdentifier = createGetKeyIdentifier({
bip44: assets.bitcoin.bip44,
validationRules: { allowedChainIndices: [0, 1], allowedPurposes: [44, 84, 86] },
})