Template Circuits
The template circuits are not are not used independently inside Iden3 protocols but rather as a building blocks inside the main circuits.
Note: not all the templates are described here but only a few of them. Check Iden3 Circuits and Iden3 Circomlib to see all the templates.
idOwnershipBySignature
Inputs
| Input | Description | 
|---|---|
| userState | Identity State of the prover | 
| userClaimsTreeRoot | Prover's Claims Tree Root | 
| userAuthClaimMtp[nLevels] | Merkle Tree Proof of Auth Claim inside Prover's Claims tree | 
| userAuthClaim[8] | Prover's Auth Claim | 
| userRevTreeRoot | Prover's Revocation Tree Root | 
| userAuthClaimNonRevMtp[nLevels] | Merkle Tree Proof of non membership of Auth Claim inside Prover's Revocation Tree | 
| userAuthClaimNonRevMtpNoAux | Flag that indicates whether to check the auxiliary Node | 
| userAuthClaimNonRevMtpAuxHi | Auxiliary Node Index | 
| userAuthClaimNonRevMtpAuxHv | Auxiliary Node Value | 
| userRootsTreeRoot | Prover's Roots Tree Root | 
| challenge | Message to be signed by the prover | 
| challengeSignatureR8x | Signature of the challenge (Rx point) | 
| challengeSignatureR8y | Signature of the challenge (Ry point) | 
| challengeSignatureS | Signature of the challenge (S point) | 
Scope
- Verifies that the signaturewas performed by the key contained in theauthClaimand performs further verification on the auth claim using theVerifyAuthClaimAndSignature(nLevels)template
- The stategenerated by hashing the three roots should match the expected state from the blockchain (or be the genesis state) using thecheckIdenStateMatchesRoots()template
VerifyAuthClaimAndSignature
Inputs
| Input | Description | 
|---|---|
| claimsTreeRoot | Prover's Claims Tree Root | 
| authClaimMtp[nLevels] | Merkle Tree Proof of Auth Claim inside Prover's Claims tree | 
| authClaim[8] | Prover's Auth Claim | 
| revTreeRoot | Prover's Revocation Tree Root | 
| userAuthClaimNonRevMtp[nLevels] | Merkle Tree Proof of non membership of Auth Claim inside Prover's Revocation Tree | 
| userAuthClaimNonRevMtpNoAux | Flag that indicates whether to check the auxiliary Node | 
| userAuthClaimNonRevMtpAuxHi | Auxiliary Node Index | 
| userAuthClaimNonRevMtpAuxHv | Auxiliary Node Value | 
| challenge | Message to be signed by the prover | 
| challengeSignatureR8x | Signature of the challenge (Rx point) | 
| challengeSignatureR8y | Signature of the challenge (Ry point) | 
| challengeSignatureS | Signature of the challenge (S point) | 
Scope
- The schema hash of the claim must match the expected AUTH_SCHEMA_HASH (hardcoded inside the circuit). Verification performed using the verifyCredentialSchema()template
- The authClaim exists inside the claims tree root by using the checkClaimExists()template
- The authClaim hasn't been revoked, namely verifies that the authClaim is not included inside the revocation tree root, using the checkClaimNotRevoked()template
- Verifies that the signature on the challenge has been performed by the publickey contained in the authClaim using the checkDataSignatureWithPubKeyInClaim()template