UNPKG

@polkadot/util-crypto

Version:
34 lines (33 loc) 1.23 kB
import { keccak_256 as keccak256Js, keccak_512 as keccak512Js } from '@noble/hashes/sha3'; import { keccak256, keccak512 } from '@polkadot/wasm-crypto'; import { createAsHex, createBitHasher, createDualHasher } from '../helpers.js'; /** * @name keccakAsU8a * @summary Creates a keccak Uint8Array from the input. * @description * From either a `string` or a `Buffer` input, create the keccak and return the result as a `Uint8Array`. * @example * <BR> * * ```javascript * import { keccakAsU8a } from '@polkadot/util-crypto'; * * keccakAsU8a('123'); // => Uint8Array * ``` */ export const keccakAsU8a = /*#__PURE__*/ createDualHasher({ 256: keccak256, 512: keccak512 }, { 256: keccak256Js, 512: keccak512Js }); /** * @name keccak256AsU8a * @description Creates a keccak256 Uint8Array from the input. */ export const keccak256AsU8a = /*#__PURE__*/ createBitHasher(256, keccakAsU8a); /** * @name keccak512AsU8a * @description Creates a keccak512 Uint8Array from the input. */ export const keccak512AsU8a = /*#__PURE__*/ createBitHasher(512, keccakAsU8a); /** * @name keccakAsHex * @description Creates a keccak hex string from the input. */ export const keccakAsHex = /*#__PURE__*/ createAsHex(keccakAsU8a);