nim-groth16/test_proof.nim
2023-11-11 13:35:13 +01:00

29 lines
782 B
Nim

import ./groth16
import ./export_json
import ./witness
import ./zkey
import ./zkey_types
#-------------------------------------------------------------------------------
proc testProveAndVerify*( zkey_fname, wtns_fname: string) =
echo("parsing witness & zkey files...")
let witness = parseWitness( wtns_fname)
let zkey = parseZKey( zkey_fname)
echo("generating proof...")
let vkey = extractVKey( zkey)
let proof = generateProof( zkey, witness )
echo("exporting proof...")
exportPublicIO( "my_pub.json" , proof )
exportProof( "my_prf.json" , proof )
echo("verifying the proof...")
let ok = verifyProof( vkey, proof)
echo("verification succeeded = ",ok)
#-------------------------------------------------------------------------------