3.7.2 • Published 8 months ago
@exodus/key-utils v3.7.2
@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] },
})