19 lines
874 B
JavaScript
19 lines
874 B
JavaScript
import { sha256 } from '@noble/hashes/sha2.js'
|
|
import { makeBase58check } from './fallback/base58check.js'
|
|
|
|
// Note: while API is async, we use hashSync for now until we improve webcrypto perf for hash256
|
|
// Inputs to base58 are typically very small, and that makes a difference
|
|
|
|
// Note: using native WebCrypto will have to have account for SharedArrayBuffer
|
|
|
|
const hash256sync = (x) => sha256(sha256(x))
|
|
const hash256 = hash256sync // See note at the top
|
|
|
|
const b58c = /* @__PURE__ */ makeBase58check(hash256, hash256sync)
|
|
export const toBase58check = /* @__PURE__ */ (() => b58c.encode)()
|
|
export const fromBase58check = /* @__PURE__ */ (() => b58c.decode)()
|
|
export const toBase58checkSync = /* @__PURE__ */ (() => b58c.encodeSync)()
|
|
export const fromBase58checkSync = /* @__PURE__ */ (() => b58c.decodeSync)()
|
|
|
|
export { makeBase58check } from './fallback/base58check.js'
|