UNPKG

943 BJavaScriptView Raw
1// Copyright 2017-2023 @polkadot/util-crypto authors & contributors
2// SPDX-License-Identifier: Apache-2.0
3
4import { BN_EIGHT, bnToU8a, u8aConcat, u8aToBn } from '@polkadot/util';
5import { BN_LE_32_OPTS, BN_LE_512_OPTS, BN_LE_OPTS } from "../../bn.js";
6import { hmacShaAsU8a } from "../../hmac/index.js";
7
8// performs hard-only derivation on the xprv
9export function ledgerDerivePrivate(xprv, index) {
10 const kl = xprv.subarray(0, 32);
11 const kr = xprv.subarray(32, 64);
12 const cc = xprv.subarray(64, 96);
13 const data = u8aConcat([0], kl, kr, bnToU8a(index, BN_LE_32_OPTS));
14 const z = hmacShaAsU8a(cc, data, 512);
15 data[0] = 0x01;
16 return u8aConcat(bnToU8a(u8aToBn(kl, BN_LE_OPTS).iadd(u8aToBn(z.subarray(0, 28), BN_LE_OPTS).imul(BN_EIGHT)), BN_LE_512_OPTS).subarray(0, 32), bnToU8a(u8aToBn(kr, BN_LE_OPTS).iadd(u8aToBn(z.subarray(32, 64), BN_LE_OPTS)), BN_LE_512_OPTS).subarray(0, 32), hmacShaAsU8a(cc, data, 512).subarray(32, 64));
17}
\No newline at end of file