@hiero-ledger/cryptography
Version:
Cryptographic utilities and primitives for the Hiero SDK
52 lines (47 loc) • 1.39 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.decode = decode;
exports.encode = encode;
exports.hexZeroPadded = hexZeroPadded;
/**
* @param {Uint8Array} data
* @returns {string}
*/
function encode(data) {
return Buffer.from(data).toString("hex");
}
/**
* @param {string} text
* @returns {Uint8Array}
*/
function decode(text) {
const str = text.startsWith("0x") ? text.substring(2) : text;
return Buffer.from(str, "hex");
}
/**
* Encode with a specified length. Supports zero padding if the most significant byte is 0
*
* https://github.com/ethers-io/ethers.js/blob/master/packages/bytes/src.ts/index.ts#L315
* @param {Uint8Array} value
* @param {number} length
* @returns {string}
*/
function hexZeroPadded(value, length) {
const HexCharacters = "0123456789abcdef";
// https://github.com/ethers-io/ethers.js/blob/master/packages/bytes/src.ts/index.ts#L243
let result = "0x";
for (let i = 0; i < value.length; i++) {
let v = value[i];
result += HexCharacters[(v & 0xf0) >> 4] + HexCharacters[v & 0x0f];
}
// https://github.com/ethers-io/ethers.js/blob/master/packages/bytes/src.ts/index.ts#L315
if (result.length > 2 * length + 2) {
console.log("result out of range", "result");
}
while (result.length < 2 * length + 2) {
result = "0x0" + result.substring(2);
}
return result.substring(2);
}