| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 | /** *  Cryptographic hashing functions * *  @_subsection: api/crypto:Hash Functions [about-crypto-hashing] */import { keccak_256 } from "@noble/hashes/sha3";import { getBytes, hexlify } from "../utils/index.js";import type { BytesLike } from "../utils/index.js";let locked = false;const _keccak256 = function(data: Uint8Array): Uint8Array {    return keccak_256(data);}let __keccak256: (data: Uint8Array) => BytesLike = _keccak256;/** *  Compute the cryptographic KECCAK256 hash of %%data%%. * *  The %%data%% **must** be a data representation, to compute the *  hash of UTF-8 data use the [[id]] function. * *  @returns DataHexstring *  @example: *    keccak256("0x") *    //_result: * *    keccak256("0x1337") *    //_result: * *    keccak256(new Uint8Array([ 0x13, 0x37 ])) *    //_result: * *    // Strings are assumed to be DataHexString, otherwise it will *    // throw. To hash UTF-8 data, see the note above. *    keccak256("Hello World") *    //_error: */export function keccak256(_data: BytesLike): string {    const data = getBytes(_data, "data");    return hexlify(__keccak256(data));}keccak256._ = _keccak256;keccak256.lock = function(): void { locked = true; }keccak256.register = function(func: (data: Uint8Array) => BytesLike) {    if (locked) { throw new TypeError("keccak256 is locked"); }    __keccak256 = func;}Object.freeze(keccak256);
 |