1 | /**
|
2 | * @name u8aToHex
|
3 | * @summary Creates a hex string from a Uint8Array object.
|
4 | * @description
|
5 | * `UInt8Array` input values return the actual hex string. `null` or `undefined` values returns an `0x` string.
|
6 | * @example
|
7 | * <BR>
|
8 | *
|
9 | * ```javascript
|
10 | * import { u8aToHex } from '@polkadot/util';
|
11 | *
|
12 | * u8aToHex(new Uint8Array([0x68, 0x65, 0x6c, 0x6c, 0xf])); // 0x68656c0f
|
13 | * ```
|
14 | */
|
15 | export function u8aToHex(value, bitLength = -1, isPrefixed = true) {
|
16 | const length = Math.ceil(bitLength / 8);
|
17 | return `${isPrefixed ? '0x' : ''}${!value?.length
|
18 | ? ''
|
19 | : (bitLength > 0 && value.length > length)
|
20 | ? `${Buffer.from(value.subarray(0, length / 2)).toString('hex')}…${Buffer.from(value.subarray(value.length - length / 2)).toString('hex')}`
|
21 | : Buffer.from(value).toString('hex')}`;
|
22 | }
|