Off-chain verification
Verification of proofs via an off-chain verification service
Proofs can be submitted to a verification service for checking. In order to use a verification service, an endpoint must be obtained from Nebra. (TODO: link)
Proofs can be submitted using the upa command line tool, or programmatically with the Typescript SDK.
Verification using the upatool
upatoolInstall the tool
The standalone upatool can be installed with:
$ npm install --global @nebrazkp/upaIt should then be available in the shell:
$ upa version
2.0.3Specify a verification service endpoint
The --verify-endpointflag, or the VERIFY_ENDPOINTenv var can be used to specify the URL of the verification service to be queried.  It is often convenient to use a .envfile:
VERIFY_ENDPOINT=<endpoint>Verifying proofs in snarkjs format
Use the upa off-chain verify-snarkjscommand:
$ upa off-chain verify-snarkjs vk.json proof.json(Use --helpfor the full list of arguments)
Verify proofs in gnark format
Export the VK, proof and inputs to JSON as described here.
Use the upa off-chain verify-gnarkcommand:
$ upa off-chain verify-gnark vk.json proof.json inputs.jsonVerifying proofs in UPA format
If proofs have already been converted to the UPA format (in particular the AppVkProofInputs format - see the section about proof formats) they can be submitted individually or in batches using the upa off-chain verify command.
Verification using the SDK
In your Typescript project, add the SDK:
$ yarn add @nebrazkp/upaThe VerifierClientclass can then be used to submit proofs for verification:
import VerifierClient from "@nebrazkp/sdk/offChainVerify";
const client = new VerifierClient("<ENDPOINT>");
const valid = await client.verify([vkProofInputs]);Note that vkProofInputsmust be of type `AppVkProofInputs`.  See here for information about converting vk and proof formats into instances of this type.
Last updated
Was this helpful?

