|
{{ groth16_verifier }}
|
|
|
|
{{ kzg10_verifier }}
|
|
|
|
/**
|
|
* @author PSE & 0xPARC
|
|
* @title NovaDecider contract, for verifying zk-snarks Nova IVC proofs.
|
|
* @dev This is an askama template. It will feature a snarkjs groth16 and a kzg10 verifier, from which this contract inherits.
|
|
* WARNING: This contract is not complete nor finished. It lacks checks to ensure that no soundness issues can happen.
|
|
* Indeed, we know some of the checks that are missing. And we're working on the solution
|
|
* but for now, it's good enough for testing and benchmarking.
|
|
*/
|
|
contract NovaDecider is Groth16Verifier, KZG10Verifier {
|
|
function verifyProof(uint[2] calldata _pA, uint[2][2] calldata _pB, uint[2] calldata _pC, uint[1] calldata _pubSignals, uint256[2] calldata c, uint256[2] calldata pi, uint256 x, uint256 y) public view returns (bool) {
|
|
bool success_kzg = super.check(c, pi, x, y);
|
|
require(success_kzg == true, "KZG Failed");
|
|
|
|
// for now, we do not relate the Groth16 and KZG10 proofs
|
|
bool success_g16 = super.verifyProof(_pA, _pB, _pC, _pubSignals);
|
|
require(success_g16 == true, "G16 Failed");
|
|
|
|
return(true);
|
|
}
|
|
}
|