From d4baf872d6471aecd949943a6979f8cd2209c00a Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Thu, 14 Mar 2024 21:33:08 +0000 Subject: [PATCH] Deploy to GitHub pages --- .nojekyll | 0 CNAME | 1 + assets/highlight.css | 127 ++ assets/main.js | 59 + assets/navigation.js | 1 + assets/search.js | 1 + assets/style.css | 1414 +++++++++++++++++ .../_zk_kit_eddsa_poseidon.EdDSAPoseidon.html | 20 + classes/_zk_kit_imt.IMT.html | 87 + classes/_zk_kit_imt.LeanIMT.html | 85 + classes/_zk_kit_smt.SMT.html | 95 ++ classes/_zk_kit_utils.F1Field.html | 92 ++ functions/_zk_kit_baby_jubjub.addPoint.html | 10 + functions/_zk_kit_baby_jubjub.inCurve.html | 5 + .../_zk_kit_baby_jubjub.mulPointEscalar.html | 6 + functions/_zk_kit_baby_jubjub.packPoint.html | 6 + .../_zk_kit_baby_jubjub.unpackPoint.html | 6 + ...zk_kit_eddsa_poseidon.derivePublicKey.html | 8 + ...kit_eddsa_poseidon.deriveSecretScalar.html | 10 + .../_zk_kit_eddsa_poseidon.packPublicKey.html | 5 + .../_zk_kit_eddsa_poseidon.signMessage.html | 6 + ...zk_kit_eddsa_poseidon.unpackPublicKey.html | 5 + ...zk_kit_eddsa_poseidon.verifySignature.html | 6 + functions/_zk_kit_eddsa_proof.generate.html | 14 + functions/_zk_kit_eddsa_proof.verify.html | 4 + functions/_zk_kit_groth16.buildBn128.html | 4 + functions/_zk_kit_groth16.prove.html | 6 + functions/_zk_kit_groth16.verify.html | 5 + ...ytower.LazyTowerHashChainProofBuilder.html | 12 + .../_zk_kit_poseidon_cipher.checkEqual.html | 5 + .../_zk_kit_poseidon_cipher.normalize.html | 5 + ...k_kit_poseidon_cipher.poseidonDecrypt.html | 7 + ...on_cipher.poseidonDecryptWithoutCheck.html | 8 + ...k_kit_poseidon_cipher.poseidonEncrypt.html | 6 + .../_zk_kit_poseidon_cipher.poseidonPerm.html | 4 + functions/_zk_kit_poseidon_cipher.pow5.html | 4 + ...it_poseidon_cipher.unstringifyBigInts.html | 5 + ..._zk_kit_poseidon_cipher.validateNonce.html | 3 + .../_zk_kit_poseidon_proof.generate.html | 14 + functions/_zk_kit_poseidon_proof.verify.html | 3 + functions/_zk_kit_smt.checkHex.html | 4 + .../_zk_kit_smt.getFirstCommonElements.html | 5 + ..._kit_smt.getIndexOfLastNonZeroElement.html | 5 + functions/_zk_kit_smt.hexToBin.html | 4 + functions/_zk_kit_smt.keyToPath.html | 5 + ...it_utils.conversions.beBigIntToBuffer.html | 9 + ...it_utils.conversions.beBufferToBigInt.html | 4 + ...ils.conversions.beHexadecimalToBigInt.html | 5 + ..._kit_utils.conversions.bigIntToBuffer.html | 4 + ...utils.conversions.bigIntToHexadecimal.html | 4 + ...tils.conversions.bigNumberishToBigInt.html | 6 + ...tils.conversions.bigNumberishToBuffer.html | 6 + ..._kit_utils.conversions.bufferToBigInt.html | 4 + ...utils.conversions.bufferToHexadecimal.html | 5 + ...utils.conversions.hexadecimalToBigInt.html | 4 + ...utils.conversions.hexadecimalToBuffer.html | 5 + ...it_utils.conversions.leBigIntToBuffer.html | 9 + ...it_utils.conversions.leBufferToBigInt.html | 4 + .../_zk_kit_utils.crypto.getRandomValues.html | 4 + ..._kit_utils.errorHandlers.requireArray.html | 4 + ...kit_utils.errorHandlers.requireBigInt.html | 4 + ..._utils.errorHandlers.requireBigNumber.html | 4 + ...ils.errorHandlers.requireBigNumberish.html | 4 + ...kit_utils.errorHandlers.requireBuffer.html | 4 + ...it_utils.errorHandlers.requireDefined.html | 4 + ...t_utils.errorHandlers.requireFunction.html | 4 + ...tils.errorHandlers.requireHexadecimal.html | 8 + ...kit_utils.errorHandlers.requireNumber.html | 4 + ...kit_utils.errorHandlers.requireObject.html | 5 + ...kit_utils.errorHandlers.requireString.html | 4 + ...rrorHandlers.requireStringifiedBigInt.html | 4 + ..._kit_utils.errorHandlers.requireTypes.html | 4 + ...utils.errorHandlers.requireUint8Array.html | 4 + ...zk_kit_utils.packing.packGroth16Proof.html | 4 + ..._kit_utils.packing.unpackGroth16Proof.html | 4 + functions/_zk_kit_utils.scalar.bits.html | 7 + functions/_zk_kit_utils.scalar.gt.html | 5 + functions/_zk_kit_utils.scalar.isOdd.html | 4 + functions/_zk_kit_utils.scalar.isZero.html | 4 + functions/_zk_kit_utils.scalar.mul.html | 5 + .../_zk_kit_utils.scalar.shiftRight.html | 7 + .../_zk_kit_utils.typeChecks.isArray.html | 3 + .../_zk_kit_utils.typeChecks.isBigInt.html | 3 + .../_zk_kit_utils.typeChecks.isBigNumber.html | 5 + ...k_kit_utils.typeChecks.isBigNumberish.html | 7 + .../_zk_kit_utils.typeChecks.isBuffer.html | 3 + .../_zk_kit_utils.typeChecks.isDefined.html | 3 + .../_zk_kit_utils.typeChecks.isFunction.html | 3 + ...zk_kit_utils.typeChecks.isHexadecimal.html | 7 + .../_zk_kit_utils.typeChecks.isNumber.html | 3 + .../_zk_kit_utils.typeChecks.isObject.html | 4 + .../_zk_kit_utils.typeChecks.isString.html | 3 + ..._utils.typeChecks.isStringifiedBigInt.html | 3 + ..._kit_utils.typeChecks.isSupportedType.html | 4 + .../_zk_kit_utils.typeChecks.isType.html | 4 + ..._zk_kit_utils.typeChecks.isUint8Array.html | 3 + hierarchy.html | 1 + index.html | 410 +++++ .../_zk_kit_groth16.CircuitSignals.html | 1 + interfaces/_zk_kit_groth16.Groth16Proof.html | 6 + interfaces/_zk_kit_smt.EntryResponse.html | 4 + interfaces/_zk_kit_smt.MerkleProof.html | 6 + modules/_zk_kit_baby_jubjub.html | 78 + modules/_zk_kit_circuits.html | 72 + modules/_zk_kit_eddsa_poseidon.html | 88 + modules/_zk_kit_eddsa_proof.html | 88 + modules/_zk_kit_groth16.html | 85 + modules/_zk_kit_imt.html | 74 + modules/_zk_kit_lazytower.html | 67 + modules/_zk_kit_poseidon_cipher.html | 80 + modules/_zk_kit_poseidon_proof.html | 93 ++ modules/_zk_kit_smt.html | 82 + modules/_zk_kit_utils.conversions.html | 14 + modules/_zk_kit_utils.crypto.html | 2 + modules/_zk_kit_utils.errorHandlers.html | 15 + modules/_zk_kit_utils.html | 117 ++ modules/_zk_kit_utils.packing.html | 3 + modules/_zk_kit_utils.scalar.html | 7 + modules/_zk_kit_utils.typeChecks.html | 17 + types/_zk_kit_baby_jubjub.Point.html | 1 + types/_zk_kit_eddsa_poseidon.Signature.html | 1 + types/_zk_kit_eddsa_proof.EddsaProof.html | 1 + types/_zk_kit_eddsa_proof.SnarkArtifacts.html | 1 + types/_zk_kit_groth16.NumericString.html | 1 + types/_zk_kit_groth16.PublicSignals.html | 1 + types/_zk_kit_groth16.SignalValueType.html | 1 + types/_zk_kit_groth16.ZKArtifact.html | 1 + types/_zk_kit_imt.IMTHashFunction.html | 3 + types/_zk_kit_imt.IMTMerkleProof.html | 9 + types/_zk_kit_imt.IMTNode.html | 2 + types/_zk_kit_imt.LeanIMTHashFunction.html | 3 + types/_zk_kit_imt.LeanIMTMerkleProof.html | 9 + ...kit_lazytower.LazyTowerHashChainProof.html | 1 + .../_zk_kit_poseidon_cipher.BigIntOutput.html | 1 + types/_zk_kit_poseidon_cipher.CipherText.html | 1 + ..._zk_kit_poseidon_cipher.EncryptionKey.html | 1 + types/_zk_kit_poseidon_cipher.Nonce.html | 1 + types/_zk_kit_poseidon_cipher.PlainText.html | 1 + ..._kit_poseidon_cipher.StringifiedInput.html | 1 + .../_zk_kit_poseidon_proof.PoseidonProof.html | 1 + ..._zk_kit_poseidon_proof.SnarkArtifacts.html | 1 + types/_zk_kit_smt.ChildNodes.html | 1 + types/_zk_kit_smt.Entry.html | 1 + types/_zk_kit_smt.EntryMark.html | 1 + types/_zk_kit_smt.HashFunction.html | 1 + types/_zk_kit_smt.Key.html | 1 + types/_zk_kit_smt.Node.html | 1 + types/_zk_kit_smt.Siblings.html | 1 + types/_zk_kit_smt.Value.html | 1 + types/_zk_kit_utils.BigNumber.html | 1 + types/_zk_kit_utils.BigNumberish.html | 1 + types/_zk_kit_utils.PackedGroth16Proof.html | 1 + ...zk_kit_utils.typeChecks.SupportedType.html | 1 + variables/_zk_kit_baby_jubjub.Base8.html | 1 + variables/_zk_kit_baby_jubjub.Fr.html | 1 + variables/_zk_kit_baby_jubjub.order.html | 1 + variables/_zk_kit_baby_jubjub.r.html | 3 + variables/_zk_kit_baby_jubjub.subOrder.html | 1 + variables/_zk_kit_poseidon_cipher.C.html | 1 + variables/_zk_kit_poseidon_cipher.M.html | 1 + 160 files changed, 3893 insertions(+) create mode 100644 .nojekyll create mode 100644 CNAME create mode 100644 assets/highlight.css create mode 100644 assets/main.js create mode 100644 assets/navigation.js create mode 100644 assets/search.js create mode 100644 assets/style.css create mode 100644 classes/_zk_kit_eddsa_poseidon.EdDSAPoseidon.html create mode 100644 classes/_zk_kit_imt.IMT.html create mode 100644 classes/_zk_kit_imt.LeanIMT.html create mode 100644 classes/_zk_kit_smt.SMT.html create mode 100644 classes/_zk_kit_utils.F1Field.html create mode 100644 functions/_zk_kit_baby_jubjub.addPoint.html create mode 100644 functions/_zk_kit_baby_jubjub.inCurve.html create mode 100644 functions/_zk_kit_baby_jubjub.mulPointEscalar.html create mode 100644 functions/_zk_kit_baby_jubjub.packPoint.html create mode 100644 functions/_zk_kit_baby_jubjub.unpackPoint.html create mode 100644 functions/_zk_kit_eddsa_poseidon.derivePublicKey.html create mode 100644 functions/_zk_kit_eddsa_poseidon.deriveSecretScalar.html create mode 100644 functions/_zk_kit_eddsa_poseidon.packPublicKey.html create mode 100644 functions/_zk_kit_eddsa_poseidon.signMessage.html create mode 100644 functions/_zk_kit_eddsa_poseidon.unpackPublicKey.html create mode 100644 functions/_zk_kit_eddsa_poseidon.verifySignature.html create mode 100644 functions/_zk_kit_eddsa_proof.generate.html create mode 100644 functions/_zk_kit_eddsa_proof.verify.html create mode 100644 functions/_zk_kit_groth16.buildBn128.html create mode 100644 functions/_zk_kit_groth16.prove.html create mode 100644 functions/_zk_kit_groth16.verify.html create mode 100644 functions/_zk_kit_lazytower.LazyTowerHashChainProofBuilder.html create mode 100644 functions/_zk_kit_poseidon_cipher.checkEqual.html create mode 100644 functions/_zk_kit_poseidon_cipher.normalize.html create mode 100644 functions/_zk_kit_poseidon_cipher.poseidonDecrypt.html create mode 100644 functions/_zk_kit_poseidon_cipher.poseidonDecryptWithoutCheck.html create mode 100644 functions/_zk_kit_poseidon_cipher.poseidonEncrypt.html create mode 100644 functions/_zk_kit_poseidon_cipher.poseidonPerm.html create mode 100644 functions/_zk_kit_poseidon_cipher.pow5.html create mode 100644 functions/_zk_kit_poseidon_cipher.unstringifyBigInts.html create mode 100644 functions/_zk_kit_poseidon_cipher.validateNonce.html create mode 100644 functions/_zk_kit_poseidon_proof.generate.html create mode 100644 functions/_zk_kit_poseidon_proof.verify.html create mode 100644 functions/_zk_kit_smt.checkHex.html create mode 100644 functions/_zk_kit_smt.getFirstCommonElements.html create mode 100644 functions/_zk_kit_smt.getIndexOfLastNonZeroElement.html create mode 100644 functions/_zk_kit_smt.hexToBin.html create mode 100644 functions/_zk_kit_smt.keyToPath.html create mode 100644 functions/_zk_kit_utils.conversions.beBigIntToBuffer.html create mode 100644 functions/_zk_kit_utils.conversions.beBufferToBigInt.html create mode 100644 functions/_zk_kit_utils.conversions.beHexadecimalToBigInt.html create mode 100644 functions/_zk_kit_utils.conversions.bigIntToBuffer.html create mode 100644 functions/_zk_kit_utils.conversions.bigIntToHexadecimal.html create mode 100644 functions/_zk_kit_utils.conversions.bigNumberishToBigInt.html create mode 100644 functions/_zk_kit_utils.conversions.bigNumberishToBuffer.html create mode 100644 functions/_zk_kit_utils.conversions.bufferToBigInt.html create mode 100644 functions/_zk_kit_utils.conversions.bufferToHexadecimal.html create mode 100644 functions/_zk_kit_utils.conversions.hexadecimalToBigInt.html create mode 100644 functions/_zk_kit_utils.conversions.hexadecimalToBuffer.html create mode 100644 functions/_zk_kit_utils.conversions.leBigIntToBuffer.html create mode 100644 functions/_zk_kit_utils.conversions.leBufferToBigInt.html create mode 100644 functions/_zk_kit_utils.crypto.getRandomValues.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireArray.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireBigInt.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireBigNumber.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireBigNumberish.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireBuffer.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireDefined.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireFunction.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireHexadecimal.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireNumber.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireObject.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireString.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireStringifiedBigInt.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireTypes.html create mode 100644 functions/_zk_kit_utils.errorHandlers.requireUint8Array.html create mode 100644 functions/_zk_kit_utils.packing.packGroth16Proof.html create mode 100644 functions/_zk_kit_utils.packing.unpackGroth16Proof.html create mode 100644 functions/_zk_kit_utils.scalar.bits.html create mode 100644 functions/_zk_kit_utils.scalar.gt.html create mode 100644 functions/_zk_kit_utils.scalar.isOdd.html create mode 100644 functions/_zk_kit_utils.scalar.isZero.html create mode 100644 functions/_zk_kit_utils.scalar.mul.html create mode 100644 functions/_zk_kit_utils.scalar.shiftRight.html create mode 100644 functions/_zk_kit_utils.typeChecks.isArray.html create mode 100644 functions/_zk_kit_utils.typeChecks.isBigInt.html create mode 100644 functions/_zk_kit_utils.typeChecks.isBigNumber.html create mode 100644 functions/_zk_kit_utils.typeChecks.isBigNumberish.html create mode 100644 functions/_zk_kit_utils.typeChecks.isBuffer.html create mode 100644 functions/_zk_kit_utils.typeChecks.isDefined.html create mode 100644 functions/_zk_kit_utils.typeChecks.isFunction.html create mode 100644 functions/_zk_kit_utils.typeChecks.isHexadecimal.html create mode 100644 functions/_zk_kit_utils.typeChecks.isNumber.html create mode 100644 functions/_zk_kit_utils.typeChecks.isObject.html create mode 100644 functions/_zk_kit_utils.typeChecks.isString.html create mode 100644 functions/_zk_kit_utils.typeChecks.isStringifiedBigInt.html create mode 100644 functions/_zk_kit_utils.typeChecks.isSupportedType.html create mode 100644 functions/_zk_kit_utils.typeChecks.isType.html create mode 100644 functions/_zk_kit_utils.typeChecks.isUint8Array.html create mode 100644 hierarchy.html create mode 100644 index.html create mode 100644 interfaces/_zk_kit_groth16.CircuitSignals.html create mode 100644 interfaces/_zk_kit_groth16.Groth16Proof.html create mode 100644 interfaces/_zk_kit_smt.EntryResponse.html create mode 100644 interfaces/_zk_kit_smt.MerkleProof.html create mode 100644 modules/_zk_kit_baby_jubjub.html create mode 100644 modules/_zk_kit_circuits.html create mode 100644 modules/_zk_kit_eddsa_poseidon.html create mode 100644 modules/_zk_kit_eddsa_proof.html create mode 100644 modules/_zk_kit_groth16.html create mode 100644 modules/_zk_kit_imt.html create mode 100644 modules/_zk_kit_lazytower.html create mode 100644 modules/_zk_kit_poseidon_cipher.html create mode 100644 modules/_zk_kit_poseidon_proof.html create mode 100644 modules/_zk_kit_smt.html create mode 100644 modules/_zk_kit_utils.conversions.html create mode 100644 modules/_zk_kit_utils.crypto.html create mode 100644 modules/_zk_kit_utils.errorHandlers.html create mode 100644 modules/_zk_kit_utils.html create mode 100644 modules/_zk_kit_utils.packing.html create mode 100644 modules/_zk_kit_utils.scalar.html create mode 100644 modules/_zk_kit_utils.typeChecks.html create mode 100644 types/_zk_kit_baby_jubjub.Point.html create mode 100644 types/_zk_kit_eddsa_poseidon.Signature.html create mode 100644 types/_zk_kit_eddsa_proof.EddsaProof.html create mode 100644 types/_zk_kit_eddsa_proof.SnarkArtifacts.html create mode 100644 types/_zk_kit_groth16.NumericString.html create mode 100644 types/_zk_kit_groth16.PublicSignals.html create mode 100644 types/_zk_kit_groth16.SignalValueType.html create mode 100644 types/_zk_kit_groth16.ZKArtifact.html create mode 100644 types/_zk_kit_imt.IMTHashFunction.html create mode 100644 types/_zk_kit_imt.IMTMerkleProof.html create mode 100644 types/_zk_kit_imt.IMTNode.html create mode 100644 types/_zk_kit_imt.LeanIMTHashFunction.html create mode 100644 types/_zk_kit_imt.LeanIMTMerkleProof.html create mode 100644 types/_zk_kit_lazytower.LazyTowerHashChainProof.html create mode 100644 types/_zk_kit_poseidon_cipher.BigIntOutput.html create mode 100644 types/_zk_kit_poseidon_cipher.CipherText.html create mode 100644 types/_zk_kit_poseidon_cipher.EncryptionKey.html create mode 100644 types/_zk_kit_poseidon_cipher.Nonce.html create mode 100644 types/_zk_kit_poseidon_cipher.PlainText.html create mode 100644 types/_zk_kit_poseidon_cipher.StringifiedInput.html create mode 100644 types/_zk_kit_poseidon_proof.PoseidonProof.html create mode 100644 types/_zk_kit_poseidon_proof.SnarkArtifacts.html create mode 100644 types/_zk_kit_smt.ChildNodes.html create mode 100644 types/_zk_kit_smt.Entry.html create mode 100644 types/_zk_kit_smt.EntryMark.html create mode 100644 types/_zk_kit_smt.HashFunction.html create mode 100644 types/_zk_kit_smt.Key.html create mode 100644 types/_zk_kit_smt.Node.html create mode 100644 types/_zk_kit_smt.Siblings.html create mode 100644 types/_zk_kit_smt.Value.html create mode 100644 types/_zk_kit_utils.BigNumber.html create mode 100644 types/_zk_kit_utils.BigNumberish.html create mode 100644 types/_zk_kit_utils.PackedGroth16Proof.html create mode 100644 types/_zk_kit_utils.typeChecks.SupportedType.html create mode 100644 variables/_zk_kit_baby_jubjub.Base8.html create mode 100644 variables/_zk_kit_baby_jubjub.Fr.html create mode 100644 variables/_zk_kit_baby_jubjub.order.html create mode 100644 variables/_zk_kit_baby_jubjub.r.html create mode 100644 variables/_zk_kit_baby_jubjub.subOrder.html create mode 100644 variables/_zk_kit_poseidon_cipher.C.html create mode 100644 variables/_zk_kit_poseidon_cipher.M.html diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 000000000..e69de29bb diff --git a/CNAME b/CNAME new file mode 100644 index 000000000..92ad0ab8e --- /dev/null +++ b/CNAME @@ -0,0 +1 @@ +zkkit.pse.dev \ No newline at end of file diff --git a/assets/highlight.css b/assets/highlight.css new file mode 100644 index 000000000..0fd0af8ba --- /dev/null +++ b/assets/highlight.css @@ -0,0 +1,127 @@ +:root { + --light-hl-0: #795E26; + --dark-hl-0: #DCDCAA; + --light-hl-1: #000000; + --dark-hl-1: #D4D4D4; + --light-hl-2: #A31515; + --dark-hl-2: #CE9178; + --light-hl-3: #008000; + --dark-hl-3: #6A9955; + --light-hl-4: #0000FF; + --dark-hl-4: #569CD6; + --light-hl-5: #800000; + --dark-hl-5: #808080; + --light-hl-6: #800000; + --dark-hl-6: #569CD6; + --light-hl-7: #000000FF; + --dark-hl-7: #D4D4D4; + --light-hl-8: #E50000; + --dark-hl-8: #9CDCFE; + --light-hl-9: #0000FF; + --dark-hl-9: #CE9178; + --light-hl-10: #AF00DB; + --dark-hl-10: #C586C0; + --light-hl-11: #001080; + --dark-hl-11: #9CDCFE; + --light-hl-12: #0070C1; + --dark-hl-12: #4FC1FF; + --light-hl-13: #267F99; + --dark-hl-13: #4EC9B0; + --light-hl-14: #098658; + --dark-hl-14: #B5CEA8; + --light-code-background: #FFFFFF; + --dark-code-background: #1E1E1E; +} + +@media (prefers-color-scheme: light) { :root { + --hl-0: var(--light-hl-0); + --hl-1: var(--light-hl-1); + --hl-2: var(--light-hl-2); + --hl-3: var(--light-hl-3); + --hl-4: var(--light-hl-4); + --hl-5: var(--light-hl-5); + --hl-6: var(--light-hl-6); + --hl-7: var(--light-hl-7); + --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --hl-12: var(--light-hl-12); + --hl-13: var(--light-hl-13); + --hl-14: var(--light-hl-14); + --code-background: var(--light-code-background); +} } + +@media (prefers-color-scheme: dark) { :root { + --hl-0: var(--dark-hl-0); + --hl-1: var(--dark-hl-1); + --hl-2: var(--dark-hl-2); + --hl-3: var(--dark-hl-3); + --hl-4: var(--dark-hl-4); + --hl-5: var(--dark-hl-5); + --hl-6: var(--dark-hl-6); + --hl-7: var(--dark-hl-7); + --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --hl-12: var(--dark-hl-12); + --hl-13: var(--dark-hl-13); + --hl-14: var(--dark-hl-14); + --code-background: var(--dark-code-background); +} } + +:root[data-theme='light'] { + --hl-0: var(--light-hl-0); + --hl-1: var(--light-hl-1); + --hl-2: var(--light-hl-2); + --hl-3: var(--light-hl-3); + --hl-4: var(--light-hl-4); + --hl-5: var(--light-hl-5); + --hl-6: var(--light-hl-6); + --hl-7: var(--light-hl-7); + --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --hl-12: var(--light-hl-12); + --hl-13: var(--light-hl-13); + --hl-14: var(--light-hl-14); + --code-background: var(--light-code-background); +} + +:root[data-theme='dark'] { + --hl-0: var(--dark-hl-0); + --hl-1: var(--dark-hl-1); + --hl-2: var(--dark-hl-2); + --hl-3: var(--dark-hl-3); + --hl-4: var(--dark-hl-4); + --hl-5: var(--dark-hl-5); + --hl-6: var(--dark-hl-6); + --hl-7: var(--dark-hl-7); + --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --hl-12: var(--dark-hl-12); + --hl-13: var(--dark-hl-13); + --hl-14: var(--dark-hl-14); + --code-background: var(--dark-code-background); +} + +.hl-0 { color: var(--hl-0); } +.hl-1 { color: var(--hl-1); } +.hl-2 { color: var(--hl-2); } +.hl-3 { color: var(--hl-3); } +.hl-4 { color: var(--hl-4); } +.hl-5 { color: var(--hl-5); } +.hl-6 { color: var(--hl-6); } +.hl-7 { color: var(--hl-7); } +.hl-8 { color: var(--hl-8); } +.hl-9 { color: var(--hl-9); } +.hl-10 { color: var(--hl-10); } +.hl-11 { color: var(--hl-11); } +.hl-12 { color: var(--hl-12); } +.hl-13 { color: var(--hl-13); } +.hl-14 { color: var(--hl-14); } +pre, code { background: var(--code-background); } diff --git a/assets/main.js b/assets/main.js new file mode 100644 index 000000000..3092fea0e --- /dev/null +++ b/assets/main.js @@ -0,0 +1,59 @@ +"use strict"; +"use strict";(()=>{var Ie=Object.create;var ne=Object.defineProperty;var Pe=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var _e=Object.getPrototypeOf,Re=Object.prototype.hasOwnProperty;var Me=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var Fe=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Oe(e))!Re.call(t,i)&&i!==n&&ne(t,i,{get:()=>e[i],enumerable:!(r=Pe(e,i))||r.enumerable});return t};var De=(t,e,n)=>(n=t!=null?Ie(_e(t)):{},Fe(e||!t||!t.__esModule?ne(n,"default",{value:t,enumerable:!0}):n,t));var ae=Me((se,oe)=>{(function(){var t=function(e){var n=new t.Builder;return n.pipeline.add(t.trimmer,t.stopWordFilter,t.stemmer),n.searchPipeline.add(t.stemmer),e.call(n,n),n.build()};t.version="2.3.9";t.utils={},t.utils.warn=function(e){return function(n){e.console&&console.warn&&console.warn(n)}}(this),t.utils.asString=function(e){return e==null?"":e.toString()},t.utils.clone=function(e){if(e==null)return e;for(var n=Object.create(null),r=Object.keys(e),i=0;i0){var d=t.utils.clone(n)||{};d.position=[a,u],d.index=s.length,s.push(new t.Token(r.slice(a,o),d))}a=o+1}}return s},t.tokenizer.separator=/[\s\-]+/;t.Pipeline=function(){this._stack=[]},t.Pipeline.registeredFunctions=Object.create(null),t.Pipeline.registerFunction=function(e,n){n in this.registeredFunctions&&t.utils.warn("Overwriting existing registered function: "+n),e.label=n,t.Pipeline.registeredFunctions[e.label]=e},t.Pipeline.warnIfFunctionNotRegistered=function(e){var n=e.label&&e.label in this.registeredFunctions;n||t.utils.warn(`Function is not registered with pipeline. This may cause problems when serialising the index. +`,e)},t.Pipeline.load=function(e){var n=new t.Pipeline;return e.forEach(function(r){var i=t.Pipeline.registeredFunctions[r];if(i)n.add(i);else throw new Error("Cannot load unregistered function: "+r)}),n},t.Pipeline.prototype.add=function(){var e=Array.prototype.slice.call(arguments);e.forEach(function(n){t.Pipeline.warnIfFunctionNotRegistered(n),this._stack.push(n)},this)},t.Pipeline.prototype.after=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");r=r+1,this._stack.splice(r,0,n)},t.Pipeline.prototype.before=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");this._stack.splice(r,0,n)},t.Pipeline.prototype.remove=function(e){var n=this._stack.indexOf(e);n!=-1&&this._stack.splice(n,1)},t.Pipeline.prototype.run=function(e){for(var n=this._stack.length,r=0;r1&&(oe&&(r=s),o!=e);)i=r-n,s=n+Math.floor(i/2),o=this.elements[s*2];if(o==e||o>e)return s*2;if(ol?d+=2:a==l&&(n+=r[u+1]*i[d+1],u+=2,d+=2);return n},t.Vector.prototype.similarity=function(e){return this.dot(e)/this.magnitude()||0},t.Vector.prototype.toArray=function(){for(var e=new Array(this.elements.length/2),n=1,r=0;n0){var o=s.str.charAt(0),a;o in s.node.edges?a=s.node.edges[o]:(a=new t.TokenSet,s.node.edges[o]=a),s.str.length==1&&(a.final=!0),i.push({node:a,editsRemaining:s.editsRemaining,str:s.str.slice(1)})}if(s.editsRemaining!=0){if("*"in s.node.edges)var l=s.node.edges["*"];else{var l=new t.TokenSet;s.node.edges["*"]=l}if(s.str.length==0&&(l.final=!0),i.push({node:l,editsRemaining:s.editsRemaining-1,str:s.str}),s.str.length>1&&i.push({node:s.node,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)}),s.str.length==1&&(s.node.final=!0),s.str.length>=1){if("*"in s.node.edges)var u=s.node.edges["*"];else{var u=new t.TokenSet;s.node.edges["*"]=u}s.str.length==1&&(u.final=!0),i.push({node:u,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)})}if(s.str.length>1){var d=s.str.charAt(0),v=s.str.charAt(1),f;v in s.node.edges?f=s.node.edges[v]:(f=new t.TokenSet,s.node.edges[v]=f),s.str.length==1&&(f.final=!0),i.push({node:f,editsRemaining:s.editsRemaining-1,str:d+s.str.slice(2)})}}}return r},t.TokenSet.fromString=function(e){for(var n=new t.TokenSet,r=n,i=0,s=e.length;i=e;n--){var r=this.uncheckedNodes[n],i=r.child.toString();i in this.minimizedNodes?r.parent.edges[r.char]=this.minimizedNodes[i]:(r.child._str=i,this.minimizedNodes[i]=r.child),this.uncheckedNodes.pop()}};t.Index=function(e){this.invertedIndex=e.invertedIndex,this.fieldVectors=e.fieldVectors,this.tokenSet=e.tokenSet,this.fields=e.fields,this.pipeline=e.pipeline},t.Index.prototype.search=function(e){return this.query(function(n){var r=new t.QueryParser(e,n);r.parse()})},t.Index.prototype.query=function(e){for(var n=new t.Query(this.fields),r=Object.create(null),i=Object.create(null),s=Object.create(null),o=Object.create(null),a=Object.create(null),l=0;l1?this._b=1:this._b=e},t.Builder.prototype.k1=function(e){this._k1=e},t.Builder.prototype.add=function(e,n){var r=e[this._ref],i=Object.keys(this._fields);this._documents[r]=n||{},this.documentCount+=1;for(var s=0;s=this.length)return t.QueryLexer.EOS;var e=this.str.charAt(this.pos);return this.pos+=1,e},t.QueryLexer.prototype.width=function(){return this.pos-this.start},t.QueryLexer.prototype.ignore=function(){this.start==this.pos&&(this.pos+=1),this.start=this.pos},t.QueryLexer.prototype.backup=function(){this.pos-=1},t.QueryLexer.prototype.acceptDigitRun=function(){var e,n;do e=this.next(),n=e.charCodeAt(0);while(n>47&&n<58);e!=t.QueryLexer.EOS&&this.backup()},t.QueryLexer.prototype.more=function(){return this.pos1&&(e.backup(),e.emit(t.QueryLexer.TERM)),e.ignore(),e.more())return t.QueryLexer.lexText},t.QueryLexer.lexEditDistance=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.EDIT_DISTANCE),t.QueryLexer.lexText},t.QueryLexer.lexBoost=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.BOOST),t.QueryLexer.lexText},t.QueryLexer.lexEOS=function(e){e.width()>0&&e.emit(t.QueryLexer.TERM)},t.QueryLexer.termSeparator=t.tokenizer.separator,t.QueryLexer.lexText=function(e){for(;;){var n=e.next();if(n==t.QueryLexer.EOS)return t.QueryLexer.lexEOS;if(n.charCodeAt(0)==92){e.escapeCharacter();continue}if(n==":")return t.QueryLexer.lexField;if(n=="~")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexEditDistance;if(n=="^")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexBoost;if(n=="+"&&e.width()===1||n=="-"&&e.width()===1)return e.emit(t.QueryLexer.PRESENCE),t.QueryLexer.lexText;if(n.match(t.QueryLexer.termSeparator))return t.QueryLexer.lexTerm}},t.QueryParser=function(e,n){this.lexer=new t.QueryLexer(e),this.query=n,this.currentClause={},this.lexemeIdx=0},t.QueryParser.prototype.parse=function(){this.lexer.run(),this.lexemes=this.lexer.lexemes;for(var e=t.QueryParser.parseClause;e;)e=e(this);return this.query},t.QueryParser.prototype.peekLexeme=function(){return this.lexemes[this.lexemeIdx]},t.QueryParser.prototype.consumeLexeme=function(){var e=this.peekLexeme();return this.lexemeIdx+=1,e},t.QueryParser.prototype.nextClause=function(){var e=this.currentClause;this.query.clause(e),this.currentClause={}},t.QueryParser.parseClause=function(e){var n=e.peekLexeme();if(n!=null)switch(n.type){case t.QueryLexer.PRESENCE:return t.QueryParser.parsePresence;case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expected either a field or a term, found "+n.type;throw n.str.length>=1&&(r+=" with value '"+n.str+"'"),new t.QueryParseError(r,n.start,n.end)}},t.QueryParser.parsePresence=function(e){var n=e.consumeLexeme();if(n!=null){switch(n.str){case"-":e.currentClause.presence=t.Query.presence.PROHIBITED;break;case"+":e.currentClause.presence=t.Query.presence.REQUIRED;break;default:var r="unrecognised presence operator'"+n.str+"'";throw new t.QueryParseError(r,n.start,n.end)}var i=e.peekLexeme();if(i==null){var r="expecting term or field, found nothing";throw new t.QueryParseError(r,n.start,n.end)}switch(i.type){case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expecting term or field, found '"+i.type+"'";throw new t.QueryParseError(r,i.start,i.end)}}},t.QueryParser.parseField=function(e){var n=e.consumeLexeme();if(n!=null){if(e.query.allFields.indexOf(n.str)==-1){var r=e.query.allFields.map(function(o){return"'"+o+"'"}).join(", "),i="unrecognised field '"+n.str+"', possible fields: "+r;throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.fields=[n.str];var s=e.peekLexeme();if(s==null){var i="expecting term, found nothing";throw new t.QueryParseError(i,n.start,n.end)}switch(s.type){case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var i="expecting term, found '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseTerm=function(e){var n=e.consumeLexeme();if(n!=null){e.currentClause.term=n.str.toLowerCase(),n.str.indexOf("*")!=-1&&(e.currentClause.usePipeline=!1);var r=e.peekLexeme();if(r==null){e.nextClause();return}switch(r.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+r.type+"'";throw new t.QueryParseError(i,r.start,r.end)}}},t.QueryParser.parseEditDistance=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="edit distance must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.editDistance=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseBoost=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="boost must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.boost=r;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},function(e,n){typeof define=="function"&&define.amd?define(n):typeof se=="object"?oe.exports=n():e.lunr=n()}(this,function(){return t})})()});var re=[];function G(t,e){re.push({selector:e,constructor:t})}var U=class{constructor(){this.alwaysVisibleMember=null;this.createComponents(document.body),this.ensureActivePageVisible(),this.ensureFocusedElementVisible(),this.listenForCodeCopies(),window.addEventListener("hashchange",()=>this.ensureFocusedElementVisible())}createComponents(e){re.forEach(n=>{e.querySelectorAll(n.selector).forEach(r=>{r.dataset.hasInstance||(new n.constructor({el:r,app:this}),r.dataset.hasInstance=String(!0))})})}filterChanged(){this.ensureFocusedElementVisible()}ensureActivePageVisible(){let e=document.querySelector(".tsd-navigation .current"),n=e?.parentElement;for(;n&&!n.classList.contains(".tsd-navigation");)n instanceof HTMLDetailsElement&&(n.open=!0),n=n.parentElement;if(e){let r=e.getBoundingClientRect().top-document.documentElement.clientHeight/4;document.querySelector(".site-menu").scrollTop=r}}ensureFocusedElementVisible(){if(this.alwaysVisibleMember&&(this.alwaysVisibleMember.classList.remove("always-visible"),this.alwaysVisibleMember.firstElementChild.remove(),this.alwaysVisibleMember=null),!location.hash)return;let e=document.getElementById(location.hash.substring(1));if(!e)return;let n=e.parentElement;for(;n&&n.tagName!=="SECTION";)n=n.parentElement;if(n&&n.offsetParent==null){this.alwaysVisibleMember=n,n.classList.add("always-visible");let r=document.createElement("p");r.classList.add("warning"),r.textContent="This member is normally hidden due to your filter settings.",n.prepend(r)}}listenForCodeCopies(){document.querySelectorAll("pre > button").forEach(e=>{let n;e.addEventListener("click",()=>{e.previousElementSibling instanceof HTMLElement&&navigator.clipboard.writeText(e.previousElementSibling.innerText.trim()),e.textContent="Copied!",e.classList.add("visible"),clearTimeout(n),n=setTimeout(()=>{e.classList.remove("visible"),n=setTimeout(()=>{e.textContent="Copy"},100)},1e3)})})}};var ie=(t,e=100)=>{let n;return()=>{clearTimeout(n),n=setTimeout(()=>t(),e)}};var de=De(ae());async function le(t,e){if(!window.searchData)return;let n=await fetch(window.searchData),r=new Blob([await n.arrayBuffer()]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();t.data=i,t.index=de.Index.load(i.index),e.classList.remove("loading"),e.classList.add("ready")}function he(){let t=document.getElementById("tsd-search");if(!t)return;let e={base:t.dataset.base+"/"},n=document.getElementById("tsd-search-script");t.classList.add("loading"),n&&(n.addEventListener("error",()=>{t.classList.remove("loading"),t.classList.add("failure")}),n.addEventListener("load",()=>{le(e,t)}),le(e,t));let r=document.querySelector("#tsd-search input"),i=document.querySelector("#tsd-search .results");if(!r||!i)throw new Error("The input field or the result list wrapper was not found");let s=!1;i.addEventListener("mousedown",()=>s=!0),i.addEventListener("mouseup",()=>{s=!1,t.classList.remove("has-focus")}),r.addEventListener("focus",()=>t.classList.add("has-focus")),r.addEventListener("blur",()=>{s||(s=!1,t.classList.remove("has-focus"))}),Ae(t,i,r,e)}function Ae(t,e,n,r){n.addEventListener("input",ie(()=>{Ne(t,e,n,r)},200));let i=!1;n.addEventListener("keydown",s=>{i=!0,s.key=="Enter"?Ve(e,n):s.key=="Escape"?n.blur():s.key=="ArrowUp"?ue(e,-1):s.key==="ArrowDown"?ue(e,1):i=!1}),n.addEventListener("keypress",s=>{i&&s.preventDefault()}),document.body.addEventListener("keydown",s=>{s.altKey||s.ctrlKey||s.metaKey||!n.matches(":focus")&&s.key==="/"&&(n.focus(),s.preventDefault())})}function Ne(t,e,n,r){if(!r.index||!r.data)return;e.textContent="";let i=n.value.trim(),s;if(i){let o=i.split(" ").map(a=>a.length?`*${a}*`:"").join(" ");s=r.index.search(o)}else s=[];for(let o=0;oa.score-o.score);for(let o=0,a=Math.min(10,s.length);o`,d=ce(l.name,i);globalThis.DEBUG_SEARCH_WEIGHTS&&(d+=` (score: ${s[o].score.toFixed(2)})`),l.parent&&(d=` + ${ce(l.parent,i)}.${d}`);let v=document.createElement("li");v.classList.value=l.classes??"";let f=document.createElement("a");f.href=r.base+l.url,f.innerHTML=u+d,v.append(f),e.appendChild(v)}}function ue(t,e){let n=t.querySelector(".current");if(!n)n=t.querySelector(e==1?"li:first-child":"li:last-child"),n&&n.classList.add("current");else{let r=n;if(e===1)do r=r.nextElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);else do r=r.previousElementSibling??void 0;while(r instanceof HTMLElement&&r.offsetParent==null);r&&(n.classList.remove("current"),r.classList.add("current"))}}function Ve(t,e){let n=t.querySelector(".current");if(n||(n=t.querySelector("li:first-child")),n){let r=n.querySelector("a");r&&(window.location.href=r.href),e.blur()}}function ce(t,e){if(e==="")return t;let n=t.toLocaleLowerCase(),r=e.toLocaleLowerCase(),i=[],s=0,o=n.indexOf(r);for(;o!=-1;)i.push(K(t.substring(s,o)),`${K(t.substring(o,o+r.length))}`),s=o+r.length,o=n.indexOf(r,s);return i.push(K(t.substring(s))),i.join("")}var He={"&":"&","<":"<",">":">","'":"'",'"':"""};function K(t){return t.replace(/[&<>"'"]/g,e=>He[e])}var C=class{constructor(e){this.el=e.el,this.app=e.app}};var F="mousedown",pe="mousemove",H="mouseup",J={x:0,y:0},fe=!1,ee=!1,Be=!1,D=!1,me=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);document.documentElement.classList.add(me?"is-mobile":"not-mobile");me&&"ontouchstart"in document.documentElement&&(Be=!0,F="touchstart",pe="touchmove",H="touchend");document.addEventListener(F,t=>{ee=!0,D=!1;let e=F=="touchstart"?t.targetTouches[0]:t;J.y=e.pageY||0,J.x=e.pageX||0});document.addEventListener(pe,t=>{if(ee&&!D){let e=F=="touchstart"?t.targetTouches[0]:t,n=J.x-(e.pageX||0),r=J.y-(e.pageY||0);D=Math.sqrt(n*n+r*r)>10}});document.addEventListener(H,()=>{ee=!1});document.addEventListener("click",t=>{fe&&(t.preventDefault(),t.stopImmediatePropagation(),fe=!1)});var X=class extends C{constructor(e){super(e),this.className=this.el.dataset.toggle||"",this.el.addEventListener(H,n=>this.onPointerUp(n)),this.el.addEventListener("click",n=>n.preventDefault()),document.addEventListener(F,n=>this.onDocumentPointerDown(n)),document.addEventListener(H,n=>this.onDocumentPointerUp(n))}setActive(e){if(this.active==e)return;this.active=e,document.documentElement.classList.toggle("has-"+this.className,e),this.el.classList.toggle("active",e);let n=(this.active?"to-has-":"from-has-")+this.className;document.documentElement.classList.add(n),setTimeout(()=>document.documentElement.classList.remove(n),500)}onPointerUp(e){D||(this.setActive(!0),e.preventDefault())}onDocumentPointerDown(e){if(this.active){if(e.target.closest(".col-sidebar, .tsd-filter-group"))return;this.setActive(!1)}}onDocumentPointerUp(e){if(!D&&this.active&&e.target.closest(".col-sidebar")){let n=e.target.closest("a");if(n){let r=window.location.href;r.indexOf("#")!=-1&&(r=r.substring(0,r.indexOf("#"))),n.href.substring(0,r.length)==r&&setTimeout(()=>this.setActive(!1),250)}}}};var te;try{te=localStorage}catch{te={getItem(){return null},setItem(){}}}var Q=te;var ve=document.head.appendChild(document.createElement("style"));ve.dataset.for="filters";var Y=class extends C{constructor(e){super(e),this.key=`filter-${this.el.name}`,this.value=this.el.checked,this.el.addEventListener("change",()=>{this.setLocalStorage(this.el.checked)}),this.setLocalStorage(this.fromLocalStorage()),ve.innerHTML+=`html:not(.${this.key}) .tsd-is-${this.el.name} { display: none; } +`,this.updateIndexHeadingVisibility()}fromLocalStorage(){let e=Q.getItem(this.key);return e?e==="true":this.el.checked}setLocalStorage(e){Q.setItem(this.key,e.toString()),this.value=e,this.handleValueChange()}handleValueChange(){this.el.checked=this.value,document.documentElement.classList.toggle(this.key,this.value),this.app.filterChanged(),this.updateIndexHeadingVisibility()}updateIndexHeadingVisibility(){let e=document.querySelector(".tsd-index-content"),n=e?.open;e&&(e.open=!0),document.querySelectorAll(".tsd-index-section").forEach(r=>{r.style.display="block";let i=Array.from(r.querySelectorAll(".tsd-index-link")).every(s=>s.offsetParent==null);r.style.display=i?"none":"block"}),e&&(e.open=n)}};var Z=class extends C{constructor(e){super(e),this.summary=this.el.querySelector(".tsd-accordion-summary"),this.icon=this.summary.querySelector("svg"),this.key=`tsd-accordion-${this.summary.dataset.key??this.summary.textContent.trim().replace(/\s+/g,"-").toLowerCase()}`;let n=Q.getItem(this.key);this.el.open=n?n==="true":this.el.open,this.el.addEventListener("toggle",()=>this.update());let r=this.summary.querySelector("a");r&&r.addEventListener("click",()=>{location.assign(r.href)}),this.update()}update(){this.icon.style.transform=`rotate(${this.el.open?0:-90}deg)`,Q.setItem(this.key,this.el.open.toString())}};function ge(t){let e=Q.getItem("tsd-theme")||"os";t.value=e,ye(e),t.addEventListener("change",()=>{Q.setItem("tsd-theme",t.value),ye(t.value)})}function ye(t){document.documentElement.dataset.theme=t}var Le;function be(){let t=document.getElementById("tsd-nav-script");t&&(t.addEventListener("load",xe),xe())}async function xe(){let t=document.getElementById("tsd-nav-container");if(!t||!window.navigationData)return;let n=await(await fetch(window.navigationData)).arrayBuffer(),r=new Blob([n]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();Le=t.dataset.base+"/",t.innerHTML="";for(let s of i)we(s,t,[]);window.app.createComponents(t),window.app.ensureActivePageVisible()}function we(t,e,n){let r=e.appendChild(document.createElement("li"));if(t.children){let i=[...n,t.text],s=r.appendChild(document.createElement("details"));s.className=t.class?`${t.class} tsd-index-accordion`:"tsd-index-accordion",s.dataset.key=i.join("$");let o=s.appendChild(document.createElement("summary"));o.className="tsd-accordion-summary",o.innerHTML='',Ee(t,o);let a=s.appendChild(document.createElement("div"));a.className="tsd-accordion-details";let l=a.appendChild(document.createElement("ul"));l.className="tsd-nested-navigation";for(let u of t.children)we(u,l,i)}else Ee(t,r,t.class)}function Ee(t,e,n){if(t.path){let r=e.appendChild(document.createElement("a"));r.href=Le+t.path,n&&(r.className=n),location.href===r.href&&r.classList.add("current"),t.kind&&(r.innerHTML=``),r.appendChild(document.createElement("span")).textContent=t.text}else e.appendChild(document.createElement("span")).textContent=t.text}G(X,"a[data-toggle]");G(Z,".tsd-index-accordion");G(Y,".tsd-filter-item input[type=checkbox]");var Se=document.getElementById("tsd-theme");Se&&ge(Se);var je=new U;Object.defineProperty(window,"app",{value:je});he();be();})(); +/*! Bundled license information: + +lunr/lunr.js: + (** + * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9 + * Copyright (C) 2020 Oliver Nightingale + * @license MIT + *) + (*! + * lunr.utils + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Set + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.tokenizer + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Pipeline + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Vector + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.stemmer + * Copyright (C) 2020 Oliver Nightingale + * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt + *) + (*! + * lunr.stopWordFilter + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.trimmer + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.TokenSet + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Index + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Builder + * Copyright (C) 2020 Oliver Nightingale + *) +*/ diff --git a/assets/navigation.js b/assets/navigation.js new file mode 100644 index 000000000..929b66936 --- /dev/null +++ b/assets/navigation.js @@ -0,0 +1 @@ +window.navigationData = "data:application/octet-stream;base64,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" \ No newline at end of file diff --git a/assets/search.js b/assets/search.js new file mode 100644 index 000000000..ea38127af --- /dev/null +++ b/assets/search.js @@ -0,0 +1 @@ +window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file diff --git a/assets/style.css b/assets/style.css new file mode 100644 index 000000000..98a437794 --- /dev/null +++ b/assets/style.css @@ -0,0 +1,1414 @@ +:root { + /* Light */ + --light-color-background: #f2f4f8; + --light-color-background-secondary: #eff0f1; + --light-color-warning-text: #222; + --light-color-background-warning: #e6e600; + --light-color-icon-background: var(--light-color-background); + --light-color-accent: #c5c7c9; + --light-color-active-menu-item: var(--light-color-accent); + --light-color-text: #222; + --light-color-text-aside: #6e6e6e; + --light-color-link: #1f70c2; + + --light-color-ts-keyword: #056bd6; + --light-color-ts-project: #b111c9; + --light-color-ts-module: var(--light-color-ts-project); + --light-color-ts-namespace: var(--light-color-ts-project); + --light-color-ts-enum: #7e6f15; + --light-color-ts-enum-member: var(--light-color-ts-enum); + --light-color-ts-variable: #4760ec; + --light-color-ts-function: #572be7; + --light-color-ts-class: #1f70c2; + --light-color-ts-interface: #108024; + --light-color-ts-constructor: var(--light-color-ts-class); + --light-color-ts-property: var(--light-color-ts-variable); + --light-color-ts-method: var(--light-color-ts-function); + --light-color-ts-call-signature: var(--light-color-ts-method); + --light-color-ts-index-signature: var(--light-color-ts-property); + --light-color-ts-constructor-signature: var(--light-color-ts-constructor); + --light-color-ts-parameter: var(--light-color-ts-variable); + /* type literal not included as links will never be generated to it */ + --light-color-ts-type-parameter: #a55c0e; + --light-color-ts-accessor: var(--light-color-ts-property); + --light-color-ts-get-signature: var(--light-color-ts-accessor); + --light-color-ts-set-signature: var(--light-color-ts-accessor); + --light-color-ts-type-alias: #d51270; + /* reference not included as links will be colored with the kind that it points to */ + + --light-external-icon: url("data:image/svg+xml;utf8,"); + --light-color-scheme: light; + + /* Dark */ + --dark-color-background: #2b2e33; + --dark-color-background-secondary: #1e2024; + --dark-color-background-warning: #bebe00; + --dark-color-warning-text: #222; + --dark-color-icon-background: var(--dark-color-background-secondary); + --dark-color-accent: #9096a2; + --dark-color-active-menu-item: #5d5d6a; + --dark-color-text: #f5f5f5; + --dark-color-text-aside: #dddddd; + --dark-color-link: #00aff4; + + --dark-color-ts-keyword: #3399ff; + --dark-color-ts-project: #e358ff; + --dark-color-ts-module: var(--dark-color-ts-project); + --dark-color-ts-namespace: var(--dark-color-ts-project); + --dark-color-ts-enum: #f4d93e; + --dark-color-ts-enum-member: var(--dark-color-ts-enum); + --dark-color-ts-variable: #798dff; + --dark-color-ts-function: #a280ff; + --dark-color-ts-class: #8ac4ff; + --dark-color-ts-interface: #6cff87; + --dark-color-ts-constructor: var(--dark-color-ts-class); + --dark-color-ts-property: var(--dark-color-ts-variable); + --dark-color-ts-method: var(--dark-color-ts-function); + --dark-color-ts-call-signature: var(--dark-color-ts-method); + --dark-color-ts-index-signature: var(--dark-color-ts-property); + --dark-color-ts-constructor-signature: var(--dark-color-ts-constructor); + --dark-color-ts-parameter: var(--dark-color-ts-variable); + /* type literal not included as links will never be generated to it */ + --dark-color-ts-type-parameter: #e07d13; + --dark-color-ts-accessor: var(--dark-color-ts-property); + --dark-color-ts-get-signature: var(--dark-color-ts-accessor); + --dark-color-ts-set-signature: var(--dark-color-ts-accessor); + --dark-color-ts-type-alias: #ff6492; + /* reference not included as links will be colored with the kind that it points to */ + + --dark-external-icon: url("data:image/svg+xml;utf8,"); + --dark-color-scheme: dark; +} + +@media (prefers-color-scheme: light) { + :root { + --color-background: var(--light-color-background); + --color-background-secondary: var(--light-color-background-secondary); + --color-background-warning: var(--light-color-background-warning); + --color-warning-text: var(--light-color-warning-text); + --color-icon-background: var(--light-color-icon-background); + --color-accent: var(--light-color-accent); + --color-active-menu-item: var(--light-color-active-menu-item); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + --color-link: var(--light-color-link); + + --color-ts-keyword: var(--light-color-ts-keyword); + --color-ts-module: var(--light-color-ts-module); + --color-ts-namespace: var(--light-color-ts-namespace); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-enum-member: var(--light-color-ts-enum-member); + --color-ts-variable: var(--light-color-ts-variable); + --color-ts-function: var(--light-color-ts-function); + --color-ts-class: var(--light-color-ts-class); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-constructor: var(--light-color-ts-constructor); + --color-ts-property: var(--light-color-ts-property); + --color-ts-method: var(--light-color-ts-method); + --color-ts-call-signature: var(--light-color-ts-call-signature); + --color-ts-index-signature: var(--light-color-ts-index-signature); + --color-ts-constructor-signature: var( + --light-color-ts-constructor-signature + ); + --color-ts-parameter: var(--light-color-ts-parameter); + --color-ts-type-parameter: var(--light-color-ts-type-parameter); + --color-ts-accessor: var(--light-color-ts-accessor); + --color-ts-get-signature: var(--light-color-ts-get-signature); + --color-ts-set-signature: var(--light-color-ts-set-signature); + --color-ts-type-alias: var(--light-color-ts-type-alias); + + --external-icon: var(--light-external-icon); + --color-scheme: var(--light-color-scheme); + } +} + +@media (prefers-color-scheme: dark) { + :root { + --color-background: var(--dark-color-background); + --color-background-secondary: var(--dark-color-background-secondary); + --color-background-warning: var(--dark-color-background-warning); + --color-warning-text: var(--dark-color-warning-text); + --color-icon-background: var(--dark-color-icon-background); + --color-accent: var(--dark-color-accent); + --color-active-menu-item: var(--dark-color-active-menu-item); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + --color-link: var(--dark-color-link); + + --color-ts-keyword: var(--dark-color-ts-keyword); + --color-ts-module: var(--dark-color-ts-module); + --color-ts-namespace: var(--dark-color-ts-namespace); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-enum-member: var(--dark-color-ts-enum-member); + --color-ts-variable: var(--dark-color-ts-variable); + --color-ts-function: var(--dark-color-ts-function); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-constructor: var(--dark-color-ts-constructor); + --color-ts-property: var(--dark-color-ts-property); + --color-ts-method: var(--dark-color-ts-method); + --color-ts-call-signature: var(--dark-color-ts-call-signature); + --color-ts-index-signature: var(--dark-color-ts-index-signature); + --color-ts-constructor-signature: var( + --dark-color-ts-constructor-signature + ); + --color-ts-parameter: var(--dark-color-ts-parameter); + --color-ts-type-parameter: var(--dark-color-ts-type-parameter); + --color-ts-accessor: var(--dark-color-ts-accessor); + --color-ts-get-signature: var(--dark-color-ts-get-signature); + --color-ts-set-signature: var(--dark-color-ts-set-signature); + --color-ts-type-alias: var(--dark-color-ts-type-alias); + + --external-icon: var(--dark-external-icon); + --color-scheme: var(--dark-color-scheme); + } +} + +html { + color-scheme: var(--color-scheme); +} + +body { + margin: 0; +} + +:root[data-theme="light"] { + --color-background: var(--light-color-background); + --color-background-secondary: var(--light-color-background-secondary); + --color-background-warning: var(--light-color-background-warning); + --color-warning-text: var(--light-color-warning-text); + --color-icon-background: var(--light-color-icon-background); + --color-accent: var(--light-color-accent); + --color-active-menu-item: var(--light-color-active-menu-item); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + --color-link: var(--light-color-link); + + --color-ts-keyword: var(--light-color-ts-keyword); + --color-ts-module: var(--light-color-ts-module); + --color-ts-namespace: var(--light-color-ts-namespace); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-enum-member: var(--light-color-ts-enum-member); + --color-ts-variable: var(--light-color-ts-variable); + --color-ts-function: var(--light-color-ts-function); + --color-ts-class: var(--light-color-ts-class); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-constructor: var(--light-color-ts-constructor); + --color-ts-property: var(--light-color-ts-property); + --color-ts-method: var(--light-color-ts-method); + --color-ts-call-signature: var(--light-color-ts-call-signature); + --color-ts-index-signature: var(--light-color-ts-index-signature); + --color-ts-constructor-signature: var( + --light-color-ts-constructor-signature + ); + --color-ts-parameter: var(--light-color-ts-parameter); + --color-ts-type-parameter: var(--light-color-ts-type-parameter); + --color-ts-accessor: var(--light-color-ts-accessor); + --color-ts-get-signature: var(--light-color-ts-get-signature); + --color-ts-set-signature: var(--light-color-ts-set-signature); + --color-ts-type-alias: var(--light-color-ts-type-alias); + + --external-icon: var(--light-external-icon); + --color-scheme: var(--light-color-scheme); +} + +:root[data-theme="dark"] { + --color-background: var(--dark-color-background); + --color-background-secondary: var(--dark-color-background-secondary); + --color-background-warning: var(--dark-color-background-warning); + --color-warning-text: var(--dark-color-warning-text); + --color-icon-background: var(--dark-color-icon-background); + --color-accent: var(--dark-color-accent); + --color-active-menu-item: var(--dark-color-active-menu-item); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + --color-link: var(--dark-color-link); + + --color-ts-keyword: var(--dark-color-ts-keyword); + --color-ts-module: var(--dark-color-ts-module); + --color-ts-namespace: var(--dark-color-ts-namespace); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-enum-member: var(--dark-color-ts-enum-member); + --color-ts-variable: var(--dark-color-ts-variable); + --color-ts-function: var(--dark-color-ts-function); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-constructor: var(--dark-color-ts-constructor); + --color-ts-property: var(--dark-color-ts-property); + --color-ts-method: var(--dark-color-ts-method); + --color-ts-call-signature: var(--dark-color-ts-call-signature); + --color-ts-index-signature: var(--dark-color-ts-index-signature); + --color-ts-constructor-signature: var( + --dark-color-ts-constructor-signature + ); + --color-ts-parameter: var(--dark-color-ts-parameter); + --color-ts-type-parameter: var(--dark-color-ts-type-parameter); + --color-ts-accessor: var(--dark-color-ts-accessor); + --color-ts-get-signature: var(--dark-color-ts-get-signature); + --color-ts-set-signature: var(--dark-color-ts-set-signature); + --color-ts-type-alias: var(--dark-color-ts-type-alias); + + --external-icon: var(--dark-external-icon); + --color-scheme: var(--dark-color-scheme); +} + +.always-visible, +.always-visible .tsd-signatures { + display: inherit !important; +} + +h1, +h2, +h3, +h4, +h5, +h6 { + line-height: 1.2; +} + +h1 > a:not(.link), +h2 > a:not(.link), +h3 > a:not(.link), +h4 > a:not(.link), +h5 > a:not(.link), +h6 > a:not(.link) { + text-decoration: none; + color: var(--color-text); +} + +h1 { + font-size: 1.875rem; + margin: 0.67rem 0; +} + +h2 { + font-size: 1.5rem; + margin: 0.83rem 0; +} + +h3 { + font-size: 1.25rem; + margin: 1rem 0; +} + +h4 { + font-size: 1.05rem; + margin: 1.33rem 0; +} + +h5 { + font-size: 1rem; + margin: 1.5rem 0; +} + +h6 { + font-size: 0.875rem; + margin: 2.33rem 0; +} + +.uppercase { + text-transform: uppercase; +} + +dl, +menu, +ol, +ul { + margin: 1em 0; +} + +dd { + margin: 0 0 0 40px; +} + +.container { + max-width: 1700px; + padding: 0 2rem; +} + +/* Footer */ +.tsd-generator { + border-top: 1px solid var(--color-accent); + padding-top: 1rem; + padding-bottom: 1rem; + max-height: 3.5rem; +} + +.tsd-generator > p { + margin-top: 0; + margin-bottom: 0; + padding: 0 1rem; +} + +.container-main { + margin: 0 auto; + /* toolbar, footer, margin */ + min-height: calc(100vh - 41px - 56px - 4rem); +} + +@keyframes fade-in { + from { + opacity: 0; + } + to { + opacity: 1; + } +} +@keyframes fade-out { + from { + opacity: 1; + visibility: visible; + } + to { + opacity: 0; + } +} +@keyframes fade-in-delayed { + 0% { + opacity: 0; + } + 33% { + opacity: 0; + } + 100% { + opacity: 1; + } +} +@keyframes fade-out-delayed { + 0% { + opacity: 1; + visibility: visible; + } + 66% { + opacity: 0; + } + 100% { + opacity: 0; + } +} +@keyframes pop-in-from-right { + from { + transform: translate(100%, 0); + } + to { + transform: translate(0, 0); + } +} +@keyframes pop-out-to-right { + from { + transform: translate(0, 0); + visibility: visible; + } + to { + transform: translate(100%, 0); + } +} +body { + background: var(--color-background); + font-family: "Segoe UI", sans-serif; + font-size: 16px; + color: var(--color-text); +} + +a { + color: var(--color-link); + text-decoration: none; +} +a:hover { + text-decoration: underline; +} +a.external[target="_blank"] { + background-image: var(--external-icon); + background-position: top 3px right; + background-repeat: no-repeat; + padding-right: 13px; +} + +code, +pre { + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + padding: 0.2em; + margin: 0; + font-size: 0.875rem; + border-radius: 0.8em; +} + +pre { + position: relative; + white-space: pre; + white-space: pre-wrap; + word-wrap: break-word; + padding: 10px; + border: 1px solid var(--color-accent); +} +pre code { + padding: 0; + font-size: 100%; +} +pre > button { + position: absolute; + top: 10px; + right: 10px; + opacity: 0; + transition: opacity 0.1s; + box-sizing: border-box; +} +pre:hover > button, +pre > button.visible { + opacity: 1; +} + +blockquote { + margin: 1em 0; + padding-left: 1em; + border-left: 4px solid gray; +} + +.tsd-typography { + line-height: 1.333em; +} +.tsd-typography ul { + list-style: square; + padding: 0 0 0 20px; + margin: 0; +} +.tsd-typography .tsd-index-panel h3, +.tsd-index-panel .tsd-typography h3, +.tsd-typography h4, +.tsd-typography h5, +.tsd-typography h6 { + font-size: 1em; +} +.tsd-typography h5, +.tsd-typography h6 { + font-weight: normal; +} +.tsd-typography p, +.tsd-typography ul, +.tsd-typography ol { + margin: 1em 0; +} +.tsd-typography table { + border-collapse: collapse; + border: none; +} +.tsd-typography td, +.tsd-typography th { + padding: 6px 13px; + border: 1px solid var(--color-accent); +} +.tsd-typography thead, +.tsd-typography tr:nth-child(even) { + background-color: var(--color-background-secondary); +} + +.tsd-breadcrumb { + margin: 0; + padding: 0; + color: var(--color-text-aside); +} +.tsd-breadcrumb a { + color: var(--color-text-aside); + text-decoration: none; +} +.tsd-breadcrumb a:hover { + text-decoration: underline; +} +.tsd-breadcrumb li { + display: inline; +} +.tsd-breadcrumb li:after { + content: " / "; +} + +.tsd-comment-tags { + display: flex; + flex-direction: column; +} +dl.tsd-comment-tag-group { + display: flex; + align-items: center; + overflow: hidden; + margin: 0.5em 0; +} +dl.tsd-comment-tag-group dt { + display: flex; + margin-right: 0.5em; + font-size: 0.875em; + font-weight: normal; +} +dl.tsd-comment-tag-group dd { + margin: 0; +} +code.tsd-tag { + padding: 0.25em 0.4em; + border: 0.1em solid var(--color-accent); + margin-right: 0.25em; + font-size: 70%; +} +h1 code.tsd-tag:first-of-type { + margin-left: 0.25em; +} + +dl.tsd-comment-tag-group dd:before, +dl.tsd-comment-tag-group dd:after { + content: " "; +} +dl.tsd-comment-tag-group dd pre, +dl.tsd-comment-tag-group dd:after { + clear: both; +} +dl.tsd-comment-tag-group p { + margin: 0; +} + +.tsd-panel.tsd-comment .lead { + font-size: 1.1em; + line-height: 1.333em; + margin-bottom: 2em; +} +.tsd-panel.tsd-comment .lead:last-child { + margin-bottom: 0; +} + +.tsd-filter-visibility h4 { + font-size: 1rem; + padding-top: 0.75rem; + padding-bottom: 0.5rem; + margin: 0; +} +.tsd-filter-item:not(:last-child) { + margin-bottom: 0.5rem; +} +.tsd-filter-input { + display: flex; + width: fit-content; + width: -moz-fit-content; + align-items: center; + user-select: none; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + cursor: pointer; +} +.tsd-filter-input input[type="checkbox"] { + cursor: pointer; + position: absolute; + width: 1.5em; + height: 1.5em; + opacity: 0; +} +.tsd-filter-input input[type="checkbox"]:disabled { + pointer-events: none; +} +.tsd-filter-input svg { + cursor: pointer; + width: 1.5em; + height: 1.5em; + margin-right: 0.5em; + border-radius: 0.33em; + /* Leaving this at full opacity breaks event listeners on Firefox. + Don't remove unless you know what you're doing. */ + opacity: 0.99; +} +.tsd-filter-input input[type="checkbox"]:focus + svg { + transform: scale(0.95); +} +.tsd-filter-input input[type="checkbox"]:focus:not(:focus-visible) + svg { + transform: scale(1); +} +.tsd-checkbox-background { + fill: var(--color-accent); +} +input[type="checkbox"]:checked ~ svg .tsd-checkbox-checkmark { + stroke: var(--color-text); +} +.tsd-filter-input input:disabled ~ svg > .tsd-checkbox-background { + fill: var(--color-background); + stroke: var(--color-accent); + stroke-width: 0.25rem; +} +.tsd-filter-input input:disabled ~ svg > .tsd-checkbox-checkmark { + stroke: var(--color-accent); +} + +.tsd-theme-toggle { + padding-top: 0.75rem; +} +.tsd-theme-toggle > h4 { + display: inline; + vertical-align: middle; + margin-right: 0.75rem; +} + +.tsd-hierarchy { + list-style: square; + margin: 0; +} +.tsd-hierarchy .target { + font-weight: bold; +} + +.tsd-full-hierarchy:not(:last-child) { + margin-bottom: 1em; + padding-bottom: 1em; + border-bottom: 1px solid var(--color-accent); +} +.tsd-full-hierarchy, +.tsd-full-hierarchy ul { + list-style: none; + margin: 0; + padding: 0; +} +.tsd-full-hierarchy ul { + padding-left: 1.5rem; +} +.tsd-full-hierarchy a { + padding: 0.25rem 0 !important; + font-size: 1rem; + display: inline-flex; + align-items: center; + color: var(--color-text); +} + +.tsd-panel-group.tsd-index-group { + margin-bottom: 0; +} +.tsd-index-panel .tsd-index-list { + list-style: none; + line-height: 1.333em; + margin: 0; + padding: 0.25rem 0 0 0; + overflow: hidden; + display: grid; + grid-template-columns: repeat(3, 1fr); + column-gap: 1rem; + grid-template-rows: auto; +} +@media (max-width: 1024px) { + .tsd-index-panel .tsd-index-list { + grid-template-columns: repeat(2, 1fr); + } +} +@media (max-width: 768px) { + .tsd-index-panel .tsd-index-list { + grid-template-columns: repeat(1, 1fr); + } +} +.tsd-index-panel .tsd-index-list li { + -webkit-page-break-inside: avoid; + -moz-page-break-inside: avoid; + -ms-page-break-inside: avoid; + -o-page-break-inside: avoid; + page-break-inside: avoid; +} + +.tsd-flag { + display: inline-block; + padding: 0.25em 0.4em; + border-radius: 4px; + color: var(--color-comment-tag-text); + background-color: var(--color-comment-tag); + text-indent: 0; + font-size: 75%; + line-height: 1; + font-weight: normal; +} + +.tsd-anchor { + position: relative; + top: -100px; +} + +.tsd-member { + position: relative; +} +.tsd-member .tsd-anchor + h3 { + display: flex; + align-items: center; + margin-top: 0; + margin-bottom: 0; + border-bottom: none; +} + +.tsd-navigation.settings { + margin: 1rem 0; +} +.tsd-navigation > a, +.tsd-navigation .tsd-accordion-summary { + width: calc(100% - 0.25rem); + display: flex; + align-items: center; +} +.tsd-navigation a, +.tsd-navigation summary > span, +.tsd-page-navigation a { + display: flex; + width: calc(100% - 0.25rem); + align-items: center; + padding: 0.25rem; + color: var(--color-text); + text-decoration: none; + box-sizing: border-box; +} +.tsd-navigation a.current, +.tsd-page-navigation a.current { + background: var(--color-active-menu-item); +} +.tsd-navigation a:hover, +.tsd-page-navigation a:hover { + text-decoration: underline; +} +.tsd-navigation ul, +.tsd-page-navigation ul { + margin-top: 0; + margin-bottom: 0; + padding: 0; + list-style: none; +} +.tsd-navigation li, +.tsd-page-navigation li { + padding: 0; + max-width: 100%; +} +.tsd-nested-navigation { + margin-left: 3rem; +} +.tsd-nested-navigation > li > details { + margin-left: -1.5rem; +} +.tsd-small-nested-navigation { + margin-left: 1.5rem; +} +.tsd-small-nested-navigation > li > details { + margin-left: -1.5rem; +} + +.tsd-page-navigation ul { + padding-left: 1.75rem; +} + +#tsd-sidebar-links a { + margin-top: 0; + margin-bottom: 0.5rem; + line-height: 1.25rem; +} +#tsd-sidebar-links a:last-of-type { + margin-bottom: 0; +} + +a.tsd-index-link { + padding: 0.25rem 0 !important; + font-size: 1rem; + line-height: 1.25rem; + display: inline-flex; + align-items: center; + color: var(--color-text); +} +.tsd-accordion-summary { + list-style-type: none; /* hide marker on non-safari */ + outline: none; /* broken on safari, so just hide it */ +} +.tsd-accordion-summary::-webkit-details-marker { + display: none; /* hide marker on safari */ +} +.tsd-accordion-summary, +.tsd-accordion-summary a { + user-select: none; + -moz-user-select: none; + -webkit-user-select: none; + -ms-user-select: none; + + cursor: pointer; +} +.tsd-accordion-summary a { + width: calc(100% - 1.5rem); +} +.tsd-accordion-summary > * { + margin-top: 0; + margin-bottom: 0; + padding-top: 0; + padding-bottom: 0; +} +.tsd-index-accordion .tsd-accordion-summary > svg { + margin-left: 0.25rem; +} +.tsd-index-content > :not(:first-child) { + margin-top: 0.75rem; +} +.tsd-index-heading { + margin-top: 1.5rem; + margin-bottom: 0.75rem; +} + +.tsd-kind-icon { + margin-right: 0.5rem; + width: 1.25rem; + height: 1.25rem; + min-width: 1.25rem; + min-height: 1.25rem; +} +.tsd-kind-icon path { + transform-origin: center; + transform: scale(1.1); +} +.tsd-signature > .tsd-kind-icon { + margin-right: 0.8rem; +} + +.tsd-panel { + margin-bottom: 2.5rem; +} +.tsd-panel.tsd-member { + margin-bottom: 4rem; +} +.tsd-panel:empty { + display: none; +} +.tsd-panel > h1, +.tsd-panel > h2, +.tsd-panel > h3 { + margin: 1.5rem -1.5rem 0.75rem -1.5rem; + padding: 0 1.5rem 0.75rem 1.5rem; +} +.tsd-panel > h1.tsd-before-signature, +.tsd-panel > h2.tsd-before-signature, +.tsd-panel > h3.tsd-before-signature { + margin-bottom: 0; + border-bottom: none; +} + +.tsd-panel-group { + margin: 4rem 0; +} +.tsd-panel-group.tsd-index-group { + margin: 2rem 0; +} +.tsd-panel-group.tsd-index-group details { + margin: 2rem 0; +} + +#tsd-search { + transition: background-color 0.2s; +} +#tsd-search .title { + position: relative; + z-index: 2; +} +#tsd-search .field { + position: absolute; + left: 0; + top: 0; + right: 2.5rem; + height: 100%; +} +#tsd-search .field input { + box-sizing: border-box; + position: relative; + top: -50px; + z-index: 1; + width: 100%; + padding: 0 10px; + opacity: 0; + outline: 0; + border: 0; + background: transparent; + color: var(--color-text); +} +#tsd-search .field label { + position: absolute; + overflow: hidden; + right: -40px; +} +#tsd-search .field input, +#tsd-search .title, +#tsd-toolbar-links a { + transition: opacity 0.2s; +} +#tsd-search .results { + position: absolute; + visibility: hidden; + top: 40px; + width: 100%; + margin: 0; + padding: 0; + list-style: none; + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); +} +#tsd-search .results li { + background-color: var(--color-background); + line-height: initial; + padding: 4px; +} +#tsd-search .results li:nth-child(even) { + background-color: var(--color-background-secondary); +} +#tsd-search .results li.state { + display: none; +} +#tsd-search .results li.current:not(.no-results), +#tsd-search .results li:hover:not(.no-results) { + background-color: var(--color-accent); +} +#tsd-search .results a { + display: flex; + align-items: center; + padding: 0.25rem; + box-sizing: border-box; +} +#tsd-search .results a:before { + top: 10px; +} +#tsd-search .results span.parent { + color: var(--color-text-aside); + font-weight: normal; +} +#tsd-search.has-focus { + background-color: var(--color-accent); +} +#tsd-search.has-focus .field input { + top: 0; + opacity: 1; +} +#tsd-search.has-focus .title, +#tsd-search.has-focus #tsd-toolbar-links a { + z-index: 0; + opacity: 0; +} +#tsd-search.has-focus .results { + visibility: visible; +} +#tsd-search.loading .results li.state.loading { + display: block; +} +#tsd-search.failure .results li.state.failure { + display: block; +} + +#tsd-toolbar-links { + position: absolute; + top: 0; + right: 2rem; + height: 100%; + display: flex; + align-items: center; + justify-content: flex-end; +} +#tsd-toolbar-links a { + margin-left: 1.5rem; +} +#tsd-toolbar-links a:hover { + text-decoration: underline; +} + +.tsd-signature { + margin: 0 0 1rem 0; + padding: 1rem 0.5rem; + border: 1px solid var(--color-accent); + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + font-size: 14px; + overflow-x: auto; +} + +.tsd-signature-keyword { + color: var(--color-ts-keyword); + font-weight: normal; +} + +.tsd-signature-symbol { + color: var(--color-text-aside); + font-weight: normal; +} + +.tsd-signature-type { + font-style: italic; + font-weight: normal; +} + +.tsd-signatures { + padding: 0; + margin: 0 0 1em 0; + list-style-type: none; +} +.tsd-signatures .tsd-signature { + margin: 0; + border-color: var(--color-accent); + border-width: 1px 0; + transition: background-color 0.1s; +} +.tsd-description .tsd-signatures .tsd-signature { + border-width: 1px; +} + +ul.tsd-parameter-list, +ul.tsd-type-parameter-list { + list-style: square; + margin: 0; + padding-left: 20px; +} +ul.tsd-parameter-list > li.tsd-parameter-signature, +ul.tsd-type-parameter-list > li.tsd-parameter-signature { + list-style: none; + margin-left: -20px; +} +ul.tsd-parameter-list h5, +ul.tsd-type-parameter-list h5 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} +.tsd-sources { + margin-top: 1rem; + font-size: 0.875em; +} +.tsd-sources a { + color: var(--color-text-aside); + text-decoration: underline; +} +.tsd-sources ul { + list-style: none; + padding: 0; +} + +.tsd-page-toolbar { + position: sticky; + z-index: 1; + top: 0; + left: 0; + width: 100%; + color: var(--color-text); + background: var(--color-background-secondary); + border-bottom: 1px var(--color-accent) solid; + transition: transform 0.3s ease-in-out; +} +.tsd-page-toolbar a { + color: var(--color-text); + text-decoration: none; +} +.tsd-page-toolbar a.title { + font-weight: bold; +} +.tsd-page-toolbar a.title:hover { + text-decoration: underline; +} +.tsd-page-toolbar .tsd-toolbar-contents { + display: flex; + justify-content: space-between; + height: 2.5rem; + margin: 0 auto; +} +.tsd-page-toolbar .table-cell { + position: relative; + white-space: nowrap; + line-height: 40px; +} +.tsd-page-toolbar .table-cell:first-child { + width: 100%; +} +.tsd-page-toolbar .tsd-toolbar-icon { + box-sizing: border-box; + line-height: 0; + padding: 12px 0; +} + +.tsd-widget { + display: inline-block; + overflow: hidden; + opacity: 0.8; + height: 40px; + transition: + opacity 0.1s, + background-color 0.2s; + vertical-align: bottom; + cursor: pointer; +} +.tsd-widget:hover { + opacity: 0.9; +} +.tsd-widget.active { + opacity: 1; + background-color: var(--color-accent); +} +.tsd-widget.no-caption { + width: 40px; +} +.tsd-widget.no-caption:before { + margin: 0; +} + +.tsd-widget.options, +.tsd-widget.menu { + display: none; +} +input[type="checkbox"] + .tsd-widget:before { + background-position: -120px 0; +} +input[type="checkbox"]:checked + .tsd-widget:before { + background-position: -160px 0; +} + +img { + max-width: 100%; +} + +.tsd-anchor-icon { + display: inline-flex; + align-items: center; + margin-left: 0.5rem; + vertical-align: middle; + color: var(--color-text); +} + +.tsd-anchor-icon svg { + width: 1em; + height: 1em; + visibility: hidden; +} + +.tsd-anchor-link:hover > .tsd-anchor-icon svg { + visibility: visible; +} + +.deprecated { + text-decoration: line-through !important; +} + +.warning { + padding: 1rem; + color: var(--color-warning-text); + background: var(--color-background-warning); +} + +.tsd-kind-project { + color: var(--color-ts-project); +} +.tsd-kind-module { + color: var(--color-ts-module); +} +.tsd-kind-namespace { + color: var(--color-ts-namespace); +} +.tsd-kind-enum { + color: var(--color-ts-enum); +} +.tsd-kind-enum-member { + color: var(--color-ts-enum-member); +} +.tsd-kind-variable { + color: var(--color-ts-variable); +} +.tsd-kind-function { + color: var(--color-ts-function); +} +.tsd-kind-class { + color: var(--color-ts-class); +} +.tsd-kind-interface { + color: var(--color-ts-interface); +} +.tsd-kind-constructor { + color: var(--color-ts-constructor); +} +.tsd-kind-property { + color: var(--color-ts-property); +} +.tsd-kind-method { + color: var(--color-ts-method); +} +.tsd-kind-call-signature { + color: var(--color-ts-call-signature); +} +.tsd-kind-index-signature { + color: var(--color-ts-index-signature); +} +.tsd-kind-constructor-signature { + color: var(--color-ts-constructor-signature); +} +.tsd-kind-parameter { + color: var(--color-ts-parameter); +} +.tsd-kind-type-literal { + color: var(--color-ts-type-literal); +} +.tsd-kind-type-parameter { + color: var(--color-ts-type-parameter); +} +.tsd-kind-accessor { + color: var(--color-ts-accessor); +} +.tsd-kind-get-signature { + color: var(--color-ts-get-signature); +} +.tsd-kind-set-signature { + color: var(--color-ts-set-signature); +} +.tsd-kind-type-alias { + color: var(--color-ts-type-alias); +} + +/* if we have a kind icon, don't color the text by kind */ +.tsd-kind-icon ~ span { + color: var(--color-text); +} + +* { + scrollbar-width: thin; + scrollbar-color: var(--color-accent) var(--color-icon-background); +} + +*::-webkit-scrollbar { + width: 0.75rem; +} + +*::-webkit-scrollbar-track { + background: var(--color-icon-background); +} + +*::-webkit-scrollbar-thumb { + background-color: var(--color-accent); + border-radius: 999rem; + border: 0.25rem solid var(--color-icon-background); +} + +/* mobile */ +@media (max-width: 769px) { + .tsd-widget.options, + .tsd-widget.menu { + display: inline-block; + } + + .container-main { + display: flex; + } + html .col-content { + float: none; + max-width: 100%; + width: 100%; + } + html .col-sidebar { + position: fixed !important; + overflow-y: auto; + -webkit-overflow-scrolling: touch; + z-index: 1024; + top: 0 !important; + bottom: 0 !important; + left: auto !important; + right: 0 !important; + padding: 1.5rem 1.5rem 0 0; + width: 75vw; + visibility: hidden; + background-color: var(--color-background); + transform: translate(100%, 0); + } + html .col-sidebar > *:last-child { + padding-bottom: 20px; + } + html .overlay { + content: ""; + display: block; + position: fixed; + z-index: 1023; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: rgba(0, 0, 0, 0.75); + visibility: hidden; + } + + .to-has-menu .overlay { + animation: fade-in 0.4s; + } + + .to-has-menu .col-sidebar { + animation: pop-in-from-right 0.4s; + } + + .from-has-menu .overlay { + animation: fade-out 0.4s; + } + + .from-has-menu .col-sidebar { + animation: pop-out-to-right 0.4s; + } + + .has-menu body { + overflow: hidden; + } + .has-menu .overlay { + visibility: visible; + } + .has-menu .col-sidebar { + visibility: visible; + transform: translate(0, 0); + display: flex; + flex-direction: column; + gap: 1.5rem; + max-height: 100vh; + padding: 1rem 2rem; + } + .has-menu .tsd-navigation { + max-height: 100%; + } +} + +/* one sidebar */ +@media (min-width: 770px) { + .container-main { + display: grid; + grid-template-columns: minmax(0, 1fr) minmax(0, 2fr); + grid-template-areas: "sidebar content"; + margin: 2rem auto; + } + + .col-sidebar { + grid-area: sidebar; + } + .col-content { + grid-area: content; + padding: 0 1rem; + } +} +@media (min-width: 770px) and (max-width: 1399px) { + .col-sidebar { + max-height: calc(100vh - 2rem - 42px); + overflow: auto; + position: sticky; + top: 42px; + padding-top: 1rem; + } + .site-menu { + margin-top: 1rem; + } +} + +/* two sidebars */ +@media (min-width: 1200px) { + .container-main { + grid-template-columns: minmax(0, 1fr) minmax(0, 2.5fr) minmax(0, 20rem); + grid-template-areas: "sidebar content toc"; + } + + .col-sidebar { + display: contents; + } + + .page-menu { + grid-area: toc; + padding-left: 1rem; + } + .site-menu { + grid-area: sidebar; + } + + .site-menu { + margin-top: 1rem 0; + } + + .page-menu, + .site-menu { + max-height: calc(100vh - 2rem - 42px); + overflow: auto; + position: sticky; + top: 42px; + } +} diff --git a/classes/_zk_kit_eddsa_poseidon.EdDSAPoseidon.html b/classes/_zk_kit_eddsa_poseidon.EdDSAPoseidon.html new file mode 100644 index 000000000..6292659e6 --- /dev/null +++ b/classes/_zk_kit_eddsa_poseidon.EdDSAPoseidon.html @@ -0,0 +1,20 @@ +EdDSAPoseidon | ZK-kit

Represents a cryptographic entity capable of signing messages and verifying signatures +using the EdDSA scheme with Poseidon hash and the Baby Jubjub elliptic curve.

+

Constructors

  • Initializes a new instance, deriving necessary cryptographic parameters from the provided private key. +If the private key is not passed as a parameter, a random 32-byte key is generated.

    +

    Parameters

    • privateKey: BigNumberish = ...

      The private key used for signing and public key derivation.

      +

    Returns EdDSAPoseidon

Properties

packedPublicKey: string
privateKey: BigNumberish
publicKey: Point
secretScalar: string

Methods

  • Signs a given message using the private key and returns the signature.

    +

    Parameters

    Returns Signature<string>

    The signature of the message.

    +
  • Verifies a signature against a message and the public key stored in this instance.

    +

    Parameters

    • message: BigNumberish

      The message whose signature is to be verified.

      +
    • signature: Signature

      The signature to be verified.

      +

    Returns boolean

    True if the signature is valid for the message and public key, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/classes/_zk_kit_imt.IMT.html b/classes/_zk_kit_imt.IMT.html new file mode 100644 index 000000000..c946f5614 --- /dev/null +++ b/classes/_zk_kit_imt.IMT.html @@ -0,0 +1,87 @@ +IMT | ZK-kit

An IMT (aka Incremental Merkle Tree) is a type of data structure used in cryptography and +computer science for efficiently verifying the integrity of a large set of data, +especially in situations where new data is added over time. It is based on the concept +of a Merkle tree, and its key feature is its ability to efficiently update the tree +when new data is added or existing data is modified. +In this implementation, the tree is constructed using a fixed IMT#depth +value, and a list of IMT#zeroes (one for each level) is used to compute the +hash of a node when not all of its children are defined. The number of children for each +node can also be specified with the IMT#arity parameter.

+

Constructors

  • It initializes the tree with an hash function, the depth, the zero value to use for zeroes +and the arity (i.e. the number of children for each node). It also takes an optional parameter +to initialize the tree with a list of leaves.

    +

    Parameters

    • hash: IMTHashFunction

      The hash function used to create nodes.

      +
    • depth: number

      The tree depth.

      +
    • zeroValue: any

      The zero value used to create zeroes.

      +
    • arity: number = 2

      The number of children for each node.

      +
    • leaves: any[] = []

      The list of initial leaves.

      +

    Returns IMT

Properties

_arity: number

The number of children per node.

+
_depth: number

The depth of the tree, which is the number of edges from the node to the +tree's root node.

+

The hash function used to compute the tree nodes.

+
_nodes: any[][]

The matrix where all the tree nodes are stored. The first index indicates +the level of the tree, while the second index represents the node's +position within that specific level.

+
_zeroes: any[]

A list of zero values calculated during the initialization of the tree. +The list contains one value for each level of the tree, and the value for +a given level is equal to the hash of the previous level's value. +The first value is the zero hash provided by the user. +These values are used to calculate the hash of a node in case some of its +children are missing.

+

Accessors

  • get arity(): number
  • The number of children per node.

    +

    Returns number

    The number of children per node.

    +
  • get depth(): number
  • The depth of the tree, which equals the number of levels - 1.

    +

    Returns number

    The depth of the tree.

    +
  • get leaves(): any[]
  • The leaves of the tree. They can be retrieved from the first +level of the tree using IMT#_nodes. The returned +value is a copy of the array and not the original object.

    +

    Returns any[]

    The list of tree leaves.

    +
  • get root(): any
  • The root of the tree. This value doesn't need to be stored as +it is always the first and unique element of the last level of the tree. +Its value can be retrieved in IMT#_nodes.

    +

    Returns any

    The root hash of the tree.

    +
  • get zeroes(): any[]
  • The list of zero values calculated during the initialization of the tree.

    +

    Returns any[]

    The list of pre-computed zeroes.

    +

Methods

  • It creates a IMTMerkleProof for a leaf of the tree. +That proof can be verified by this tree using the same hash function.

    +

    Parameters

    • index: number

      The index of the leaf for which a Merkle proof will be generated.

      +

    Returns IMTMerkleProof

    The Merkle proof of the leaf.

    +
  • It deletes a leaf from the tree. It does not remove the leaf from +the data structure, but rather it sets the leaf to be deleted to the zero value.

    +

    Parameters

    • index: number

      The index of the leaf to be deleted.

      +

    Returns void

  • It returns the index of a leaf. If the leaf does not exist it returns -1.

    +

    Parameters

    • leaf: any

      A leaf of the tree.

      +

    Returns number

    The index of the leaf.

    +
  • The leaves are inserted incrementally. If 'i' is the index of the last +leaf, the new one will be inserted at position 'i + 1'. Every time a +new leaf is inserted, the nodes that separate the new leaf from the root +of the tree are created or updated if they already exist, from bottom to top. +When a node has only one child (the left one), its value is the hash of that +node and the zero value of that level. Otherwise, the hash of the children +is calculated.

    +

    Parameters

    • leaf: any

      The new leaf to be inserted in the tree.

      +

    Returns void

  • It updates a leaf in the tree. It's very similar to the IMT#insert function.

    +

    Parameters

    • index: number

      The index of the leaf to be updated.

      +
    • newLeaf: any

      The new leaf to be inserted.

      +

    Returns void

  • It verifies a IMTMerkleProof to confirm that a leaf indeed +belongs to the tree.

    +

    Parameters

    Returns boolean

    True if the leaf is part of the tree, and false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/classes/_zk_kit_imt.LeanIMT.html b/classes/_zk_kit_imt.LeanIMT.html new file mode 100644 index 000000000..ae158dde7 --- /dev/null +++ b/classes/_zk_kit_imt.LeanIMT.html @@ -0,0 +1,85 @@ +LeanIMT | ZK-kit

Class LeanIMT<N>

The LeanIMT is an optimized binary version of the IMT. +This implementation exclusively supports binary trees, eliminates the use of +zeroes, and the tree's LeanIMT#depth is dynamic. When a node doesn't have the right child, +instead of using a zero hash as in the IMT, the node's value becomes that +of its left child. Furthermore, rather than utilizing a static tree depth, +it is updated based on the number of LeanIMT#leaves in the tree. This approach +results in the calculation of significantly fewer hashes, making the tree more efficient.

+

Type Parameters

  • N = bigint

Constructors

  • It initializes the tree with a given hash function and an optional list of leaves.

    +

    Type Parameters

    • N = bigint

    Parameters

    • hash: LeanIMTHashFunction<N>

      The hash function used to create nodes.

      +
    • leaves: N[] = []

      The list of leaves.

      +

    Returns LeanIMT<N>

Properties

The hash function used to compute the tree nodes.

+
_nodes: N[][]

The matrix where all the tree nodes are stored. The first index indicates +the level of the tree, while the second index represents the node's +position within that specific level. The last level will always contain +a list with a single element, which is the root. +Most of the attributes of this class are getters which can retrieve +their values from this matrix.

+

Accessors

  • get depth(): number
  • The depth of the tree, which equals the number of levels - 1.

    +

    Returns number

    The depth of the tree.

    +
  • get leaves(): N[]
  • The leaves of the tree. They can be retrieved from the first +level of the tree using LeanIMT#_nodes. The returned +value is a copy of the array and not the original object.

    +

    Returns N[]

    The list of tree leaves.

    +
  • get root(): N
  • The root of the tree. This value doesn't need to be stored as +it is always the first and unique element of the last level of the tree. +Its value can be retrieved in LeanIMT#_nodes.

    +

    Returns N

    The root hash of the tree.

    +
  • get size(): number
  • The size of the tree, which the number of its leaves. +It's the length of the first level's list.

    +

    Returns number

    The number of leaves of the tree.

    +

Methods

  • It enables the conversion of the full tree structure into a JSON string, +facilitating future imports of the tree. This approach is beneficial for +large trees, as it saves time by storing hashes instead of recomputing them

    +

    Returns string

    The stringified JSON of the tree.

    +
  • It returns true if the leaf exists, and false otherwise

    +

    Parameters

    • leaf: N

      A leaf of the tree.

      +

    Returns boolean

    True if the tree has the leaf, and false otherwise.

    +
  • It imports an entire tree by initializing the nodes without calculating +any hashes. Note that it is crucial to ensure the integrity of the tree +before or after importing it. +The tree must be empty before importing.

    +

    Parameters

    • nodes: string

      The stringified JSON of the tree.

      +

    Returns void

  • It returns the index of a leaf. If the leaf does not exist it returns -1.

    +

    Parameters

    • leaf: N

      A leaf of the tree.

      +

    Returns number

    The index of the leaf.

    +
  • The leaves are inserted incrementally. If 'i' is the index of the last +leaf, the new one will be inserted at position 'i + 1'. Every time a +new leaf is inserted, the nodes that separate the new leaf from the root +of the tree are created or updated if they already exist, from bottom to top. +When a node has only one child (the left one), its value takes on the value +of the child. Otherwise, the hash of the children is calculated.

    +

    Parameters

    • leaf: N

      The new leaf to be inserted in the tree.

      +

    Returns void

  • This function is useful when you want to insert N leaves all at once. +It is more efficient than using the LeanIMT#insert method N times because it +significantly reduces the number of cases where a node has only one +child, which is a common occurrence in gradual insertion.

    +

    Parameters

    • leaves: N[]

      The list of leaves to be inserted.

      +

    Returns void

  • It updates a leaf in the tree. It's very similar to the LeanIMT#insert function.

    +

    Parameters

    • index: number

      The index of the leaf to be updated.

      +
    • newLeaf: N

      The new leaf to be inserted.

      +

    Returns void

Generated using TypeDoc

\ No newline at end of file diff --git a/classes/_zk_kit_smt.SMT.html b/classes/_zk_kit_smt.SMT.html new file mode 100644 index 000000000..9ce11b23f --- /dev/null +++ b/classes/_zk_kit_smt.SMT.html @@ -0,0 +1,95 @@ +SMT | ZK-kit

SparseMerkleTree class provides all the functions to create a sparse Merkle tree +and to take advantage of its features: SMT.add, SMT.get, +SMT.update, SMT.delete, SMT.createProof, +SMT.verifyProof. +To better understand the code below it may be useful to describe the terminology used:

+
    +
  • nodes: every node in the tree is the hash of the two child nodes (H(x, y));
  • +
  • root node: the root node is the top hash and since it represents the whole data +structure it can be used to certify its integrity;
  • +
  • leaf nodes: every leaf node is the hash of a key/value pair and an additional +value to mark the node as leaf node (H(x, y, 1));
  • +
  • entry: a tree entry is a key/value pair used to create the leaf nodes;
  • +
  • zero nodes: a zero node is an hash of zeros and in this implementation H(0,0) = 0;
  • +
  • siblings: the children of a parent node are siblings;
  • +
  • path: every entry key is a number < 2^256 that can be converted in a binary number, +and this binary number is the path used to place the entry in the tree (1 or 0 define the +child node to choose);
  • +
  • matching node: when an entry is not found and the path leads to another existing entry, +this entry is a matching entry and it has some of the first bits in common with the entry not found;
  • +
  • depth: the depth of a node is the length of the path to its root.
  • +
+

Constructors

  • Initializes the SparseMerkleTree attributes.

    +

    Parameters

    • hash: HashFunction

      Hash function used to hash the child nodes.

      +
    • bigNumbers: boolean = false

      BigInt type enabling.

      +

    Returns SMT

Properties

bigNumbers: boolean
entryMark: Node
nodes: Map<Node, ChildNodes>
root: Node
zeroNode: Node

Methods

  • Adds a new entry in the tree. It retrieves a matching entry +or a zero node with a top-down approach and then it updates all the +hashes of the nodes in the path of the new entry with a bottom-up approach.

    +

    Parameters

    • key: Node

      The key of the new entry.

      +
    • value: Node

      The value of the new entry.

      +

    Returns void

  • Adds new nodes in the tree with a bottom-up approach until it reaches the root node.

    +

    Parameters

    • node: Node

      The node to start from.

      +
    • path: number[]

      The path of the key.

      +
    • siblings: Siblings

      The siblings of the path.

      +
    • i: number = ...

      The index to start from.

      +

    Returns Node

    The root node.

    +
  • Calculates nodes with a bottom-up approach until it reaches the root node.

    +

    Parameters

    • node: Node

      The node to start from.

      +
    • path: number[]

      The path of the key.

      +
    • siblings: Siblings

      The siblings of the path.

      +

    Returns Node

    The root node.

    +
  • Checks the parameter type.

    +

    Parameters

    • parameter: Node

      The parameter to check.

      +

    Returns void

  • Creates a proof to prove the membership or the non-membership +of a tree entry.

    +

    Parameters

    • key: Node

      A key of an existing or a non-existing entry.

      +

    Returns MerkleProof

    The membership or the non-membership proof.

    +
  • Deletes an entry in the tree. Also in this case all the hashes of +the nodes in the path of the entry are updated with a bottom-up approach.

    +

    Parameters

    • key: Node

      The key of the entry.

      +

    Returns void

  • Deletes nodes in the tree with a bottom-up approach until it reaches the root node.

    +

    Parameters

    • node: Node

      The node to start from.

      +
    • path: number[]

      The path of the key.

      +
    • siblings: Siblings

      The siblings of the path.

      +

    Returns void

  • Gets a key and if the key exists in the tree the function returns the +value, otherwise it returns 'undefined'.

    +

    Parameters

    • key: Node

      A key of a tree entry.

      +

    Returns undefined | Node

    A value of a tree entry or 'undefined'.

    +
  • Checks if a node is a leaf node.

    +

    Parameters

    • node: Node

      A node of the tree.

      +

    Returns boolean

    True if the node is a leaf, false otherwise.

    +
  • Searches for an entry in the tree. If the key passed as parameter exists in +the tree, the function returns the entry, otherwise it returns the entry +with only the key, and when there is another existing entry +in the same path it returns also this entry as 'matching entry'. +In any case the function returns the siblings of the path.

    +

    Parameters

    • key: Node

      The key of the entry to search for.

      +

    Returns EntryResponse

    The entry response.

    +
  • Updates a value of an entry in the tree. Also in this case +all the hashes of the nodes in the path of the entry are updated +with a bottom-up approach.

    +

    Parameters

    • key: Node

      The key of the entry.

      +
    • value: Node

      The value of the entry.

      +

    Returns void

  • Verifies a membership or a non-membership proof.

    +

    Parameters

    Returns boolean

    True if the proof is valid, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/classes/_zk_kit_utils.F1Field.html b/classes/_zk_kit_utils.F1Field.html new file mode 100644 index 000000000..eae61de21 --- /dev/null +++ b/classes/_zk_kit_utils.F1Field.html @@ -0,0 +1,92 @@ +F1Field | ZK-kit

F1Field +Represents a finite field of order 'order' providing arithmetic operations under modulus. +This class includes operations such as addition, subtraction, multiplication, division, +and inversion, all performed modulo the field's order. It's designed to work with bigints, +supporting large numbers for cryptographic purposes and other applications requiring +modular arithmetic.

+

Constructors

Properties

Methods

Constructors

Properties

_half: bigint

Half the order of the field, used for certain comparisons.

+
_negone: bigint

The scalar value -1 in the field, represented positively.

+
_order: bigint

The order of the finite field (i.e., the modulus).

+
one: bigint = ...

Represents the scalar value 1 in the field.

+
zero: bigint = ...

Represents the scalar value 0 in the field.

+

Methods

  • Adds two bigint values together under modulus, ensuring the result is within the field.

    +

    Parameters

    • a: bigint

      The first value.

      +
    • b: bigint

      The second value.

      +

    Returns bigint

    The sum of 'a' and 'b' modulo the field's order.

    +
  • Divides one bigint by another within the field by multiplying the first value +by the multiplicative inverse of the second.

    +

    Parameters

    • a: bigint

      The dividend.

      +
    • b: bigint

      The divisor.

      +

    Returns bigint

    The result of the division of 'a' by 'b' modulo the field's order.

    +
  • Ensures a given result falls within the field by applying modular reduction. +This method also handles negative inputs, correctly mapping them into the field.

    +

    Parameters

    • res: bigint

      The result to be normalized to the field.

      +

    Returns bigint

    The equivalent value within the field.

    +
  • Checks if two bigint values are equal within the context of the field.

    +

    Parameters

    • a: bigint

      The first value to compare.

      +
    • b: bigint

      The second value to compare.

      +

    Returns boolean

    True if 'a' equals 'b', false otherwise.

    +
  • Compares two bigint values to determine if the first is greater than or equal to the second, +considering the field's modular context.

    +

    Parameters

    • a: bigint

      The first value to compare.

      +
    • b: bigint

      The second value to compare.

      +

    Returns boolean

    True if 'a' is greater than or equal to 'b', false otherwise.

    +
  • Computes the multiplicative inverse of a given value within the field. +This method uses the Extended Euclidean Algorithm to find the inverse, +ensuring the result is always a positive value less than the field's order. +If the input value is zero, which has no inverse, an error is thrown.

    +

    Parameters

    • a: bigint

      The value for which to compute the inverse.

      +

    Returns bigint

    The multiplicative inverse of 'a' modulo the field's order.

    +

    Throws

    if 'a' is zero.

    +
  • Checks if a bigint value is zero within the context of the field.

    +

    Parameters

    • a: bigint

      The value to check.

      +

    Returns boolean

    True if 'a' is zero, false otherwise.

    +
  • Compares two bigint values to determine if the first is less than the second, +taking into account the field's order for modular comparison.

    +

    Parameters

    • a: bigint

      The first value to compare.

      +
    • b: bigint

      The second value to compare.

      +

    Returns boolean

    True if 'a' is less than 'b', false otherwise.

    +
  • Performs modular multiplication of two bigint values within the field.

    +

    Parameters

    • a: bigint

      The first value.

      +
    • b: bigint

      The second value.

      +

    Returns bigint

    The product of 'a' and 'b' modulo the field's order.

    +
  • Computes the negation of a bigint value within the field. +The result is the modular additive inverse that, when added to the original value, +yields zero in the field's modulus.

    +

    Parameters

    • a: bigint

      The value to negate.

      +

    Returns bigint

    The negation of 'a' modulo the field's order.

    +
  • Raises a base to an exponent within the field, efficiently computing +scalar exponentiation using the square-and-multiply algorithm. +Supports both positive and negative exponents through the use of the inv method for negatives.

    +

    Parameters

    • base: bigint

      The base to be exponentiated.

      +
    • e: bigint

      The exponent.

      +

    Returns bigint

    The result of raising 'base' to the power 'e' modulo the field's order.

    +
  • Squares a bigint value within the field. +This is a specific case of multiplication where the value is multiplied by itself, +optimized for performance where applicable.

    +

    Parameters

    • a: bigint

      The value to square.

      +

    Returns bigint

    The square of 'a' modulo the field's order.

    +
  • Subtracts one bigint from another under modulus, ensuring the result is within the field.

    +

    Parameters

    • a: bigint

      The value from which to subtract.

      +
    • b: bigint

      The value to be subtracted.

      +

    Returns bigint

    The difference of 'a' and 'b' modulo the field's order.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_baby_jubjub.addPoint.html b/functions/_zk_kit_baby_jubjub.addPoint.html new file mode 100644 index 000000000..61221f907 --- /dev/null +++ b/functions/_zk_kit_baby_jubjub.addPoint.html @@ -0,0 +1,10 @@ +addPoint | ZK-kit
  • Performs point addition on the Baby Jubjub elliptic curve, +calculating a third point from two given points. +Let P1 = (x1, y1) and P2 = (x2, y2) be two arbitrary points of the curve. +Then P1 + P2 = (x3, y3) is calculated in the following way: +x3 = (x1y2 + y1x2)/(1 + dx1x2y1y2) +y3 = (y1y2 - ax1x2)/(1 - dx1x2y1*y2)

    +

    Parameters

    • p1: Point<bigint>

      First point on the curve.

      +
    • p2: Point<bigint>

      Second point on the curve.

      +

    Returns Point<bigint>

    Resultant third point on the curve.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_baby_jubjub.inCurve.html b/functions/_zk_kit_baby_jubjub.inCurve.html new file mode 100644 index 000000000..e8a5e020e --- /dev/null +++ b/functions/_zk_kit_baby_jubjub.inCurve.html @@ -0,0 +1,5 @@ +inCurve | ZK-kit
  • Determines if a given point lies on the Baby Jubjub elliptic curve by verifying the curve equation. +This function checks if the point satisfies the curve equation ax^2 + y^2 = 1 + dx^2y^2.

    +

    Parameters

    • p: Point

      The point to check, represented as a pair of bigint values.

      +

    Returns boolean

    True if the point is on the curve, otherwise false.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_baby_jubjub.mulPointEscalar.html b/functions/_zk_kit_baby_jubjub.mulPointEscalar.html new file mode 100644 index 000000000..e006a72f7 --- /dev/null +++ b/functions/_zk_kit_baby_jubjub.mulPointEscalar.html @@ -0,0 +1,6 @@ +mulPointEscalar | ZK-kit
  • Performs a scalar multiplication by starting from the 'base' point and 'adding' +it to itself 'e' times.

    +

    Parameters

    • base: Point<bigint>

      The base point used as a starting point.

      +
    • e: bigint

      A secret number representing the private key.

      +

    Returns Point<bigint>

    The resulting point representing the public key.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_baby_jubjub.packPoint.html b/functions/_zk_kit_baby_jubjub.packPoint.html new file mode 100644 index 000000000..fb1787454 --- /dev/null +++ b/functions/_zk_kit_baby_jubjub.packPoint.html @@ -0,0 +1,6 @@ +packPoint | ZK-kit
  • Packs a point on the Baby Jubjub elliptic curve into a bigint. +This process involves converting the y-coordinate to a buffer and conditionally modifying the last byte +to encode the sign of the x-coordinate, following a specific compact representation format.

    +

    Parameters

    • unpackedPoint: Point<bigint>

      The point to be packed, consisting of x and y coordinates.

      +

    Returns bigint

    The packed representation of the point as a bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_baby_jubjub.unpackPoint.html b/functions/_zk_kit_baby_jubjub.unpackPoint.html new file mode 100644 index 000000000..0097394ac --- /dev/null +++ b/functions/_zk_kit_baby_jubjub.unpackPoint.html @@ -0,0 +1,6 @@ +unpackPoint | ZK-kit
  • Unpacks a bigint back into a point on the Baby Jubjub elliptic curve, reversing the packing process. +This involves interpreting the bigint as the y-coordinate and extracting the sign of the x-coordinate +from the encoded format. The function then calculates the x-coordinate using the curve equation.

    +

    Parameters

    • packedPoint: bigint

      The packed point as a bigint.

      +

    Returns Point<bigint> | null

    The unpacked point as a pair of bigint values, or null if the point is invalid.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.derivePublicKey.html b/functions/_zk_kit_eddsa_poseidon.derivePublicKey.html new file mode 100644 index 000000000..a82ceb138 --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.derivePublicKey.html @@ -0,0 +1,8 @@ +derivePublicKey | ZK-kit
  • Derives a public key from a given private key using the +Jubjub elliptic curve. +This function utilizes the Baby Jubjub elliptic curve for cryptographic operations. +The private key should be securely stored and managed, and it should never be exposed +or transmitted in an unsecured manner.

    +

    Parameters

    • privateKey: BigNumberish

      The private key used for generating the public key.

      +

    Returns Point<string>

    The derived public key.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.deriveSecretScalar.html b/functions/_zk_kit_eddsa_poseidon.deriveSecretScalar.html new file mode 100644 index 000000000..63ac36642 --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.deriveSecretScalar.html @@ -0,0 +1,10 @@ +deriveSecretScalar | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.packPublicKey.html b/functions/_zk_kit_eddsa_poseidon.packPublicKey.html new file mode 100644 index 000000000..cdc2c2ee1 --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.packPublicKey.html @@ -0,0 +1,5 @@ +packPublicKey | ZK-kit
  • Converts a given public key into a packed (compressed) string format for efficient transmission and storage. +This method ensures the public key is valid and within the Baby Jubjub curve before packing.

    +

    Parameters

    • publicKey: Point

      The public key to be packed.

      +

    Returns string

    A string representation of the packed public key.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.signMessage.html b/functions/_zk_kit_eddsa_poseidon.signMessage.html new file mode 100644 index 000000000..e71938976 --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.signMessage.html @@ -0,0 +1,6 @@ +signMessage | ZK-kit
  • Signs a message using the provided private key, employing Poseidon hashing and +EdDSA with the Baby Jubjub elliptic curve.

    +

    Parameters

    Returns Signature<string>

    The signature object, containing properties relevant to EdDSA signatures, such as 'R8' and 'S' values.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.unpackPublicKey.html b/functions/_zk_kit_eddsa_poseidon.unpackPublicKey.html new file mode 100644 index 000000000..9e91724ad --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.unpackPublicKey.html @@ -0,0 +1,5 @@ +unpackPublicKey | ZK-kit
  • Unpacks a public key from its packed string representation back to its original point form on the Baby Jubjub curve. +This function checks for the validity of the input format before attempting to unpack.

    +

    Parameters

    • publicKey: BigNumberish

      The packed public key as a bignumberish.

      +

    Returns Point<string>

    The unpacked public key as a point.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_poseidon.verifySignature.html b/functions/_zk_kit_eddsa_poseidon.verifySignature.html new file mode 100644 index 000000000..c63acbb9d --- /dev/null +++ b/functions/_zk_kit_eddsa_poseidon.verifySignature.html @@ -0,0 +1,6 @@ +verifySignature | ZK-kit
  • Verifies an EdDSA signature using the Baby Jubjub elliptic curve and Poseidon hash function.

    +

    Parameters

    • message: BigNumberish

      The original message that was be signed.

      +
    • signature: Signature

      The EdDSA signature to be verified.

      +
    • publicKey: Point

      The public key associated with the private key used to sign the message.

      +

    Returns boolean

    Returns true if the signature is valid and corresponds to the message and public key, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_proof.generate.html b/functions/_zk_kit_eddsa_proof.generate.html new file mode 100644 index 000000000..fe68b447a --- /dev/null +++ b/functions/_zk_kit_eddsa_proof.generate.html @@ -0,0 +1,14 @@ +generate | ZK-kit
  • Creates a zero-knowledge proof to prove that you have the pre-image of a Semaphore commitment, +without disclosing the actual preimage itself. +The use of a scope parameter along with a nullifier helps ensure the uniqueness +and non-reusability of the proofs, enhancing security in applications like +blockchain transactions or private data verification. +If, for example, this package were used with Semaphore to demonstrate possession +of a Semaphore identity of a group of voters, the scope could be the poll's ID.

    +

    Parameters

    • privateKey: string | number | bigint | Buffer

      The private key of the commitment.

      +
    • scope: number | bigint | BytesLike | Hexable

      A public value used to contextualize the cryptographic proof +and calculate the nullifier.

      +
    • Optional snarkArtifacts: SnarkArtifacts

      The Snark artifacts (wasm and zkey files) generated in +a trusted setup of the circuit are necessary to generate valid proofs

      +

    Returns Promise<EddsaProof>

    The Poseidon zero-knowledge proof.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_eddsa_proof.verify.html b/functions/_zk_kit_eddsa_proof.verify.html new file mode 100644 index 000000000..0f19881f3 --- /dev/null +++ b/functions/_zk_kit_eddsa_proof.verify.html @@ -0,0 +1,4 @@ +verify | ZK-kit
  • Verifies that a Eddsa proof is valid.

    +

    Parameters

    • eddsaProof: EddsaProof

      The Eddsa zero-knowledge proof.

      +

    Returns Promise<boolean>

    True if the proof is valid, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_groth16.buildBn128.html b/functions/_zk_kit_groth16.buildBn128.html new file mode 100644 index 000000000..5ec283106 --- /dev/null +++ b/functions/_zk_kit_groth16.buildBn128.html @@ -0,0 +1,4 @@ +buildBn128 | ZK-kit
  • Builds and returns a BN 128 curve. If the curve has been cached, +it returns the cached curve.

    +

    Returns Promise<any>

    BN 128 ffjavascript curve.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_groth16.prove.html b/functions/_zk_kit_groth16.prove.html new file mode 100644 index 000000000..dbaced589 --- /dev/null +++ b/functions/_zk_kit_groth16.prove.html @@ -0,0 +1,6 @@ +prove | ZK-kit
  • Creates a Groth16 proof composed of public signals and zero-knowledge parameters.

    +

    Parameters

    Returns Promise<{
        proof: Groth16Proof;
        publicSignals: PublicSignals;
    }>

    A proof containing public signals and zero-knowledge parameters.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_groth16.verify.html b/functions/_zk_kit_groth16.verify.html new file mode 100644 index 000000000..e546cee6e --- /dev/null +++ b/functions/_zk_kit_groth16.verify.html @@ -0,0 +1,5 @@ +verify | ZK-kit
  • Verifies if a Groth16 proof is valid or not.

    +

    Parameters

    • verificationKey: any

      The verification key used to verify the proof.

      +
    • proof: {
          proof: Groth16Proof;
          publicSignals: PublicSignals;
      }

      The proof containing public signals and zero-knowledge parameters.

      +

    Returns Promise<boolean>

    True if the proof is valid, and false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_lazytower.LazyTowerHashChainProofBuilder.html b/functions/_zk_kit_lazytower.LazyTowerHashChainProofBuilder.html new file mode 100644 index 000000000..b2476ae80 --- /dev/null +++ b/functions/_zk_kit_lazytower.LazyTowerHashChainProofBuilder.html @@ -0,0 +1,12 @@ +LazyTowerHashChainProofBuilder | ZK-kit

Function LazyTowerHashChainProofBuilder

  • LazyTowerHashChainProofBuilder is a TypeScript implementation of LazyTower to generate proofs of membership.

    +

    Parameters

    • H: number

      Height of tower of the proving circuit. It can be less than the H in the contract.

      +
    • W: number

      Width of tower.

      +
    • hash: ((a, b) => bigint) = defaultHash

      A hash function which supports 2 input values.

      +
        • (a, b): bigint
        • Parameters

          • a: bigint
          • b: bigint

          Returns bigint

    Returns {
        add: ((item) => void);
        build: ((idx) => LazyTowerHashChainProof);
        indexOf: ((item) => number);
    }

    • add: ((item) => void)
        • (item): void
        • Adds a new item in the LazyTower.

          +

          Parameters

          • item: bigint

            Item to be added.

            +

          Returns void

    • build: ((idx) => LazyTowerHashChainProof)
    • indexOf: ((item) => number)
        • (item): number
        • Returns the index of a item. If the item does not exist it returns -1.

          +

          Parameters

          • item: bigint

            Added item.

            +

          Returns number

          Index of the item.

          +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.checkEqual.html b/functions/_zk_kit_poseidon_cipher.checkEqual.html new file mode 100644 index 000000000..16cfcd84b --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.checkEqual.html @@ -0,0 +1,5 @@ +checkEqual | ZK-kit
  • Check if two field values are equal

    +

    Parameters

    • a: bigint

      the first value

      +
    • b: bigint

      the second value

      +
    • error: string

      the error to throw if the values are not equal

      +

    Returns void

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.normalize.html b/functions/_zk_kit_poseidon_cipher.normalize.html new file mode 100644 index 000000000..1722f200c --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.normalize.html @@ -0,0 +1,5 @@ +normalize | ZK-kit
  • Given a bigint a, returns a normalized value of a.

    +

    Parameters

    • a: bigint

      the value to normalize

      +

    Returns bigint

    the normalized value of a

    +

    Dev

    r is 'r' is the alt_bn128 prime order, so we can use it to normalize values

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.poseidonDecrypt.html b/functions/_zk_kit_poseidon_cipher.poseidonDecrypt.html new file mode 100644 index 000000000..3c5fdf5af --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.poseidonDecrypt.html @@ -0,0 +1,7 @@ +poseidonDecrypt | ZK-kit
  • Decrypt some ciphertext using poseidon encryption

    +

    Parameters

    • ciphertext: CipherText<bigint>

      the ciphertext to decrypt

      +
    • key: EncryptionKey<bigint>

      the key to decrypt with

      +
    • nonce: bigint

      the nonce used to encrypt

      +
    • length: number

      the length of the plaintext

      +

    Returns PlainText<bigint>

    the plaintext

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.poseidonDecryptWithoutCheck.html b/functions/_zk_kit_poseidon_cipher.poseidonDecryptWithoutCheck.html new file mode 100644 index 000000000..b32530a71 --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.poseidonDecryptWithoutCheck.html @@ -0,0 +1,8 @@ +poseidonDecryptWithoutCheck | ZK-kit
  • Decrypt some ciphertext using poseidon encryption

    +

    Parameters

    • ciphertext: CipherText<bigint>

      the ciphertext to decrypt

      +
    • key: EncryptionKey<bigint>

      the key to decrypt with

      +
    • nonce: bigint

      the nonce used to encrypt

      +
    • length: number

      the length of the plaintext

      +

    Returns PlainText<bigint>

    the plaintext

    +

    Dev

    Do not throw if the plaintext is invalid

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.poseidonEncrypt.html b/functions/_zk_kit_poseidon_cipher.poseidonEncrypt.html new file mode 100644 index 000000000..04cff4ac1 --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.poseidonEncrypt.html @@ -0,0 +1,6 @@ +poseidonEncrypt | ZK-kit
  • Encrypt some plaintext using poseidon encryption

    +

    Parameters

    • msg: PlainText<bigint>

      the message to encrypt

      +
    • key: EncryptionKey<bigint>

      the key to encrypt with

      +
    • nonce: bigint

      the nonce to avoid replay attacks

      +

    Returns CipherText<bigint>

    the ciphertext

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.poseidonPerm.html b/functions/_zk_kit_poseidon_cipher.poseidonPerm.html new file mode 100644 index 000000000..6855a3427 --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.poseidonPerm.html @@ -0,0 +1,4 @@ +poseidonPerm | ZK-kit
  • Apply the Poseidon permutation to the given inputs

    +

    Parameters

    • inputs: bigint[]

      the inputs to the permutation

      +

    Returns bigint[]

    an array of bigint representing the output of the permutation

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.pow5.html b/functions/_zk_kit_poseidon_cipher.pow5.html new file mode 100644 index 000000000..cda11e67a --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.pow5.html @@ -0,0 +1,4 @@ +pow5 | ZK-kit
  • Given a bigint a, returns a^5.

    +

    Parameters

    • a: bigint

      the value to exponentiate

      +

    Returns bigint

    the result of a^5

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.unstringifyBigInts.html b/functions/_zk_kit_poseidon_cipher.unstringifyBigInts.html new file mode 100644 index 000000000..dec94f98f --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.unstringifyBigInts.html @@ -0,0 +1,5 @@ +unstringifyBigInts | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_cipher.validateNonce.html b/functions/_zk_kit_poseidon_cipher.validateNonce.html new file mode 100644 index 000000000..ff52d55f7 --- /dev/null +++ b/functions/_zk_kit_poseidon_cipher.validateNonce.html @@ -0,0 +1,3 @@ +validateNonce | ZK-kit
  • Validate that the nonce is less than 2 ^ 128 (sqrt of the field size)

    +

    Parameters

    • nonce: bigint

      the nonce to validate

      +

    Returns void

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_proof.generate.html b/functions/_zk_kit_poseidon_proof.generate.html new file mode 100644 index 000000000..a5e52b130 --- /dev/null +++ b/functions/_zk_kit_poseidon_proof.generate.html @@ -0,0 +1,14 @@ +generate | ZK-kit
  • Creates a zero-knowledge proof to prove that you have the preimages of a hash, +without disclosing the actual preimages themselves. +The use of a scope parameter helps ensure the uniqueness +and non-reusability of the proofs, enhancing security in applications like +blockchain transactions or private data verification. +If, for example, this package were used with Semaphore to demonstrate possession +of a Semaphore identity of a group of voters, the scope could be the poll's ID.

    +

    Parameters

    • preimages: (number | bigint | BytesLike | Hexable)[]

      The preimages of the hash.

      +
    • scope: number | bigint | BytesLike | Hexable

      A public value used to contextualize the cryptographic proof +and calculate the nullifier.

      +
    • Optional snarkArtifacts: SnarkArtifacts

      The Snark artifacts (wasm and zkey files) generated in +a trusted setup of the circuit are necessary to generate valid proofs

      +

    Returns Promise<PoseidonProof>

    The Poseidon zero-knowledge proof.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_poseidon_proof.verify.html b/functions/_zk_kit_poseidon_proof.verify.html new file mode 100644 index 000000000..7a34e2561 --- /dev/null +++ b/functions/_zk_kit_poseidon_proof.verify.html @@ -0,0 +1,3 @@ +verify | ZK-kit
  • Verifies that a Poseidon proof is valid.

    +

    Parameters

    Returns Promise<boolean>

    True if the proof is valid, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_smt.checkHex.html b/functions/_zk_kit_smt.checkHex.html new file mode 100644 index 000000000..27cd4e3ae --- /dev/null +++ b/functions/_zk_kit_smt.checkHex.html @@ -0,0 +1,4 @@ +checkHex | ZK-kit

Function checkHex

  • Checks if a number is a hexadecimal number.

    +

    Parameters

    • n: string

      A hexadecimal number.

      +

    Returns boolean

    True if the number is a hexadecimal, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_smt.getFirstCommonElements.html b/functions/_zk_kit_smt.getFirstCommonElements.html new file mode 100644 index 000000000..5d196dbdd --- /dev/null +++ b/functions/_zk_kit_smt.getFirstCommonElements.html @@ -0,0 +1,5 @@ +getFirstCommonElements | ZK-kit

Function getFirstCommonElements

  • Returns the first common elements of two arrays.

    +

    Parameters

    • array1: any[]

      The first array.

      +
    • array2: any[]

      The second array.

      +

    Returns any[]

    The array of the first common elements.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_smt.getIndexOfLastNonZeroElement.html b/functions/_zk_kit_smt.getIndexOfLastNonZeroElement.html new file mode 100644 index 000000000..47e685382 --- /dev/null +++ b/functions/_zk_kit_smt.getIndexOfLastNonZeroElement.html @@ -0,0 +1,5 @@ +getIndexOfLastNonZeroElement | ZK-kit

Function getIndexOfLastNonZeroElement

  • Returns the index of the last non-zero element of an array. +If there are only zero elements the function returns -1.

    +

    Parameters

    • array: any[]

      An array of hexadecimal or big numbers.

      +

    Returns number

    The index of the last non-zero element.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_smt.hexToBin.html b/functions/_zk_kit_smt.hexToBin.html new file mode 100644 index 000000000..f359ffbb5 --- /dev/null +++ b/functions/_zk_kit_smt.hexToBin.html @@ -0,0 +1,4 @@ +hexToBin | ZK-kit

Function hexToBin

  • Converts a hexadecimal number to a binary number.

    +

    Parameters

    • n: string

      A hexadecimal number.

      +

    Returns string

    The relative binary number.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_smt.keyToPath.html b/functions/_zk_kit_smt.keyToPath.html new file mode 100644 index 000000000..c61f295ff --- /dev/null +++ b/functions/_zk_kit_smt.keyToPath.html @@ -0,0 +1,5 @@ +keyToPath | ZK-kit

Function keyToPath

  • Returns the binary representation of a key. For each key it is possible +to obtain an array of 256 padded bits.

    +

    Parameters

    • key: string | bigint

      The key of a tree entry.

      +

    Returns number[]

    The relative array of bits.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.beBigIntToBuffer.html b/functions/_zk_kit_utils.conversions.beBigIntToBuffer.html new file mode 100644 index 000000000..802557cca --- /dev/null +++ b/functions/_zk_kit_utils.conversions.beBigIntToBuffer.html @@ -0,0 +1,9 @@ +beBigIntToBuffer | ZK-kit
  • Converts a bigint to a buffer and fills with zeros if a valid +size (i.e. number of bytes) is specified. If the size is not defined, +it gets the size from the given bigint. If the specified size is smaller than +the size of the bigint (i.e. minSize), an error is thrown. +It uses big-endian byte order.

    +

    Parameters

    • n: bigint

      The bigint to convert.

      +
    • Optional size: number

      The number of bytes of the buffer to return.

      +

    Returns Buffer

    The buffer representation of the bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.beBufferToBigInt.html b/functions/_zk_kit_utils.conversions.beBufferToBigInt.html new file mode 100644 index 000000000..a9d6d194a --- /dev/null +++ b/functions/_zk_kit_utils.conversions.beBufferToBigInt.html @@ -0,0 +1,4 @@ +beBufferToBigInt | ZK-kit
  • Converts a buffer of bytes to a bigint using big-endian byte order.

    +

    Parameters

    • b: Buffer

      The buffer to convert.

      +

    Returns bigint

    The bigint representation of the buffer's contents.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.beHexadecimalToBigInt.html b/functions/_zk_kit_utils.conversions.beHexadecimalToBigInt.html new file mode 100644 index 000000000..e9ada220b --- /dev/null +++ b/functions/_zk_kit_utils.conversions.beHexadecimalToBigInt.html @@ -0,0 +1,5 @@ +beHexadecimalToBigInt | ZK-kit
  • Converts a hexadecimal string to a bigint. The input is interpreted as hexadecimal +with or without a '0x' prefix. It uses big-endian byte order.

    +

    Parameters

    • hex: string

      The hexadecimal string to convert.

      +

    Returns bigint

    The bigint representation of the hexadecimal string.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bigIntToBuffer.html b/functions/_zk_kit_utils.conversions.bigIntToBuffer.html new file mode 100644 index 000000000..5aade8b91 --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bigIntToBuffer.html @@ -0,0 +1,4 @@ +bigIntToBuffer | ZK-kit
  • Converts a bigint to a buffer. Alias for beBigIntToBuffer.

    +

    Parameters

    • n: bigint

      The bigint to convert.

      +

    Returns Buffer

    The buffer representation of the bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bigIntToHexadecimal.html b/functions/_zk_kit_utils.conversions.bigIntToHexadecimal.html new file mode 100644 index 000000000..33c77a15f --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bigIntToHexadecimal.html @@ -0,0 +1,4 @@ +bigIntToHexadecimal | ZK-kit
  • Converts a bigint to a hexadecimal string.

    +

    Parameters

    • n: bigint

      The bigint value to convert.

      +

    Returns string

    The hexadecimal representation of the bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bigNumberishToBigInt.html b/functions/_zk_kit_utils.conversions.bigNumberishToBigInt.html new file mode 100644 index 000000000..7a612dfb0 --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bigNumberishToBigInt.html @@ -0,0 +1,6 @@ +bigNumberishToBigInt | ZK-kit
  • Converts a BigNumberish type to a bigint. If the input is already a bigint, +the return value will be the bigint itself, otherwise it will be converted +to a bigint using big-endian byte order.

    +

    Parameters

    Returns bigint

    The bigint representation of the BigNumberish value.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bigNumberishToBuffer.html b/functions/_zk_kit_utils.conversions.bigNumberishToBuffer.html new file mode 100644 index 000000000..284f4831e --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bigNumberishToBuffer.html @@ -0,0 +1,6 @@ +bigNumberishToBuffer | ZK-kit
  • Converts a BigNumberish type to a buffer. If the input is already a buffer, +the return value will be the buffer itself, otherwise it will be converted +to a buffer using big-endian byte order.

    +

    Parameters

    Returns Buffer

    The buffer representation of the BigNumberish value.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bufferToBigInt.html b/functions/_zk_kit_utils.conversions.bufferToBigInt.html new file mode 100644 index 000000000..cece903fa --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bufferToBigInt.html @@ -0,0 +1,4 @@ +bufferToBigInt | ZK-kit
  • Converts a buffer to a bigint. Alias for beBufferToBigInt.

    +

    Parameters

    • b: Buffer

      The buffer to convert.

      +

    Returns bigint

    The bigint representation of the buffer's contents.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.bufferToHexadecimal.html b/functions/_zk_kit_utils.conversions.bufferToHexadecimal.html new file mode 100644 index 000000000..efdc346b8 --- /dev/null +++ b/functions/_zk_kit_utils.conversions.bufferToHexadecimal.html @@ -0,0 +1,5 @@ +bufferToHexadecimal | ZK-kit
  • Converts a buffer to a hexadecimal string. It accepts 'Buffer' or 'Uint8Array'. +The hexadecimal string will not start with '0x' or '0X'. It keeps the bytes in the same order.

    +

    Parameters

    • value: Uint8Array | Buffer

      The buffer to convert.

      +

    Returns string

    The converted hexadecimal string.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.hexadecimalToBigInt.html b/functions/_zk_kit_utils.conversions.hexadecimalToBigInt.html new file mode 100644 index 000000000..94486ffea --- /dev/null +++ b/functions/_zk_kit_utils.conversions.hexadecimalToBigInt.html @@ -0,0 +1,4 @@ +hexadecimalToBigInt | ZK-kit
  • Converts a hexadecimal string to a bigint. Alias for beHexadecimalToBigInt.

    +

    Parameters

    • hex: string

      The hexadecimal string to convert.

      +

    Returns bigint

    The bigint representation of the hexadecimal string.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.hexadecimalToBuffer.html b/functions/_zk_kit_utils.conversions.hexadecimalToBuffer.html new file mode 100644 index 000000000..853bc2b51 --- /dev/null +++ b/functions/_zk_kit_utils.conversions.hexadecimalToBuffer.html @@ -0,0 +1,5 @@ +hexadecimalToBuffer | ZK-kit
  • Converts an hexadecimal string to a buffer. The hexadecimal string +should not start with '0x' or '0X'. It keeps the bytes in the same order.

    +

    Parameters

    • value: string

      The hexadecimal string to convert.

      +

    Returns Buffer

    The buffer representation of the hexadecimal string.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.leBigIntToBuffer.html b/functions/_zk_kit_utils.conversions.leBigIntToBuffer.html new file mode 100644 index 000000000..03df9a2a4 --- /dev/null +++ b/functions/_zk_kit_utils.conversions.leBigIntToBuffer.html @@ -0,0 +1,9 @@ +leBigIntToBuffer | ZK-kit
  • Converts a bigint to a buffer and fills with zeros if a valid +size (i.e. number of bytes) is specified. If the size is not defined, +it gets the size from the given bigint. If the specified size is smaller than +the size of the bigint (i.e. minSize), an error is thrown. +It uses little-endian byte order.

    +

    Parameters

    • n: bigint

      The bigint to convert.

      +
    • Optional size: number

      The number of bytes of the buffer to return.

      +

    Returns Buffer

    The buffer representation of the bigint in little-endian.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.conversions.leBufferToBigInt.html b/functions/_zk_kit_utils.conversions.leBufferToBigInt.html new file mode 100644 index 000000000..92761a0dc --- /dev/null +++ b/functions/_zk_kit_utils.conversions.leBufferToBigInt.html @@ -0,0 +1,4 @@ +leBufferToBigInt | ZK-kit
  • Converts a buffer to a bigint using little-endian byte order.

    +

    Parameters

    • buffer: Buffer

      The buffer to convert.

      +

    Returns bigint

    The bigint representation of the buffer's contents in little-endian.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.crypto.getRandomValues.html b/functions/_zk_kit_utils.crypto.getRandomValues.html new file mode 100644 index 000000000..f1fc7d3be --- /dev/null +++ b/functions/_zk_kit_utils.crypto.getRandomValues.html @@ -0,0 +1,4 @@ +getRandomValues | ZK-kit
  • Generates a random sequence of bytes securely using Node.js's crypto module.

    +

    Parameters

    • size: number

      The number of bytes to generate.

      +

    Returns Uint8Array

    A Uint8Array containing the generated random bytes.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireArray.html b/functions/_zk_kit_utils.errorHandlers.requireArray.html new file mode 100644 index 000000000..602e5e191 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireArray.html @@ -0,0 +1,4 @@ +requireArray | ZK-kit
  • Parameters

    • parameterValue: any[]

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not an Array.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireBigInt.html b/functions/_zk_kit_utils.errorHandlers.requireBigInt.html new file mode 100644 index 000000000..7e8a3e789 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireBigInt.html @@ -0,0 +1,4 @@ +requireBigInt | ZK-kit
  • Parameters

    • parameterValue: bigint

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireBigNumber.html b/functions/_zk_kit_utils.errorHandlers.requireBigNumber.html new file mode 100644 index 000000000..7486ebb42 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireBigNumber.html @@ -0,0 +1,4 @@ +requireBigNumber | ZK-kit
  • Parameters

    • parameterValue: any

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a bignumber.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireBigNumberish.html b/functions/_zk_kit_utils.errorHandlers.requireBigNumberish.html new file mode 100644 index 000000000..d86d1a080 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireBigNumberish.html @@ -0,0 +1,4 @@ +requireBigNumberish | ZK-kit
  • Parameters

    • parameterValue: any

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a bignumber-ish.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireBuffer.html b/functions/_zk_kit_utils.errorHandlers.requireBuffer.html new file mode 100644 index 000000000..6802389dd --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireBuffer.html @@ -0,0 +1,4 @@ +requireBuffer | ZK-kit
  • Parameters

    • parameterValue: Buffer

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a Buffer.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireDefined.html b/functions/_zk_kit_utils.errorHandlers.requireDefined.html new file mode 100644 index 000000000..e7a3e637f --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireDefined.html @@ -0,0 +1,4 @@ +requireDefined | ZK-kit
  • Parameters

    • parameterValue: any

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value has not been defined.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireFunction.html b/functions/_zk_kit_utils.errorHandlers.requireFunction.html new file mode 100644 index 000000000..81675f73e --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireFunction.html @@ -0,0 +1,4 @@ +requireFunction | ZK-kit
  • Parameters

    • parameterValue: Function

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a function.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireHexadecimal.html b/functions/_zk_kit_utils.errorHandlers.requireHexadecimal.html new file mode 100644 index 000000000..60ed6ff2d --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireHexadecimal.html @@ -0,0 +1,8 @@ +requireHexadecimal | ZK-kit
  • Parameters

    • parameterValue: string

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +
    • prefix: boolean = true

      A boolean to include or not a '0x' or '0X' prefix.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a hexadecimal string. +If 'prefix' is 'true', the string must start with '0x' or '0X' followed by one or more +hexadecimal digits (0-9, a-f, A-F), otherwise no prefix is expected. 'prefix' is optional and +if its value it is not explicitly defined it will be set to 'true' by default.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireNumber.html b/functions/_zk_kit_utils.errorHandlers.requireNumber.html new file mode 100644 index 000000000..b66e3bb64 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireNumber.html @@ -0,0 +1,4 @@ +requireNumber | ZK-kit
  • Parameters

    • parameterValue: number

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a number.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireObject.html b/functions/_zk_kit_utils.errorHandlers.requireObject.html new file mode 100644 index 000000000..720ecceee --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireObject.html @@ -0,0 +1,5 @@ +requireObject | ZK-kit
  • Parameters

    • parameterValue: object

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not an object. +Please, note that arrays are also objects in JavaScript.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireString.html b/functions/_zk_kit_utils.errorHandlers.requireString.html new file mode 100644 index 000000000..08ea1c22f --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireString.html @@ -0,0 +1,4 @@ +requireString | ZK-kit
  • Parameters

    • parameterValue: string

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a string.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireStringifiedBigInt.html b/functions/_zk_kit_utils.errorHandlers.requireStringifiedBigInt.html new file mode 100644 index 000000000..030449a69 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireStringifiedBigInt.html @@ -0,0 +1,4 @@ +requireStringifiedBigInt | ZK-kit
  • Parameters

    • parameterValue: string

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a stringified bigint.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireTypes.html b/functions/_zk_kit_utils.errorHandlers.requireTypes.html new file mode 100644 index 000000000..f11e29406 --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireTypes.html @@ -0,0 +1,4 @@ +requireTypes | ZK-kit
  • Parameters

    • parameterValue: any

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +
    • types: ("string" | "number" | "bigint" | "object" | "function" | "Array" | "Uint8Array" | "Buffer" | "stringified-bigint" | "hexadecimal" | "bignumber" | "bignumberish")[]

    Returns void

    Throws

    Throws a type error if the parameter value type is not part of the list of types.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.errorHandlers.requireUint8Array.html b/functions/_zk_kit_utils.errorHandlers.requireUint8Array.html new file mode 100644 index 000000000..bb7c7434e --- /dev/null +++ b/functions/_zk_kit_utils.errorHandlers.requireUint8Array.html @@ -0,0 +1,4 @@ +requireUint8Array | ZK-kit
  • Parameters

    • parameterValue: Uint8Array

      The parameter value.

      +
    • parameterName: string

      The parameter name.

      +

    Returns void

    Throws

    Throws a type error if the parameter value is not a Uint8Array.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.packing.packGroth16Proof.html b/functions/_zk_kit_utils.packing.packGroth16Proof.html new file mode 100644 index 000000000..800bf3d74 --- /dev/null +++ b/functions/_zk_kit_utils.packing.packGroth16Proof.html @@ -0,0 +1,4 @@ +packGroth16Proof | ZK-kit
  • Packs a Snarkjs Groth16 proof into a single list usable as calldata in Solidity (public signals are not included).

    +

    Parameters

    • proof: Groth16Proof

      The Groth16 proof generated with SnarkJS.

      +

    Returns PackedGroth16Proof

    Solidity calldata.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.packing.unpackGroth16Proof.html b/functions/_zk_kit_utils.packing.unpackGroth16Proof.html new file mode 100644 index 000000000..d1fb474a5 --- /dev/null +++ b/functions/_zk_kit_utils.packing.unpackGroth16Proof.html @@ -0,0 +1,4 @@ +unpackGroth16Proof | ZK-kit
  • Unpacks a PackedGroth16Proof Solidity calldata into its original form which is a SnarkJS Groth16 proof.

    +

    Parameters

    Returns Groth16Proof

    The Groth16 proof compatible with SnarkJS.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.bits.html b/functions/_zk_kit_utils.scalar.bits.html new file mode 100644 index 000000000..921bd11ef --- /dev/null +++ b/functions/_zk_kit_utils.scalar.bits.html @@ -0,0 +1,7 @@ +bits | ZK-kit
  • Converts a bigint scalar value into an array of bits, represented as numbers. +This function is particularly useful for examining the binary structure of bigints, +which can be necessary for bit manipulation and understanding the representation +of numbers at a lower level.

    +

    Parameters

    • n: bigint

      The bigint scalar value to convert into bits.

      +

    Returns number[]

    An array of numbers representing the bits of 'n', starting from the least significant bit.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.gt.html b/functions/_zk_kit_utils.scalar.gt.html new file mode 100644 index 000000000..5530f49fe --- /dev/null +++ b/functions/_zk_kit_utils.scalar.gt.html @@ -0,0 +1,5 @@ +gt | ZK-kit
  • Compares two bigint scalar values to determine if the first is greater than the second.

    +

    Parameters

    • a: bigint

      The first bigint scalar value to compare.

      +
    • b: bigint

      The second bigint scalar value to compare.

      +

    Returns boolean

    True if 'a' is greater than 'b', false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.isOdd.html b/functions/_zk_kit_utils.scalar.isOdd.html new file mode 100644 index 000000000..580001a7b --- /dev/null +++ b/functions/_zk_kit_utils.scalar.isOdd.html @@ -0,0 +1,4 @@ +isOdd | ZK-kit
  • Determines whether a bigint scalar value is odd.

    +

    Parameters

    • a: bigint

      The bigint scalar value to check.

      +

    Returns boolean

    True if 'a' is odd, false if it is even.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.isZero.html b/functions/_zk_kit_utils.scalar.isZero.html new file mode 100644 index 000000000..a235cae15 --- /dev/null +++ b/functions/_zk_kit_utils.scalar.isZero.html @@ -0,0 +1,4 @@ +isZero | ZK-kit
  • Checks if a bigint scalar value is zero.

    +

    Parameters

    • a: bigint

      The bigint scalar value to check.

      +

    Returns boolean

    True if 'a' is zero, false otherwise.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.mul.html b/functions/_zk_kit_utils.scalar.mul.html new file mode 100644 index 000000000..8ec799f54 --- /dev/null +++ b/functions/_zk_kit_utils.scalar.mul.html @@ -0,0 +1,5 @@ +mul | ZK-kit
  • Multiplies two bigint scalar values.

    +

    Parameters

    • a: bigint

      The first bigint scalar value.

      +
    • b: bigint

      The second bigint scalar value.

      +

    Returns bigint

    The product of 'a' and 'b'.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.scalar.shiftRight.html b/functions/_zk_kit_utils.scalar.shiftRight.html new file mode 100644 index 000000000..24b74b593 --- /dev/null +++ b/functions/_zk_kit_utils.scalar.shiftRight.html @@ -0,0 +1,7 @@ +shiftRight | ZK-kit
  • Performs a bitwise right shift on a bigint scalar value. +This operation is equivalent to dividing by 2^n, but it operates directly +on the binary representation, making it efficient for certain types of calculations.

    +

    Parameters

    • a: bigint

      The bigint scalar value to shift.

      +
    • n: bigint

      The number of bits to shift 'a' by.

      +

    Returns bigint

    The result of shifting 'a' right by 'n' bits.

    +

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isArray.html b/functions/_zk_kit_utils.typeChecks.isArray.html new file mode 100644 index 000000000..bf1d34e7a --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isArray.html @@ -0,0 +1,3 @@ +isArray | ZK-kit
  • Returns true if the value is an Array instance, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isBigInt.html b/functions/_zk_kit_utils.typeChecks.isBigInt.html new file mode 100644 index 000000000..a269fd5f6 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isBigInt.html @@ -0,0 +1,3 @@ +isBigInt | ZK-kit
  • Returns true if the value is a bigint, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isBigNumber.html b/functions/_zk_kit_utils.typeChecks.isBigNumber.html new file mode 100644 index 000000000..c0af88f4d --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isBigNumber.html @@ -0,0 +1,5 @@ +isBigNumber | ZK-kit
  • Checks if the given value can be considered as BigNumber. +A value is considered a BigNumber if it is a bigint or a string +that can be converted to a bigint (via Bigint(s)).

    +

    Parameters

    • value: any

      The value to check.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isBigNumberish.html b/functions/_zk_kit_utils.typeChecks.isBigNumberish.html new file mode 100644 index 000000000..6342eed7b --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isBigNumberish.html @@ -0,0 +1,7 @@ +isBigNumberish | ZK-kit
  • Checks if the given value can be considered as BigNumberish. +A value is considered BigNumberish if it meets +any of the following conditions: it's a number, a bigint, a string +that can be converted to a bigint, a hexadecimal +string, or a Buffer object.

    +

    Parameters

    • value: any

      The value to check.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isBuffer.html b/functions/_zk_kit_utils.typeChecks.isBuffer.html new file mode 100644 index 000000000..51938368a --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isBuffer.html @@ -0,0 +1,3 @@ +isBuffer | ZK-kit
  • Returns true if the value is a Buffer instance, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isDefined.html b/functions/_zk_kit_utils.typeChecks.isDefined.html new file mode 100644 index 000000000..df7fbc040 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isDefined.html @@ -0,0 +1,3 @@ +isDefined | ZK-kit
  • Returns true if the value is defined, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isFunction.html b/functions/_zk_kit_utils.typeChecks.isFunction.html new file mode 100644 index 000000000..afe293d95 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isFunction.html @@ -0,0 +1,3 @@ +isFunction | ZK-kit
  • Returns true if the value is a function, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isHexadecimal.html b/functions/_zk_kit_utils.typeChecks.isHexadecimal.html new file mode 100644 index 000000000..b97d0ea59 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isHexadecimal.html @@ -0,0 +1,7 @@ +isHexadecimal | ZK-kit
  • Checks if a string is a valid hexadecimal string representation. +If 'prefix' is 'true', the string must start with '0x' or '0X' followed by one or more +hexadecimal digits (0-9, a-f, A-F), otherwise no prefix is expected. 'prefix' is optional and +if its value it is not explicitly defined it will be set to 'true' by default.

    +

    Parameters

    • value: any

      The string to be tested.

      +
    • prefix: boolean = true

      A boolean to include or not a '0x' or '0X' prefix.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isNumber.html b/functions/_zk_kit_utils.typeChecks.isNumber.html new file mode 100644 index 000000000..40e75a4ed --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isNumber.html @@ -0,0 +1,3 @@ +isNumber | ZK-kit
  • Returns true if the value is a number, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isObject.html b/functions/_zk_kit_utils.typeChecks.isObject.html new file mode 100644 index 000000000..9dd760f41 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isObject.html @@ -0,0 +1,4 @@ +isObject | ZK-kit
  • Returns true if the value is an object, false otherwise. +Please, note that arrays are also objects in JavaScript.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isString.html b/functions/_zk_kit_utils.typeChecks.isString.html new file mode 100644 index 000000000..6f35233a2 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isString.html @@ -0,0 +1,3 @@ +isString | ZK-kit
  • Returns true if the value is a string, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isStringifiedBigInt.html b/functions/_zk_kit_utils.typeChecks.isStringifiedBigInt.html new file mode 100644 index 000000000..8fdb8c048 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isStringifiedBigInt.html @@ -0,0 +1,3 @@ +isStringifiedBigInt | ZK-kit
  • Checks if the given value is a string that represents a valid bigint.

    +

    Parameters

    • value: any

      The value to be checked if it's a stringified bigint.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isSupportedType.html b/functions/_zk_kit_utils.typeChecks.isSupportedType.html new file mode 100644 index 000000000..0a9ee9ed9 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isSupportedType.html @@ -0,0 +1,4 @@ +isSupportedType | ZK-kit
  • Returns true if the type is being supported by this utility +functions, false otherwise.

    +

    Parameters

    • type: string

      The type to be checked.

      +

    Returns type is "string" | "number" | "bigint" | "object" | "function" | "Array" | "Uint8Array" | "Buffer" | "stringified-bigint" | "hexadecimal" | "bignumber" | "bignumberish"

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isType.html b/functions/_zk_kit_utils.typeChecks.isType.html new file mode 100644 index 000000000..a860a8b10 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isType.html @@ -0,0 +1,4 @@ +isType | ZK-kit
  • Returns true if the value type is the same as the type passed +as the second parameter, false otherwise.

    +

    Parameters

    • value: any
    • type: "string" | "number" | "bigint" | "object" | "function" | "Array" | "Uint8Array" | "Buffer" | "stringified-bigint" | "hexadecimal" | "bignumber" | "bignumberish"

      The expected type.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/functions/_zk_kit_utils.typeChecks.isUint8Array.html b/functions/_zk_kit_utils.typeChecks.isUint8Array.html new file mode 100644 index 000000000..de73bdb73 --- /dev/null +++ b/functions/_zk_kit_utils.typeChecks.isUint8Array.html @@ -0,0 +1,3 @@ +isUint8Array | ZK-kit
  • Returns true if the value is a Uint8Array instance, false otherwise.

    +

    Parameters

    • value: any

      The value to be checked.

      +

    Returns boolean

Generated using TypeDoc

\ No newline at end of file diff --git a/hierarchy.html b/hierarchy.html new file mode 100644 index 000000000..b5cd32d48 --- /dev/null +++ b/hierarchy.html @@ -0,0 +1 @@ +ZK-kit

ZK-kit

Class Hierarchy

Generated using TypeDoc

\ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 000000000..c9959eb9e --- /dev/null +++ b/index.html @@ -0,0 +1,410 @@ +ZK-kit

ZK-kit

+

+ 🧰 ZK-kit +

+

A monorepo of reusable libraries for zero-knowledge technologies.

+

+ +

+ + + + + Github license + + + GitHub Workflow test + + + Coveralls + + + Linter eslint + + + Code style prettier + + + Commitizen friendly + +

+ + + + + + + + + +
ZK-kit is a set of libraries (plugins, algorithms or utility functions) that can be reused in different projects and zero-knowledge protocols, making it easier for developers to access user-friendly, tested, and documented libraries for common tasks.
+

Yarn workspaces: minimal monorepo package management (yarn, yarn build, yarn docs)
Conventional Commits: human and machine readable meaning to commit messages (yarn commit)
Jest: tests and test coverage for all libraries (yarn test:libraries)
Mocha: tests for circuits and contracts (yarn test:circuits, yarn test:contracts)
ESLint, Prettier: code quality and formatting (yarn prettier & yarn lint)
Typedocs: documentation generator for TypeScript (yarn docs)
Benny: simple benchmarking framework for JavaScript/TypeScript (yarn benchmarks)
Github actions: software workflows for automatic testing, documentation deploy and code quality checks

+

📦 Packages

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
PackageVersionDownloadsSize
+ + @zk-kit/circuits + + + + + NPM version + + + + + Downloads + +
+ + @zk-kit/eddsa-poseidon + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/poseidon-cipher + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/baby-jubjub + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/utils + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/imt + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/imt.sol + + + + + NPM version + + + + + Downloads + +
+ + @zk-kit/smt + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/poseidon-proof + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/eddsa-proof + + + (docs) + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ + @zk-kit/rollup-plugin-rust + + + + + NPM version + + + + + Downloads + + + + + npm bundle size (scoped) + +
+ +

👥 Ways to contribute

+

🛠 Install

Clone this repository:

+
git clone https://github.com/privacy-scaling-explorations/zk-kit.git
+
+

and install the dependencies:

+
cd zk-kit && yarn
+
+

📜 Usage

Code quality and formatting

Run ESLint to analyze the code and catch bugs:

+
yarn lint
+
+

Run Prettier to check formatting rules:

+
yarn prettier
+
+

or to automatically format the code:

+
yarn prettier:write
+
+

Conventional commits

Semaphore uses conventional commits. A command line utility to commit using the correct syntax can be used by running:

+
yarn commit
+
+

It will also automatically check that the modified files comply with ESLint and Prettier rules.

+

Testing

Test the code:

+
yarn test
+
+

Build

Build all the packages and compile contracts:

+
yarn build
+
+

A dist folder will be created inside each JavaScript package.

+

Documentation

Generate a documentation website for each package:

+
yarn docs
+
+

The output will be placed on the docs folder.

+

Releases

Bump a new version for your package with:

+
yarn version:bump <package-name> <version>
# e.g. yarn version:bump utils 2.0.0 +
+

It will create a commit and a git tag that you'll need to push on the main branch. A workflow will be triggered and will +publish your package on npm and release a new version on Github with its changelogs automatically.

+

❓ FAQ

I have a library that could be reused in other projects. How can I integrate it on ZK-kit?

ZK-kit provides a set of pre-configured development tools. All you have to deal with is your own code, testing and documentation. To create a package follow these steps:

+
    +
  1. Fork this repository and clone it (or simply clone it directly if you are a collaborator),
  2. +
  3. Copy one of our current libraries and update the README.md and package.json files with your package name:
  4. +
+
cd zk-kit
cp -r packages/smt packages/my-package
cd packages/my-package && rm -fr node_modules dist
grep -r -l "smt" . | xargs sed -i 's/smt/my-package/'
# Update the remaining description/usage sections, and write your code in the src & tests folders! +
+
    +
  1. Create an issue for your package and open a PR.
  2. +
+

How can I create benchmarks for my library?

You can see some examples in the benchmarks folder. All you have to do is create a file that exports a function to run your benchmark in that folder, and add that function to the index.ts file. The yarn benchmarks command can be run with no parameters (it will run all the benchmarks), or you can specify the name of your benchmark file to run just that. When you run the command it will create a benchmarks/results folder with your results.

+

Generated using TypeDoc

\ No newline at end of file diff --git a/interfaces/_zk_kit_groth16.CircuitSignals.html b/interfaces/_zk_kit_groth16.CircuitSignals.html new file mode 100644 index 000000000..26dcc478d --- /dev/null +++ b/interfaces/_zk_kit_groth16.CircuitSignals.html @@ -0,0 +1 @@ +CircuitSignals | ZK-kit

Interface CircuitSignals

interface CircuitSignals {
    [signal: string]: SignalValueType;
}

Indexable

[signal: string]: SignalValueType

Generated using TypeDoc

\ No newline at end of file diff --git a/interfaces/_zk_kit_groth16.Groth16Proof.html b/interfaces/_zk_kit_groth16.Groth16Proof.html new file mode 100644 index 000000000..645cf6f09 --- /dev/null +++ b/interfaces/_zk_kit_groth16.Groth16Proof.html @@ -0,0 +1,6 @@ +Groth16Proof | ZK-kit

Interface Groth16Proof

interface Groth16Proof {
    curve: string;
    pi_a: string[];
    pi_b: string[][];
    pi_c: string[];
    protocol: string;
}

Properties

Properties

curve: string
pi_a: string[]
pi_b: string[][]
pi_c: string[]
protocol: string

Generated using TypeDoc

\ No newline at end of file diff --git a/interfaces/_zk_kit_smt.EntryResponse.html b/interfaces/_zk_kit_smt.EntryResponse.html new file mode 100644 index 000000000..ef5707e06 --- /dev/null +++ b/interfaces/_zk_kit_smt.EntryResponse.html @@ -0,0 +1,4 @@ +EntryResponse | ZK-kit

Interface EntryResponse

interface EntryResponse {
    entry: Entry | Node[];
    matchingEntry?: Entry | Node[];
    siblings: Siblings;
}

Hierarchy (view full)

Properties

entry: Entry | Node[]
matchingEntry?: Entry | Node[]
siblings: Siblings

Generated using TypeDoc

\ No newline at end of file diff --git a/interfaces/_zk_kit_smt.MerkleProof.html b/interfaces/_zk_kit_smt.MerkleProof.html new file mode 100644 index 000000000..59cd143e0 --- /dev/null +++ b/interfaces/_zk_kit_smt.MerkleProof.html @@ -0,0 +1,6 @@ +MerkleProof | ZK-kit

Interface MerkleProof

interface MerkleProof {
    entry: Entry | Node[];
    matchingEntry?: Entry | Node[];
    membership: boolean;
    root: Node;
    siblings: Siblings;
}

Hierarchy (view full)

Properties

entry: Entry | Node[]
matchingEntry?: Entry | Node[]
membership: boolean
root: Node
siblings: Siblings

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_baby_jubjub.html b/modules/_zk_kit_baby_jubjub.html new file mode 100644 index 000000000..6d588ddd9 --- /dev/null +++ b/modules/_zk_kit_baby_jubjub.html @@ -0,0 +1,78 @@ +@zk-kit/baby-jubjub | ZK-kit

Module @zk-kit/baby-jubjub

+

+ Baby Jubjub +

+

A JavaScript library for adding points to the Baby Jubjub curve.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +
+

[!WARNING]
This library has not been audited.

+
+

BabyJubJub is an elliptic curve optimized for secure, efficient cryptographic operations in constrained environments like blockchain and zero-knowledge proofs. It's designed for fast, privacy-preserving transactions, balancing cryptographic strength with performance, making it ideal for modern cryptographic solutions.

+

References

    +
  1. Barry WhiteHat, Marta Bellés, Jordi Baylina. ERC-2494: Baby Jubjub Elliptic Curve. 2020-01-29. https://eips.ethereum.org/EIPS/eip-2494.
  2. +
  3. Barry WhiteHat, Marta Bellés, Jordi Baylina. Baby Jubjub Elliptic Curve. https://docs.iden3.io/publications/pdfs/Baby-Jubjub.pdf
  4. +
+
+

🛠 Install

npm or yarn

Install the @zk-kit/baby-jubjub package and its peer dependencies with npm:

+
npm i @zk-kit/baby-jubjub
+
+

or yarn:

+
yarn add @zk-kit/baby-jubjub
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/baby-jubjub"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/baby-jubjub"></script>
+
+

📜 Usage

import { packPoint, unpackPoint, Base8, mulPointEscalar, Point, addPoint } from "@zk-kit/baby-jubjub"

// Define two points on the BabyJubJub curve.
const p1: Point<bigint> = [BigInt(0), BigInt(1)] // Point at infinity (neutral element).
const p2: Point<bigint> = [BigInt(1), BigInt(0)] // Example point.

// Add the two points on the curve.
const p3 = addPoint(p1, p2)

// Add the result with Base8, another point on the curve, to get a new point.
const secretScalar = addPoint(Base8, p3)

// Multiply the base point by the x-coordinate of the secret scalar to get the public key.
const publicKey = mulPointEscalar(Base8, secretScalar[0])

// Pack the public key into a compressed format.
const packedPoint = packPoint(publicKey)

// Unpack the compressed public key back into its original form.
const unpackedPoint = unpackPoint(packedPoint)

if (unpackedPoint) {
console.log(publicKey[0] === unpackedPoint[0]) // true, checks if x-coordinates match
console.log(publicKey[1] === unpackedPoint[1]) // true, checks if y-coordinates match
} +
+

Index

Type Aliases

Variables

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_circuits.html b/modules/_zk_kit_circuits.html new file mode 100644 index 000000000..0ffb217df --- /dev/null +++ b/modules/_zk_kit_circuits.html @@ -0,0 +1,72 @@ +@zk-kit/circuits | ZK-kit

Module @zk-kit/circuits

+

+ ZK-kit circuits +

+

A comprehensive library of general-purpose zero-knowledge circuits.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + +

+ + + + + + + + + +
This package offers a collection of reusable circuits designed for integration into other projects or protocols, promoting code modularization within the zero-knowledge ecosystem.
+
+

[!IMPORTANT]
Installation of Circom and Nargo required for circuit tests.

+
+

Circuits

    +
  • Circom:
      +
    • PoseidonProof: proves the possession of Poseidon pre-images without revealing the pre-images themselves.
    • +
    • BinaryMerkleRoot: calculates the root of a binary Merkle tree using a provided proof-of-membership.
    • +
    • EddsaProof: proves the possession of a private key of an identity commitment without revealing the private key itself.
    • +
    • PoseidonDecrypt: decrypts a ciphertext using Poseidon hash function, considering an initial nonce and a key, and adjusts output length to a multiple of 3.
    • +
    • PoseidonDecryptWithoutCheck: decrypts a ciphertext using the Poseidon hash without validating the last ciphertext element or ensuring the last elements equal 0.
    • +
    • PoseidonDecryptIterations: decrypts a ciphertext in iterations, adjusting for a 3-element block size and validating nonce size, while revealing intermediate decryption states.
    • +
    • PoseidonPerm: performs Poseidon permutation on a given number of inputs, revealing all intermediate values and using specified rounds and constants for the operation.
    • +
    +
  • +
  • Noir:
      +
    • Sparse Merkle Tree PoseidonBN254: A reusable library of functions related to Sparse Merkle Trees based on the JS implementation of @zk-kit/smt. The library uses the Poseidon hash to implement the following functions:
        +
      • verifying membership and non-membership proofs
      • +
      • adding a new entry to a SMT
      • +
      • updating an entry of an SMT
      • +
      • deleting an existing entry from an SMT
      • +
      +
    • +
    +
  • +
+

🛠 Install

Using NPM or Yarn (Circom circuits)

Install the @zk-kit/circuits package with npm:

+
npm i @zk-kit/circuits --save
+
+

or yarn:

+
yarn add @zk-kit/circuits
+
+

Using Nargo (Noir circuits)

In your Nargo.toml file, add the following dependency:

+
[dependencies]
smt_bn254 = { tag = "v0.1.0", git = "https://github.com/privacy-scaling-explorations/zk-kit/packages/circuits/noir", directory="crates/smt_bn254" } +
+

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_eddsa_poseidon.html b/modules/_zk_kit_eddsa_poseidon.html new file mode 100644 index 000000000..ee021b55e --- /dev/null +++ b/modules/_zk_kit_eddsa_poseidon.html @@ -0,0 +1,88 @@ +@zk-kit/eddsa-poseidon | ZK-kit

Module @zk-kit/eddsa-poseidon

+

+ EdDSA Poseidon +

+

A JavaScript EdDSA library for secure signing and verification using Poseidon and the Baby Jubjub elliptic curve.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + + + + + + + +
This package offers a simplified JavaScript codebase essential for creating and validating digital signatures using EdDSA and Poseidon. It's built upon the Baby Jubjub elliptic curve, ensuring seamless integration with Circom and enhancing the developer experience.
+
+

[!WARNING]
This library has not been audited.

+
+
    +
  • Super lightweight: ~33kB (minified)
  • +
  • Compatible with browsers and NodeJS
  • +
  • TS type support
  • +
  • Comprehensive code documentation
  • +
  • Full test coverage
  • +
+

👾 Would you like to try it now? Explore it now on Ceditor!

+

References

    +
  1. Barry WhiteHat, Marta Bellés, Jordi Baylina. ERC-2494: Baby Jubjub Elliptic Curve. 2020-01-29. https://eips.ethereum.org/EIPS/eip-2494.
  2. +
  3. Lorenzo Grassi, Dmitry Khovratovich, Christian Rechberger, Arnab Roy, and Markus Schofnegger. POSEIDON: A New Hash Function for Zero-Knowledge Proof Systems. 2019. https://eprint.iacr.org/2019/458.pdf.
  4. +
+

🛠 Install

npm or yarn

Install the @zk-kit/eddsa-poseidon package and its peer dependencies with npm:

+
npm i @zk-kit/eddsa-poseidon
+
+

or yarn:

+
yarn add @zk-kit/eddsa-poseidon
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/eddsa-poseidon"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/eddsa-poseidon"></script>
+
+

📜 Usage

import {
derivePublicKey,
signMessage,
verifySignature,
deriveSecretScalar,
packPublicKey,
unpackPublicKey
} from "@zk-kit/eddsa-poseidon"

// Your private key (secret).
const privateKey = "secret"
// The message you want to sign.
const message = "message"

// Derive a public key from the private key.
const publicKey = derivePublicKey(privateKey)

/*
[
'17191193026255111087474416516591393721975640005415762645730433950079177536248',
'13751717961795090314625781035919035073474308127816403910435238282697898234143'
]
*/
console.log(publicKey)

// Sign the message.
const signature = signMessage(privateKey, message)

/*
{
R8: [
'12949573675545142400102669657964360005184873166024880859462384824349649539693',
'18253636630408169174294927826710424418689461166073329946402765380454102840608'
],
S: '701803947557694254685424075312408605924670918868054593580245088593184746870'
}
*/
console.log(signature)

const response = verifySignature(message, signature, publicKey)

// true.
console.log(response)

// Use this value as the input for your Circom circuit.
const secretScalar = deriveSecretScalar(privateKey)

/*
6544992227624943856419766050818315045047569225455760139072025985369615672473
14277921624107172450683599157880963081763136590946434672207840996093731170206
*/
console.log(secretScalar)

// Pack the public key into a compressed format.
const packedPublicKey = packPublicKey(publicKey)

// 52359937820999550851358128406546520360380553803646081112576207882956925379784n
console.log(packedPublicKey)

// Unpack the compressed public key back into its original form.
const unpackedPublicKey = unpackPublicKey(packedPublicKey)

/*
[
'17191193026255111087474416516591393721975640005415762645730433950079177536248',
'13751717961795090314625781035919035073474308127816403910435238282697898234143'
]
*/
console.log(unpackedPublicKey)

if (unpackedPublicKey) {
console.log(publicKey[0] === unpackedPublicKey[0]) // true
console.log(publicKey[1] === unpackedPublicKey[1]) // true
} +
+

Index

Classes

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_eddsa_proof.html b/modules/_zk_kit_eddsa_proof.html new file mode 100644 index 000000000..553d17f9a --- /dev/null +++ b/modules/_zk_kit_eddsa_proof.html @@ -0,0 +1,88 @@ +@zk-kit/eddsa-proof | ZK-kit

Module @zk-kit/eddsa-proof

+

+ Eddsa proof +

+

A library to generate and verify EdDSA proofs.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + + + + + + + +
This zero-knowledge library allows you to prove and verify that you have the private key of a Semaphore identity. It will be mainly used on-chain because you can get the same result off-chain using EdDSA signatures with the @semaphore-protocol/identity package. It facilitates the demonstration of having an EdDSA hash pre-image while keeping the pre-image value confidential. Additionally, it offers a mechanism to prevent the same proof from being reused. The circuit that forms the foundation of this library is accessible via this link.
+

The Snark artifacts (.wasm and .zkey files) can be specified or not in the generate function parameters and can possibly be downloaded using the following URLs:

+ +
+

[!WARNING]
The Snark artifacts currently used to generate zero-knowledge proofs are the result of an insecure trusted setup, and the library has not yet been audited. Therefore, it is advised not to use it in production.

+
+

🛠 Install

npm or yarn

Install the @zk-kit/eddsa-proof package:

+
npm i @zk-kit/eddsa-proof
+
+

or yarn:

+
yarn add @zk-kit/eddsa-proof
+
+

📜 Usage

import { generate, verify } from "@zk-kit/eddsa-proof"

// Your private key (secret) associated with your commitment.
const privateKey = 1
// A public value used to contextualize the cryptographic proof and calculate the nullifier.
const scope = 2

// Generate the proof.
const fullProof = await generate(privateKey, scope)

/*
nb. commitment and scope are always the same - proof is variable.
{
commitment: '5049599877119858813001062015237093339640938925333103011635461484168047396248',
scope: '2',
proof: [
'8187226249860430947135181878676566080058748127595453962723730464659559265736',
'8666342086907686904498490524943571067960174826127841344605359274053291451578',
'16951173581335355551706227874569504050650723200983520067525262527574411463239',
'5330430283785726456850074841877892816784859299864106837646103067998557420540',
'4275240916243995687770977511669101428890222781102049409716491642577511403456',
'5254784175927576727963123852365247945765593646193022684829294352292688366957',
'1691932310118878640744410451232696949890002258184298580387126997072583471834',
'18016798021948724211946223868702828962374378289486618942397810491195719212700'
]
}
*/
console.log(fullProof)

// If not specified, the Snark artifacts are downloaded automatically.
// You can specify them as follows.

// const fullProof = await generate(privateKey, scope, {
// wasmFilePath: "<your-path>/eddsa-proof.wasm",
// zkeyFilePath: "<your-path>/eddsa-proof.zkey"
// })

// Verify the proof.
const response = await verify(fullProof)

// true.
console.log(response) +
+

📈 Benchmarks

Benchmarks were run on a MacBook Pro, Apple M2 Pro, 16 GB RAM machine, after initializing the BN128 curve with @zk-kit/groth16-buildBn128 (~230ms).

+ + + + + + + + + + + + + +
Generate proofVerify proofConstraints
528.91 ms10. 997ms1017
+
import { generate, verify } from "@zk-kit/eddsa-proof"
import { buildBn128 } from "@zk-kit/groth16"

await buildBn128()

console.time("generate")

const proof = await generate(1, 2)

console.timeEnd("generate")

console.time("verify")

console.log(await verify(proof))

console.timeEnd("verify") +
+

Index

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_groth16.html b/modules/_zk_kit_groth16.html new file mode 100644 index 000000000..b2679f9a7 --- /dev/null +++ b/modules/_zk_kit_groth16.html @@ -0,0 +1,85 @@ +@zk-kit/groth16 | ZK-kit

Module @zk-kit/groth16

+

+ SnarkJS Groth16 +

+

A snippet of SnarkJS code for verifying and generating Groth16 proofs only.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +
+

[!WARNING]
This package is no longer maintained as SnarkJS has integrated most of the above optimizations. Please, consider installing it instead.

+
+ + + + + + +
This package contains SnarkJS functions for generating and verifying zero knowledge proofs with Groth16 specifically. In addition to the original code it also uses the cached bn128 curve if it already exists, making verification and generation of consecutive proofs faster.
+

Some advantages of using this package instead of snarkjs directly are:

+
    +
  • It only includes code to verify and generate Groth16 proofs, making your final bundle lighter.
  • +
  • It doesn't call the ffjavascript buildBn128 function if a bn128 cached curve already exists, making verification and generation of consecutive proofs much faster (e.g. verification seems to be ~9 times faster after the first one).
  • +
  • It includes TS types.
  • +
  • It provides an ESM bundle that is compatible with browsers. So there is no need to add any polyfill or additional configuration.
  • +
+

References

    +
  1. Jens Groth. On the Size of Pairing-Based Non-interactive Arguments. 2016-04-28. https://link.springer.com/chapter/10.1007/978-3-662-49896-5_11.
  2. +
+
+

🛠 Install

npm or yarn

Install the @zk-kit/groth16 package and its peer dependencies with npm:

+
npm i @zk-kit/groth16
+
+

or yarn:

+
yarn add @zk-kit/groth16
+
+

📜 Usage

+

[!WARNING]
You will need to provide your own circuits here in your specified path. Remember to define your circuit input and rename the files accordingly.

+
+
import { prove, verify, buildBn128 } from "@zk-kit/groth16"

// Build the BN128 curve for Groth16.
// https://github.com/iden3/ffjavascript/blob/master/src/wasm_field1.js
await buildBn128() // WasmField1

// Define your circuit input.
// const input = {
// input1: 1,
// input2: 2,
// inputN: "N"
// }

// Compute the proof.
const proof = await prove(input, "<YOUR-PATH>/circuit.zkey", "<YOUR-PATH>/circuit.wasm")

/*
{
proof: {
pi_a: [
'8259885706934172848141475422209230656096448508815982888010519325096632035723',
'3142099172052192611205205328157407975469005554072266974009053708782134081166',
'1'
],
pi_b: [ [Array], [Array], [Array] ],
pi_c: [
'13863804425308906943736719856399634046638544298517159271373916818387594277305',
'21340646707244019956779928177502771923632450548108204371058275686712196195969',
'1'
],
protocol: 'groth16',
curve: 'bn128'
},
publicSignals: [
'527758365153958423212195330785598453331596731388181860789801455413116800554',
'19104626566001952573667666924569656871967113105870778077087237826253896482830',
'122'
]
}
*/
console.log(proof)

// Verify the proof.
const response = await verify("<YOUR-PATH>/circuit_verification_key.json", proof)

// true or false.
console.log(response) +
+

Index

Interfaces

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_imt.html b/modules/_zk_kit_imt.html new file mode 100644 index 000000000..7904ab651 --- /dev/null +++ b/modules/_zk_kit_imt.html @@ -0,0 +1,74 @@ +@zk-kit/imt | ZK-kit

Module @zk-kit/imt

+

+ Incremental Merkle Trees +

+

Incremental Merkle tree implementations in TypeScript.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +

An Incremental Merkle Tree is a dynamic data structure optimized for verifying data integrity in growing datasets. The updates are efficient since they modify only relevant nodes, avoiding the need to rebuild the entire tree with each change. This makes it ideal for real-time data verification contexts. You can learn more about the differences between MT and IMT here.

+
+

[!WARNING]
If you are looking for the first version of this package, please visit this link.

+
+
+

🛠 Install

npm or yarn

Install the @zk-kit/imt package with npm:

+
npm i @zk-kit/imt --save
+
+

or yarn:

+
yarn add @zk-kit/imt
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/imt"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/imt"></script>
+
+

📜 Usage

IMT

In this implementation, the tree is built with a predetermined depth, utilizing a list of zeros (one for each level) to hash nodes lacking fully defined children. The tree's branching factor, or the number of children per node, can be customized via the arity parameter. For detailed insights into the implementation specifics, please refer to the technical documentation.

+
import { IMT } from "@zk-kit/imt"
import { poseidon2 } from "poseidon-lite"

/**
* depth: number of nodes from the leaf to the tree's root node.
* zeroValue: default zero, can vary based on the specific use-case.
* arity: number of children per node (2 = Binary IMT, 5 = Quinary IMT).
*/

const depth = 16
const zeroValue = 0
const arity = 2

/**
* To create an instance of an IMT, you need to provide the hash function
* used to compute the tree nodes, as well as the depth, zeroValue, and arity of the tree.
*/
const tree = new IMT(poseidon2, depth, zeroValue, arity)

// You can also initialize a tree with a given list of leaves.
// const leaves = [1, 2, 3]
// new IMT(poseidon2, depth, zeroValue, arity, leaves)

// Insert (incrementally) a leaf with a value of 1.
tree.insert(1)

// Insert (incrementally) a leaf with a value of 3.
tree.insert(3)

// 6176938709541216276071057251289703345736952331798983957780950682673395007393n.
console.log(tree.root)
/*
[
0,
14744269619966411208579211824598458697587494354926760081771325075741142829156n,
7423237065226347324353380772367382631490014989348495481811164164159255474657n,
11286972368698509976183087595462810875513684078608517520839298933882497716792n,
3607627140608796879659380071776844901612302623152076817094415224584923813162n,
19712377064642672829441595136074946683621277828620209496774504837737984048981n,
20775607673010627194014556968476266066927294572720319469184847051418138353016n,
3396914609616007258851405644437304192397291162432396347162513310381425243293n,
21551820661461729022865262380882070649935529853313286572328683688269863701601n,
6573136701248752079028194407151022595060682063033565181951145966236778420039n,
12413880268183407374852357075976609371175688755676981206018884971008854919922n,
14271763308400718165336499097156975241954733520325982997864342600795471836726n,
20066985985293572387227381049700832219069292839614107140851619262827735677018n,
9394776414966240069580838672673694685292165040808226440647796406499139370960n,
11331146992410411304059858900317123658895005918277453009197229807340014528524n,
15819538789928229930262697811477882737253464456578333862691129291651619515538n
]
*/
console.log(tree.zeroes)
// 2
console.log(tree.arity)
// 16
console.log(tree.depth)
// [1, 3]
console.log(tree.leaves)

// Get the index of the leaf with value 3.
const idx = tree.indexOf(3)
// 1
console.log(idx)

// Update the value of the leaf at position 1 to 2.
tree.update(1, 2)
// [1, 2]
console.log(tree.leaves)

// Delete leaf at position 1.
tree.delete(1)
// [1, 0]
console.log(tree.leaves)

/**
* Compute a Merkle Inclusion Proof (proof of membership) for the leaf with index 1.
* The proof is only valid if the value 1 is found in a leaf of the tree.
*/
const proof = tree.createProof(1)
// true
console.log(tree.verifyProof(proof)) +
+

Lean IMT

The LeanIMT is an optimized binary version of the IMT into binary-focused model, eliminating the need for zero values and allowing dynamic depth adjustment. Unlike the IMT, which uses a zero hash for incomplete nodes, the LeanIMT directly adopts the left child's value when a node lacks a right counterpart. The tree's depth dynamically adjusts to the count of leaves, enhancing efficiency by reducing the number of required hash calculations. For detailed insights into the implementation specifics, please refer to the technical documentation.

+
import { LeanIMT } from "@zk-kit/imt"
import { poseidon2 } from "poseidon-lite"

/**
* Hash function used to compute the tree nodes.
*/
const hash = (a, b) => poseidon2([a, b])

// To create an instance of a LeanIMT, you must provide the hash function.
const tree = new LeanIMT(hash)

// You can also initialize a tree with a given list of leaves.
// const leaves = [1n, 2n, 3n]
// new LeanIMT(hash, leaves)

// LeanIMT is strictly typed. Default type for nodes is 'bigint',
// but you can set your own type.
// new LeanIMT<number>((a, b) => a + b)

// Insert (incrementally) a leaf with a value of 1.
tree.insert(1n)
// [1n]
console.log(tree.leaves)

// Insert (incrementally) a leaf with a value of 3.
tree.insert(3n)

// 21106761926285267690763443010820487107972411248208546226053195422384279971821n
console.log(tree.root)
// 1
console.log(tree.depth)
// 2
console.log(tree.size)
// [1n, 3n]
console.log(tree.leaves)

// Get the index of the leaf with value 3n.
const idx = tree.indexOf(3n)
// 1
console.log(idx)

// Check if the tree contains a leaf with value 4n.
const has = tree.has(4n)
// false
console.log(tree.has(4n))

// Update the value of the leaf at position 1 to 2n.
tree.update(1, 2n)
// [1n, 2n]
console.log(tree.leaves)

/**
* If you want to delete a leaf with LeanIMT you can use the update function with an
* arbitrary value to be used for the removed leaves.
*/

// Update the value of the leaf at position 1 to 0n (deletion).
tree.update(1, 0n)
// [1n, 0n]
console.log(tree.leaves)

/**
* Compute a Merkle Inclusion Proof (proof of membership) for the leaf with index 1.
* The proof is only valid if the value 1 is found in a leaf of the tree.
*/
const proof = tree.generateProof(1)
// true
console.log(tree.verifyProof(proof)) +
+

Index

Classes

Type Aliases

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_lazytower.html b/modules/_zk_kit_lazytower.html new file mode 100644 index 000000000..45fe7060a --- /dev/null +++ b/modules/_zk_kit_lazytower.html @@ -0,0 +1,67 @@ +@zk-kit/lazytower | ZK-kit

Module @zk-kit/lazytower

+

+ LazyTower +

+

LazyTower implementation in TypeScript.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +
+

❗ WARNING

This library has not been audited.

+

🛠 Install

npm or yarn

Install the @zk-kit/lazytower package with npm:

+
npm i @zk-kit/lazytower --save
+
+

or yarn:

+
yarn add @zk-kit/lazytower
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/lazytower/"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/lazytower/"></script>
+
+

📜 Usage

import { LazyTowerHashChainProofBuilder } from "@zk-kit/lazytower"
import { poseidon } from "circomlibjs" // v0.0.8

const H = 10
const W = 4
const pb = LazyTowerHashChainProofBuilder(H, W, poseidon)
for (let i = BigInt(0); i < 150; i += BigInt(1)) {
pb.add(i)
}
const index = pb.indexOf(BigInt(42))
const proof = pb.build(index)
console.log(proof) +
+

Contacts

Developers

+

Index

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_poseidon_cipher.html b/modules/_zk_kit_poseidon_cipher.html new file mode 100644 index 000000000..7bf06fd3f --- /dev/null +++ b/modules/_zk_kit_poseidon_cipher.html @@ -0,0 +1,80 @@ +@zk-kit/poseidon-cipher | ZK-kit

Module @zk-kit/poseidon-cipher

+

+ Poseidon Cipher +

+

Poseidon Hash function Encryption and Decryption implementation in TypeScript.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +

This package implements encryption and decryption using the Poseidon hash function. This is a rewrite of the original implementation.

+

References

    +
  1. Dmitry Khovratovich. Encryption with Poseidon. 2019-12-26. https://drive.google.com/file/d/1EVrP3DzoGbmzkRmYnyEDcIQcXVU7GlOd/view.
  2. +
+
+

🛠 Install

npm or yarn

You can install @zk-kit/poseidon-cipher package with npm:

+
npm i @zk-kit/poseidon-cipher --save
+
+

or yarn:

+
yarn add @zk-kit/poseidon-cipher
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/poseidon-cipher"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/poseidon-cipher"></script>
+
+

📜 Usage

import { poseidonEncrypt, poseidonDecrypt, poseidonDecryptWithoutCheck } from "@zk-kit/poseidon-cipher"

// BabyJubJub random value used as private key.
const privateKey = BigInt("10108149867830299554549347844489388280570828384194562713227904027271736843407")

console.log(privateKey)

// The BabyJubJub public key derived from the private key.
const publicKey = [
BigInt("15100511232447817691325643662379962541629809665246870882117771367990737816375"),
BigInt("16289853525630400225782441139722681929418024277641315637394850958390724375621")
]
/**
[
15100511232447817691325643662379962541629809665246870882117771367990737816375n,
16289853525630400225782441139722681929418024277641315637394850958390724375621n
]
*/
console.log(publicKey)

/**
* The Elliptic-Curve Diffie–Hellman (ECDH) shared key from the private and public key.
* Learn more at https://en.wikipedia.org/wiki/Elliptic-curve_Diffie%E2%80%93Hellman.
*/
const encryptionKey = [
BigInt("18215233274609902892566361706948385597370728108990013889912246034099844508236"),
BigInt("14884395706232754242497822954958766875005771827082919466711779658153477561231")
]
/**
[
18215233274609902892566361706948385597370728108990013889912246034099844508236n,
14884395706232754242497822954958766875005771827082919466711779658153477561231n
]
*/
console.log(encryptionKey)

// The plaintext to be encrypted.
const plainText = [BigInt(0), BigInt(1)]
// The unique random value.
const nonce = BigInt(5)

// Compute the encryption.
const encrypted = poseidonEncrypt(plainText, encryptionKey, nonce)
/*
[
13027563531333274777964504528445510545245985419061604793949748860800093661040n,
21542829407417339379457427303368865281142518080970543920113508599380643597111n,
334052772696549592017166610161467257195783602071397160212931200489386609812n,
9075054520224362422769554641603717496449971372103870041485347221024944155182n
]
*/
console.log(encrypted)

// Compute the decryption.
const decrypted = poseidonDecrypt(encrypted, encryptionKey, nonce, plainText.length)
/*
[
0n,
1n
]
*/
console.log(decrypted)

// Compute the decryption without check.
const decryptedWithoutCheck = poseidonDecryptWithoutCheck(encrypted, encryptionKey, nonce, plainText.length)
/*
[
0n,
1n
]
*/
console.log(decryptedWithoutCheck) +
+

Index

Type Aliases

Variables

C +M +

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_poseidon_proof.html b/modules/_zk_kit_poseidon_proof.html new file mode 100644 index 000000000..8f183466f --- /dev/null +++ b/modules/_zk_kit_poseidon_proof.html @@ -0,0 +1,93 @@ +@zk-kit/poseidon-proof | ZK-kit

Module @zk-kit/poseidon-proof

+

+ Poseidon proof +

+

A library to generate and verify Poseidon proofs.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + + + + + + + +
This zero-knowledge library facilitates the demonstration of having a Poseidon hash pre-image while keeping the pre-image value confidential. Additionally, it offers a mechanism to prevent the same proof from being reused. The circuit that forms the foundation of this library is accessible via this link.
+

Originally developed for integration with Semaphore V4, this library also functions effectively as a standalone tool. Notable use cases in connection with Semaphore can be:

+
    +
  • allowing a Semaphore user to prove that they possess the secret value associated with the identity commitment of their Semaphore identity,
  • +
  • unmasking the identity of zero-knowledge proofs earlier created using Semaphore.
  • +
+

The Snark artifacts (.wasm and .zkey files) can be specified or not in the generate function parameters and can possibly be downloaded using the following URLs:

+ +
+

[!WARNING]
The Snark artifacts currently used to generate zero-knowledge proofs are the result of an insecure trusted setup, and the library has not yet been audited. Therefore, it is advised not to use it in production.

+
+

🛠 Install

npm or yarn

Install the @zk-kit/poseidon-proof package:

+
npm i @zk-kit/poseidon-proof
+
+

or yarn:

+
yarn add @zk-kit/poseidon-proof
+
+

📜 Usage

import { generate, verify } from "@zk-kit/poseidon-proof"

// A public value used to contextualize the cryptographic proof and calculate the nullifier.
const scope = 1
// The message (preimage) to prove (secret).
const message = 2

// Generate the proof.
const fullProof = await generate(message, scope)

/*
nb. scope, digest and nullifier are always the same - proof is variable.
{
scope: '2',
digest: '13713635907739611880977640264956372443229506353728466835599871320028961887800',
nullifier: '4995263610384888704435371233168916617325583088652670186865584118891394144999',
proof: [
'4344680442683455359115899095464919042642166233886432616638435348359080260980',
'20569010229031596977566212621532395450352277701036306316464269899598925981651',
'19318221594436336163085169568471746851468100277321435282188061183430353155289',
'13863222659316400652438453097923451250965656325472339120118358727133180331649',
'2718553541880998786976126630362604850217726344847462841516918030540821216281',
'11960084231774590415377471656397863783771599717615252119734899677642065267169',
'10666072962579546268534775428261696356732715643486735369393626224913301307278',
'4251217137130113647513155953595492143724626859298741948572817563032672674599'
]
}
*/
console.log(fullProof)

// If not specified, the Snark artifacts are downloaded automatically.
// You can specify them as follows.

// const fullProof = await generate(message, scope, {
// wasmFilePath: "<your-path>/poseidon-proof.wasm",
// zkeyFilePath: "<your-path>/poseidon-proof.zkey"
// })

// Verify the proof.
const response = await verify(fullProof)

// true.
console.log(response)

// Eventually you may want to check the nullifier. +
+

📈 Benchmarks

Benchmarks were run on an Intel Core i7-1165G7, 16 GB RAM machine, after initializing the BN128 curve with @zk-kit/groth16-buildBn128 (~230ms).

+ + + + + + + + + + + + + +
Generate proofVerify proofConstraints
80ms10ms141
+
import { generate, verify } from "@zk-kit/poseidon-proof"
import { buildBn128 } from "@zk-kit/groth16"

await buildBn128()

console.time("generate")

const proof = await generate(1, 2)

console.timeEnd("generate")

console.time("verify")

console.log(await verify(proof))

console.timeEnd("verify") +
+

Index

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_smt.html b/modules/_zk_kit_smt.html new file mode 100644 index 000000000..8c4f0a988 --- /dev/null +++ b/modules/_zk_kit_smt.html @@ -0,0 +1,82 @@ +@zk-kit/smt | ZK-kit

Module @zk-kit/smt

+

+ Sparse Merkle tree +

+

Sparse Merkle tree implementation in TypeScript.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +

A sparse Merkle tree is a data structure useful for storing a key/value map where every leaf node of the tree contains the cryptographic hash of a key/value pair and every non leaf node contains the concatenated hashes of its child nodes. Sparse Merkle trees provides a secure and efficient verification of large data sets and they are often used in peer-to-peer technologies. This implementation is an optimized version of the traditional sparse Merkle tree and it is based on the concepts expressed in the papers and resources below.

+

References

    +
  1. Rasmus Dahlberg, Tobias Pulls and Roel Peeters. Efficient Sparse Merkle Trees: Caching Strategies and Secure (Non-)Membership Proofs. Cryptology ePrint Archive: Report 2016/683, 2016. https://eprint.iacr.org/2016/683.
  2. +
  3. Faraz Haider. Compact sparse merkle trees. Cryptology ePrint Archive: Report 2018/955, 2018. https://eprint.iacr.org/2018/955.
  4. +
  5. Jordi Baylina and Marta Bellés. Sparse Merkle Trees. https://docs.iden3.io/publications/pdfs/Merkle-Tree.pdf.
  6. +
  7. Vitalik Buterin Fichter. Optimizing sparse Merkle trees. https://ethresear.ch/t/optimizing-sparse-merkle-trees/3751.
  8. +
+
+

Install

npm or yarn

You can install @zk-kit/smt package with npm:

+
npm i @zk-kit/smt --save
+
+

or yarn:

+
yarn add @zk-kit/smt
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/smt"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/smt"></script>
+
+

📜 Usage

import { ChildNodes, SMT } from "@zk-kit/smt"
import sha256 from "crypto-js/sha256"
import { poseidon2 } from "poseidon-lite"

// Hexadecimal hashes.
const hash = (childNodes: ChildNodes) => sha256(childNodes.join("")).toString()

// Create the SMT with an Hexadecimal (SHA256) hash.
const tree = new SMT(hash)

// 0
console.log(tree.root)

// Big number hashes.
const hash2 = (childNodes: ChildNodes) => poseidon2(childNodes)

// Create the SMT with a BigNumber (Poseidon) hash.
const tree2 = new SMT(hash2, true)

// 0n
console.log(tree2.root)

// Add nodes to the SMT.
tree.add("2b", "44")
tree.add("16", "78")
tree.add("d", "e7")
tree.add("10", "141")
tree.add("20", "340")

// 31ee2a59741c9c32a32d8c7fafe461cca1ccaf5986c2d592586e3e6482a48645
console.log(tree.root)

// Get the value of the leaf.
const value = tree.get("16")

// 78
console.log(value)

// Update the value of the leaf.
tree.update("16", "79")

// 79
console.log(tree.get("16"))

// Delete the leaf.
tree.delete("16")

// undefined
console.log(tree.get("16"))

// Compute the proof of membership for the leaf.
const membershipProof = tree.createProof("2b")

// Compute the proof of membership for a previously deleted leaf.
const nonMembershipProof = tree.createProof("16") // This key has been deleted.

/*
{
entry: [ '2b', '44', '1' ],
matchingEntry: undefined,
siblings: [
'006a0ab15a212e0e0126b81e056b11576628b1ad80792403dbb3a90be2e71d64',
'f786ce5a843614d7da216d95c0087c1eb29244927feeeeeb658aa60cf124cd5e'
],
root: 'c3c023c84afc0a7bab1dbebcef5f7beaf3d6af4af98e8f481620dec052be7d0d',
membership: true
}
*/
console.log(membershipProof)

/*
{
entry: [ '16' ],
matchingEntry: undefined,
siblings: [
'960f23d9fbb44241be53efb7c4d69ac129bb1cb9482dcb6789d3cc7e6de2de2b',
'2a1aef839e68d1bdf43c1b3b1ed9ef16c27162e8a175898c9ac64a679b0fc825'
],
root: 'c3c023c84afc0a7bab1dbebcef5f7beaf3d6af4af98e8f481620dec052be7d0d',
membership: false
}
*/
console.log(nonMembershipProof)

// Verify the proofs.
console.log(tree.verifyProof(membershipProof)) // true
console.log(tree.verifyProof(nonMembershipProof)) // true +
+

Index

Classes

SMT +

Interfaces

Type Aliases

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.conversions.html b/modules/_zk_kit_utils.conversions.html new file mode 100644 index 000000000..df29e7750 --- /dev/null +++ b/modules/_zk_kit_utils.conversions.html @@ -0,0 +1,14 @@ +conversions | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.crypto.html b/modules/_zk_kit_utils.crypto.html new file mode 100644 index 000000000..a545811e2 --- /dev/null +++ b/modules/_zk_kit_utils.crypto.html @@ -0,0 +1,2 @@ +crypto | ZK-kit

Index

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.errorHandlers.html b/modules/_zk_kit_utils.errorHandlers.html new file mode 100644 index 000000000..b972ffa6a --- /dev/null +++ b/modules/_zk_kit_utils.errorHandlers.html @@ -0,0 +1,15 @@ +errorHandlers | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.html b/modules/_zk_kit_utils.html new file mode 100644 index 000000000..a27bd9efc --- /dev/null +++ b/modules/_zk_kit_utils.html @@ -0,0 +1,117 @@ +@zk-kit/utils | ZK-kit

Module @zk-kit/utils

+

+ Utils +

+

Essential zero-knowledge utility library for JavaScript developers.

+

+ +

+ + + + + NPM license + + + NPM version + + + Downloads + + + npm bundle size (scoped) + + + Linter eslint + + + Code style prettier + +

+ + + +
+

[!WARNING]
This library has not been audited.

+
+

🛠 Install

npm or yarn

Install the @zk-kit/utils package and its peer dependencies with npm:

+
npm i @zk-kit/utils
+
+

or yarn:

+
yarn add @zk-kit/utils
+
+

CDN

You can also load it using a script tag using unpkg:

+
<script src="https://unpkg.com/@zk-kit/utils"></script>
+
+

or JSDelivr:

+
<script src="https://cdn.jsdelivr.net/npm/@zk-kit/utils"></script>
+
+

📜 Usage

// You can import modules from the main bundle.
import { errorHandlers, typeChecks } from "@zk-kit/utils"

// Or by using conditional exports.
import { requireNumber } from "@zk-kit/utils/error-handlers"
import { isNumber } from "@zk-kit/utils/type-checks" +
+

For more information on the functions provided by @zk-kit/utils, please refer to the documentation.

+

References

Re-exports SupportedType
Re-exports beBigIntToBuffer
Re-exports beBufferToBigInt
Re-exports beHexadecimalToBigInt
Re-exports bigIntToBuffer
Re-exports bigIntToHexadecimal
Re-exports bigNumberishToBigInt
Re-exports bigNumberishToBuffer
Re-exports bufferToBigInt
Re-exports bufferToHexadecimal
Re-exports hexadecimalToBigInt
Re-exports hexadecimalToBuffer
Re-exports isArray
Re-exports isBigInt
Re-exports isBigNumber
Re-exports isBigNumberish
Re-exports isBuffer
Re-exports isDefined
Re-exports isFunction
Re-exports isHexadecimal
Re-exports isNumber
Re-exports isObject
Re-exports isString
Re-exports isStringifiedBigInt
Re-exports isSupportedType
Re-exports isType
Re-exports isUint8Array
Re-exports leBigIntToBuffer
Re-exports leBufferToBigInt
Re-exports packGroth16Proof
Re-exports requireArray
Re-exports requireBigInt
Re-exports requireBigNumber
Re-exports requireBigNumberish
Re-exports requireBuffer
Re-exports requireDefined
Re-exports requireFunction
Re-exports requireHexadecimal
Re-exports requireNumber
Re-exports requireObject
Re-exports requireString
Re-exports requireStringifiedBigInt
Re-exports requireTypes
Re-exports requireUint8Array
Re-exports unpackGroth16Proof

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.packing.html b/modules/_zk_kit_utils.packing.html new file mode 100644 index 000000000..f9c143ad8 --- /dev/null +++ b/modules/_zk_kit_utils.packing.html @@ -0,0 +1,3 @@ +packing | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.scalar.html b/modules/_zk_kit_utils.scalar.html new file mode 100644 index 000000000..e8cf905a9 --- /dev/null +++ b/modules/_zk_kit_utils.scalar.html @@ -0,0 +1,7 @@ +scalar | ZK-kit

Index

Functions

Generated using TypeDoc

\ No newline at end of file diff --git a/modules/_zk_kit_utils.typeChecks.html b/modules/_zk_kit_utils.typeChecks.html new file mode 100644 index 000000000..3aa9887e4 --- /dev/null +++ b/modules/_zk_kit_utils.typeChecks.html @@ -0,0 +1,17 @@ +typeChecks | ZK-kit

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_baby_jubjub.Point.html b/types/_zk_kit_baby_jubjub.Point.html new file mode 100644 index 000000000..6e9ffcb66 --- /dev/null +++ b/types/_zk_kit_baby_jubjub.Point.html @@ -0,0 +1 @@ +Point | ZK-kit
Point<N>: [N, N]

Type Parameters

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_eddsa_poseidon.Signature.html b/types/_zk_kit_eddsa_poseidon.Signature.html new file mode 100644 index 000000000..2f862849a --- /dev/null +++ b/types/_zk_kit_eddsa_poseidon.Signature.html @@ -0,0 +1 @@ +Signature | ZK-kit
Signature<N>: {
    R8: Point<N>;
    S: N;
}

Type Parameters

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_eddsa_proof.EddsaProof.html b/types/_zk_kit_eddsa_proof.EddsaProof.html new file mode 100644 index 000000000..04a2ea7fc --- /dev/null +++ b/types/_zk_kit_eddsa_proof.EddsaProof.html @@ -0,0 +1 @@ +EddsaProof | ZK-kit
EddsaProof: {
    commitment: NumericString;
    proof: PackedGroth16Proof;
    scope: NumericString;
}

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_eddsa_proof.SnarkArtifacts.html b/types/_zk_kit_eddsa_proof.SnarkArtifacts.html new file mode 100644 index 000000000..7703931d4 --- /dev/null +++ b/types/_zk_kit_eddsa_proof.SnarkArtifacts.html @@ -0,0 +1 @@ +SnarkArtifacts | ZK-kit
SnarkArtifacts: {
    wasmFilePath: string;
    zkeyFilePath: string;
}

Type declaration

  • wasmFilePath: string
  • zkeyFilePath: string

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_groth16.NumericString.html b/types/_zk_kit_groth16.NumericString.html new file mode 100644 index 000000000..0d2455095 --- /dev/null +++ b/types/_zk_kit_groth16.NumericString.html @@ -0,0 +1 @@ +NumericString | ZK-kit

Type alias NumericString

NumericString: `${number}` | string

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_groth16.PublicSignals.html b/types/_zk_kit_groth16.PublicSignals.html new file mode 100644 index 000000000..cc6c986ef --- /dev/null +++ b/types/_zk_kit_groth16.PublicSignals.html @@ -0,0 +1 @@ +PublicSignals | ZK-kit

Type alias PublicSignals

PublicSignals: NumericString[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_groth16.SignalValueType.html b/types/_zk_kit_groth16.SignalValueType.html new file mode 100644 index 000000000..e64daa4d4 --- /dev/null +++ b/types/_zk_kit_groth16.SignalValueType.html @@ -0,0 +1 @@ +SignalValueType | ZK-kit

Type alias SignalValueType

SignalValueType: NumericString | number | bigint | SignalValueType[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_groth16.ZKArtifact.html b/types/_zk_kit_groth16.ZKArtifact.html new file mode 100644 index 000000000..26a91cc1c --- /dev/null +++ b/types/_zk_kit_groth16.ZKArtifact.html @@ -0,0 +1 @@ +ZKArtifact | ZK-kit

Type alias ZKArtifact

ZKArtifact: string | Uint8Array

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_imt.IMTHashFunction.html b/types/_zk_kit_imt.IMTHashFunction.html new file mode 100644 index 000000000..277b406e2 --- /dev/null +++ b/types/_zk_kit_imt.IMTHashFunction.html @@ -0,0 +1,3 @@ +IMTHashFunction | ZK-kit

Type alias IMTHashFunction

IMTHashFunction: ((values) => IMTNode)

The hash function is used to compute the nodes of the tree. +In a binary Merkle tree, each node is the hash of its two children.

+

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_imt.IMTMerkleProof.html b/types/_zk_kit_imt.IMTMerkleProof.html new file mode 100644 index 000000000..b7c185a0f --- /dev/null +++ b/types/_zk_kit_imt.IMTMerkleProof.html @@ -0,0 +1,9 @@ +IMTMerkleProof | ZK-kit

Type alias IMTMerkleProof

IMTMerkleProof: {
    leaf: any;
    leafIndex: number;
    pathIndices: number[];
    root: any;
    siblings: any[];
}

The Merkle Proof contains the necessary parameters to enable the +verifier to be certain that a leaf belongs to the tree. Given the value +of the leaf and its index, it is possible to traverse the tree by +recalculating the hashes up to the root and using the node siblings. +If the calculated root matches the root in the proof, then the leaf +belongs to the tree. It's important to note that the function used +to generate the proof and the one used to verify it must use the +same hash function.

+

Type declaration

  • leaf: any
  • leafIndex: number
  • pathIndices: number[]
  • root: any
  • siblings: any[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_imt.IMTNode.html b/types/_zk_kit_imt.IMTNode.html new file mode 100644 index 000000000..f65317314 --- /dev/null +++ b/types/_zk_kit_imt.IMTNode.html @@ -0,0 +1,2 @@ +IMTNode | ZK-kit

Type alias IMTNode

IMTNode: any

It represents a node of the tree, which can be any value.

+

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_imt.LeanIMTHashFunction.html b/types/_zk_kit_imt.LeanIMTHashFunction.html new file mode 100644 index 000000000..ee6a9b6a4 --- /dev/null +++ b/types/_zk_kit_imt.LeanIMTHashFunction.html @@ -0,0 +1,3 @@ +LeanIMTHashFunction | ZK-kit

Type alias LeanIMTHashFunction<N>

LeanIMTHashFunction<N>: ((a, b) => N)

The hash function is used to compute the nodes of the tree. +In a binary Merkle tree, each node is the hash of its two children.

+

Type Parameters

  • N = bigint

Type declaration

    • (a, b): N
    • Parameters

      Returns N

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_imt.LeanIMTMerkleProof.html b/types/_zk_kit_imt.LeanIMTMerkleProof.html new file mode 100644 index 000000000..50d6a41cc --- /dev/null +++ b/types/_zk_kit_imt.LeanIMTMerkleProof.html @@ -0,0 +1,9 @@ +LeanIMTMerkleProof | ZK-kit

Type alias LeanIMTMerkleProof<N>

LeanIMTMerkleProof<N>: {
    index: number;
    leaf: N;
    root: N;
    siblings: N[];
}

The Merkle Proof contains the necessary parameters to enable the +verifier to be certain that a leaf belongs to the tree. Given the value +of the leaf and its index, it is possible to traverse the tree by +recalculating the hashes up to the root and using the node siblings. +If the calculated root matches the root in the proof, then the leaf +belongs to the tree. It's important to note that the function used +to generate the proof and the one used to verify it must use the +same hash function.

+

Type Parameters

  • N = bigint

Type declaration

  • index: number
  • leaf: N
  • root: N
  • siblings: N[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_lazytower.LazyTowerHashChainProof.html b/types/_zk_kit_lazytower.LazyTowerHashChainProof.html new file mode 100644 index 000000000..83dba4c1b --- /dev/null +++ b/types/_zk_kit_lazytower.LazyTowerHashChainProof.html @@ -0,0 +1 @@ +LazyTowerHashChainProof | ZK-kit

Type alias LazyTowerHashChainProof

LazyTowerHashChainProof: {
    childrens: bigint[][];
    digestOfDigests: bigint;
    item: bigint;
    levelLengths: bigint;
    rootLevel: bigint[];
    rootLv: number;
    topDownDigests: bigint[];
}

Type declaration

  • childrens: bigint[][]
  • digestOfDigests: bigint
  • item: bigint
  • levelLengths: bigint
  • rootLevel: bigint[]
  • rootLv: number
  • topDownDigests: bigint[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.BigIntOutput.html b/types/_zk_kit_poseidon_cipher.BigIntOutput.html new file mode 100644 index 000000000..953e7d541 --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.BigIntOutput.html @@ -0,0 +1 @@ +BigIntOutput | ZK-kit
BigIntOutput: BigIntOutput[] | StringifiedInput | bigint | bigint[] | bigint[][] | bigint[][][] | {
    [key: string]: bigint;
} | null

Type declaration

  • [key: string]: bigint

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.CipherText.html b/types/_zk_kit_poseidon_cipher.CipherText.html new file mode 100644 index 000000000..30664da3b --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.CipherText.html @@ -0,0 +1 @@ +CipherText | ZK-kit
CipherText<N>: N[]

Type Parameters

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.EncryptionKey.html b/types/_zk_kit_poseidon_cipher.EncryptionKey.html new file mode 100644 index 000000000..41b7f56b3 --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.EncryptionKey.html @@ -0,0 +1 @@ +EncryptionKey | ZK-kit
EncryptionKey<N>: [N, N]

Type Parameters

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.Nonce.html b/types/_zk_kit_poseidon_cipher.Nonce.html new file mode 100644 index 000000000..a6599bf90 --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.Nonce.html @@ -0,0 +1 @@ +Nonce | ZK-kit
Nonce<N>: N

Type Parameters

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.PlainText.html b/types/_zk_kit_poseidon_cipher.PlainText.html new file mode 100644 index 000000000..e3d10605c --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.PlainText.html @@ -0,0 +1 @@ +PlainText | ZK-kit
PlainText<N>: N[]

Type Parameters

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_cipher.StringifiedInput.html b/types/_zk_kit_poseidon_cipher.StringifiedInput.html new file mode 100644 index 000000000..9b83089c1 --- /dev/null +++ b/types/_zk_kit_poseidon_cipher.StringifiedInput.html @@ -0,0 +1 @@ +StringifiedInput | ZK-kit
StringifiedInput: string | string[] | string[][] | string[][][] | {
    [key: string]: StringifiedInput;
} | null

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_proof.PoseidonProof.html b/types/_zk_kit_poseidon_proof.PoseidonProof.html new file mode 100644 index 000000000..2280f2b21 --- /dev/null +++ b/types/_zk_kit_poseidon_proof.PoseidonProof.html @@ -0,0 +1 @@ +PoseidonProof | ZK-kit
PoseidonProof: {
    digest: NumericString;
    proof: PackedGroth16Proof;
    scope: NumericString;
}

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_poseidon_proof.SnarkArtifacts.html b/types/_zk_kit_poseidon_proof.SnarkArtifacts.html new file mode 100644 index 000000000..e0115f475 --- /dev/null +++ b/types/_zk_kit_poseidon_proof.SnarkArtifacts.html @@ -0,0 +1 @@ +SnarkArtifacts | ZK-kit
SnarkArtifacts: {
    wasmFilePath: string;
    zkeyFilePath: string;
}

Type declaration

  • wasmFilePath: string
  • zkeyFilePath: string

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.ChildNodes.html b/types/_zk_kit_smt.ChildNodes.html new file mode 100644 index 000000000..8c1a38c19 --- /dev/null +++ b/types/_zk_kit_smt.ChildNodes.html @@ -0,0 +1 @@ +ChildNodes | ZK-kit

Type alias ChildNodes

ChildNodes: Node[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.Entry.html b/types/_zk_kit_smt.Entry.html new file mode 100644 index 000000000..0335c509b --- /dev/null +++ b/types/_zk_kit_smt.Entry.html @@ -0,0 +1 @@ +Entry | ZK-kit

Type alias Entry

Entry: [Key, Value, EntryMark]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.EntryMark.html b/types/_zk_kit_smt.EntryMark.html new file mode 100644 index 000000000..88c5973a9 --- /dev/null +++ b/types/_zk_kit_smt.EntryMark.html @@ -0,0 +1 @@ +EntryMark | ZK-kit

Type alias EntryMark

EntryMark: Node

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.HashFunction.html b/types/_zk_kit_smt.HashFunction.html new file mode 100644 index 000000000..91c7e1a01 --- /dev/null +++ b/types/_zk_kit_smt.HashFunction.html @@ -0,0 +1 @@ +HashFunction | ZK-kit

Type alias HashFunction

HashFunction: ((childNodes) => Node)

Type declaration

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.Key.html b/types/_zk_kit_smt.Key.html new file mode 100644 index 000000000..68fd252b4 --- /dev/null +++ b/types/_zk_kit_smt.Key.html @@ -0,0 +1 @@ +Key | ZK-kit

Type alias Key

Key: Node

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.Node.html b/types/_zk_kit_smt.Node.html new file mode 100644 index 000000000..197b72a99 --- /dev/null +++ b/types/_zk_kit_smt.Node.html @@ -0,0 +1 @@ +Node | ZK-kit

Type alias Node

Node: string | bigint

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.Siblings.html b/types/_zk_kit_smt.Siblings.html new file mode 100644 index 000000000..eb00f8812 --- /dev/null +++ b/types/_zk_kit_smt.Siblings.html @@ -0,0 +1 @@ +Siblings | ZK-kit

Type alias Siblings

Siblings: Node[]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_smt.Value.html b/types/_zk_kit_smt.Value.html new file mode 100644 index 000000000..d320cc3b0 --- /dev/null +++ b/types/_zk_kit_smt.Value.html @@ -0,0 +1 @@ +Value | ZK-kit

Type alias Value

Value: Node

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_utils.BigNumber.html b/types/_zk_kit_utils.BigNumber.html new file mode 100644 index 000000000..80b5ddab8 --- /dev/null +++ b/types/_zk_kit_utils.BigNumber.html @@ -0,0 +1 @@ +BigNumber | ZK-kit

Type alias BigNumber

BigNumber: bigint | string

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_utils.BigNumberish.html b/types/_zk_kit_utils.BigNumberish.html new file mode 100644 index 000000000..a89c3a37f --- /dev/null +++ b/types/_zk_kit_utils.BigNumberish.html @@ -0,0 +1 @@ +BigNumberish | ZK-kit

Type alias BigNumberish

BigNumberish: BigNumber | number | Buffer

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_utils.PackedGroth16Proof.html b/types/_zk_kit_utils.PackedGroth16Proof.html new file mode 100644 index 000000000..e2f12adc5 --- /dev/null +++ b/types/_zk_kit_utils.PackedGroth16Proof.html @@ -0,0 +1 @@ +PackedGroth16Proof | ZK-kit

Type alias PackedGroth16Proof

PackedGroth16Proof: [NumericString, NumericString, NumericString, NumericString, NumericString, NumericString, NumericString, NumericString]

Generated using TypeDoc

\ No newline at end of file diff --git a/types/_zk_kit_utils.typeChecks.SupportedType.html b/types/_zk_kit_utils.typeChecks.SupportedType.html new file mode 100644 index 000000000..455370c64 --- /dev/null +++ b/types/_zk_kit_utils.typeChecks.SupportedType.html @@ -0,0 +1 @@ +SupportedType | ZK-kit
SupportedType: typeof supportedTypes[number]

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_baby_jubjub.Base8.html b/variables/_zk_kit_baby_jubjub.Base8.html new file mode 100644 index 000000000..d22b3ae63 --- /dev/null +++ b/variables/_zk_kit_baby_jubjub.Base8.html @@ -0,0 +1 @@ +Base8 | ZK-kit

Variable Base8Const

Base8: Point<bigint> = ...

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_baby_jubjub.Fr.html b/variables/_zk_kit_baby_jubjub.Fr.html new file mode 100644 index 000000000..3006f6e17 --- /dev/null +++ b/variables/_zk_kit_baby_jubjub.Fr.html @@ -0,0 +1 @@ +Fr | ZK-kit
Fr: default = ...

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_baby_jubjub.order.html b/variables/_zk_kit_baby_jubjub.order.html new file mode 100644 index 000000000..e35f71468 --- /dev/null +++ b/variables/_zk_kit_baby_jubjub.order.html @@ -0,0 +1 @@ +order | ZK-kit

Variable orderConst

order: bigint = ...

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_baby_jubjub.r.html b/variables/_zk_kit_baby_jubjub.r.html new file mode 100644 index 000000000..aa3589541 --- /dev/null +++ b/variables/_zk_kit_baby_jubjub.r.html @@ -0,0 +1,3 @@ +r | ZK-kit
r: bigint = ...

Constants and curve parameters for BabyJubJub elliptic curve operations. +See: https://eips.ethereum.org/EIPS/eip-2494

+

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_baby_jubjub.subOrder.html b/variables/_zk_kit_baby_jubjub.subOrder.html new file mode 100644 index 000000000..aa01a79be --- /dev/null +++ b/variables/_zk_kit_baby_jubjub.subOrder.html @@ -0,0 +1 @@ +subOrder | ZK-kit

Variable subOrderConst

subOrder: bigint = ...

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_poseidon_cipher.C.html b/variables/_zk_kit_poseidon_cipher.C.html new file mode 100644 index 000000000..e79eb5789 --- /dev/null +++ b/variables/_zk_kit_poseidon_cipher.C.html @@ -0,0 +1 @@ +C | ZK-kit
C: bigint[][] = ...

Generated using TypeDoc

\ No newline at end of file diff --git a/variables/_zk_kit_poseidon_cipher.M.html b/variables/_zk_kit_poseidon_cipher.M.html new file mode 100644 index 000000000..85839fcf0 --- /dev/null +++ b/variables/_zk_kit_poseidon_cipher.M.html @@ -0,0 +1 @@ +M | ZK-kit
M: bigint[][][] = ...

Generated using TypeDoc

\ No newline at end of file