extern crate indy; // Workaround to share some utils code based on indy sdk types between tests and indy sdk use indy::api as api; #[macro_use] extern crate serde_derive; extern crate serde_json; #[macro_use] extern crate lazy_static; #[macro_use] extern crate log; #[macro_use] mod utils; use utils::wallet::WalletUtils; use utils::anoncreds::ISSUER_DID; use utils::anoncreds::AnoncredsUtils; use utils::anoncreds::COMMON_MASTER_SECRET; use utils::test::TestUtils; use std::collections::HashMap; use utils::types::{ ClaimDefinition, ClaimOffer, ProofClaimsJson, ClaimRequestJson, ClaimInfo, ClaimJson, ProofJson }; use indy::api::ErrorCode; mod high_cases { use super::*; mod issuer_create_and_store_claim_def { use super::*; #[test] fn issuer_create_and_store_claim_def_works() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = AnoncredsUtils::get_gvt_schema_json(1); let claim_def_json = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, &ISSUER_DID, &schema, None, false).unwrap(); let claim_def: ClaimDefinition = serde_json::from_str(&claim_def_json).unwrap(); assert!(claim_def.data.public_key.r.len() == 4); assert!(claim_def.data.public_key.n.len() > 0); assert!(claim_def.data.public_key.s.len() > 0); assert!(claim_def.data.public_key.rms.len() > 0); assert!(claim_def.data.public_key.z.len() > 0); assert!(claim_def.data.public_key.rctxt.len() > 0); } #[test] fn issuer_create_and_store_claim_def_works_for_invalid_wallet() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = AnoncredsUtils::get_gvt_schema_json(1); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::issuer_create_claim_definition(invalid_wallet_handle, &ISSUER_DID, &schema, None, false); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_store_claim_offer { use super::*; #[test] fn prover_store_claim_offer_works() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(&ISSUER_DID, 1); AnoncredsUtils::prover_store_claim_offer(wallet_handle, &claim_offer_json).unwrap(); } #[test] fn prover_store_claim_offer_works_for_invalid_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID); let res = AnoncredsUtils::prover_store_claim_offer(wallet_handle, &claim_offer_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_store_claim_offer_works_for_invalid_wallet() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(&ISSUER_DID, 1); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_store_claim_offer(invalid_wallet_handle, &claim_offer_json); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_get_claim_offers { use super::*; #[test] fn prover_get_claim_offers_works_for_empty_filter() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle, r#"{}"#).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 3); } #[test] fn prover_get_claim_offers_works_for_filter_by_issuer() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle, &format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID)).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 2); assert!(claim_offers.contains(&ClaimOffer { issuer_did: ISSUER_DID.to_string(), schema_seq_no: 1 })); assert!(claim_offers.contains(&ClaimOffer { issuer_did: ISSUER_DID.to_string(), schema_seq_no: 2 })); } #[test] fn prover_get_claim_offers_works_for_filter_by_schema() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle, r#"{"schema_seq_no":2}"#).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 2); assert!(claim_offers.contains(&ClaimOffer { issuer_did: ISSUER_DID.to_string(), schema_seq_no: 2 })); assert!(claim_offers.contains(&ClaimOffer { issuer_did: "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW".to_string(), schema_seq_no: 2 })); } #[test] fn prover_get_claim_offers_works_for_filter_by_issuer_and_schema() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle, &format!(r#"{{"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID)).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 1); assert!(claim_offers.contains(&ClaimOffer { issuer_did: ISSUER_DID.to_string(), schema_seq_no: 1 })); } #[test] fn prover_get_claim_offers_works_for_no_results() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle, r#"{"schema_seq_no":4}"#).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 0); } #[test] fn prover_get_claim_offers_works_for_invalid_wallet_handle() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_get_claim_offers(invalid_wallet_handle, r#"{"schema_seq_no":"1"}"#); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_create_master_secret { use super::*; #[test] fn prover_create_master_secret_works() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); AnoncredsUtils::prover_create_master_secret(wallet_handle, "master_secret_name1").unwrap(); } #[test] fn prover_create_master_secret_works_invalid_wallet_handle() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_create_master_secret(invalid_wallet_handle, "master_secret_name2"); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_create_and_store_claim_req { use super::*; #[test] fn prover_create_and_store_claim_req_works() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let schema_seq_no = 1; let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, schema_seq_no); let claim_req_json = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def, COMMON_MASTER_SECRET).unwrap(); let claim_req: ClaimRequestJson = serde_json::from_str(&claim_req_json).unwrap(); assert_eq!(claim_req.schema_seq_no, schema_seq_no); assert_eq!(claim_req.issuer_did, ISSUER_DID); assert!(claim_req.blinded_ms.u.len() > 0); } #[test] fn prover_create_and_store_claim_req_works_for_invalid_wallet() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_create_and_store_claim_req(invalid_wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def, COMMON_MASTER_SECRET); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } #[test] fn prover_create_and_store_claim_req_works_for_claim_def_does_not_correspond_offer_different_issuer_did() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer("NcYxiDXkpYi6ov5FcYDi1e3", 1); let res = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def, COMMON_MASTER_SECRET); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_and_store_claim_req_works_for_claim_def_does_not_correspond_offer_different_schema_seq_no() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 2); let res = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def, COMMON_MASTER_SECRET); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod issuer_create_claim { use super::*; #[test] fn issuer_create_claim_works() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_req = format!(r#"{{"blinded_ms":{{"prover_did":"CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW","u":"54172737564529332710724213139048941083013176891644677117322321823630308734620627329227591845094100636256829761959157314784293939045176621327154990908459072821826818718739696323299787928173535529024556540323709578850706993294234966440826690899266872682790228513973999212370574548239877108511283629423807338632435431097339875665075453785141722989098387895970395982432709011505864533727415552566715069675346220752584449560407261446567731711814188836703337365986725429656195275616846543535707364215498980750860746440672050640048215761507774996460985293327604627646056062013419674090094698841792968543317468164175921100038","ur":null}},"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID); let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, claim_json) = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json).unwrap(); let claim_json: ClaimJson = serde_json::from_str(&claim_json).unwrap(); assert!(claim_json.signature.primary_claim.a.len() > 0); assert!(claim_json.signature.primary_claim.m2.len() > 0); assert!(claim_json.signature.primary_claim.e.len() > 0); assert!(claim_json.signature.primary_claim.v.len() > 0); } #[test] fn issuer_create_claim_works_for_claim_does_not_correspond_to_claim_req() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_req = format!(r#"{{"blinded_ms"{{"prover_did":"CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW","u":"78642009183061519681642949186511883517561213024253007693605674585288964920641017651779407190325620073544451273313223865970730324882004218654708785143702626337327148875137393101464687794953218753005927492179012286511197396945795208681795313939767499444933139277315113356530041684437761038663276793040349557294620223093906897574215436647703667891052762523022326049857738264833807472302707972331207200720216038057270470116611478516211732505056236404960175670287081433670657644042478872537481050085523491110773623684416797190117083084618649667528194409150615774512701755156055570554349550169869411668543258825800016015079","ur":null}},"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID); let claim_json = AnoncredsUtils::get_xyz_claim_json(); let res = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_claim_works_for_for_invalid_wallet_handle() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_req = format!(r#"{{"blinded_ms":{{"prover_did":"CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW","u":"54172737564529332710724213139048941083013176891644677117322321823630308734620627329227591845094100636256829761959157314784293939045176621327154990908459072821826818718739696323299787928173535529024556540323709578850706993294234966440826690899266872682790228513973999212370574548239877108511283629423807338632435431097339875665075453785141722989098387895970395982432709011505864533727415552566715069675346220752584449560407261446567731711814188836703337365986725429656195275616846543535707364215498980750860746440672050640048215761507774996460985293327604627646056062013419674090094698841792968543317468164175921100038","ur":null}},"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID); let claim_json = AnoncredsUtils::get_gvt_claim_json(); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::issuer_create_claim(invalid_wallet_handle, &claim_req, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_store_claim { use super::*; #[test] fn prover_store_claim_works() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let prover_wallet_handle = WalletUtils::create_and_open_wallet("proverWallet", None).unwrap(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, COMMON_MASTER_SECRET).unwrap(); let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def_json, COMMON_MASTER_SECRET).unwrap(); let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, xclaim_json) = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json).unwrap(); AnoncredsUtils::prover_store_claim(prover_wallet_handle, &xclaim_json).unwrap(); } #[test] fn prover_store_claim_works_for_invalid_wallet_handle() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def_json, COMMON_MASTER_SECRET).unwrap(); let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, claim_json) = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json).unwrap(); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_store_claim(invalid_wallet_handle, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_get_claims { use super::*; #[test] fn prover_get_claims_works_for_empty_filter() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claims = AnoncredsUtils::prover_get_claims(wallet_handle, r#"{}"#).unwrap(); let claims: Vec = serde_json::from_str(&claims).unwrap(); assert_eq!(claims.len(), 1); } #[test] fn prover_get_claims_works_for_filter_by_issuer_did() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claims = AnoncredsUtils::prover_get_claims(wallet_handle, &format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID)).unwrap(); let claims: Vec = serde_json::from_str(&claims).unwrap(); assert_eq!(claims.len(), 1); } #[test] fn prover_get_claims_works_for_filter_by_issuer_did_and_schema_seq_no() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claims = AnoncredsUtils::prover_get_claims(wallet_handle, &format!(r#"{{"issuer_did":"{}", "schema_seq_no":1}}"#, ISSUER_DID)).unwrap(); let claims: Vec = serde_json::from_str(&claims).unwrap(); assert_eq!(claims.len(), 1); } #[test] fn prover_get_claims_works_for_empty_result() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claims = AnoncredsUtils::prover_get_claims(wallet_handle, r#"{"schema_seq_no":10}"#).unwrap(); let claims: Vec = serde_json::from_str(&claims).unwrap(); assert_eq!(claims.len(), 0); } #[test] fn prover_get_claims_works_for_invalid_wallet_handle() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_get_claims(invalid_wallet_handle, r#"{}"#); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_get_claims_for_proof_req { use super::*; #[test] fn prover_get_claims_for_proof_req_works_for_revealed_attr() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 1); assert_eq!(claims.predicates.len(), 0); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 1); } #[test] fn prover_get_claims_for_proof_req_works_for_not_found_attribute() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"some_attr"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 1); assert_eq!(claims.predicates.len(), 0); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 0); } #[test] fn prover_get_claims_for_proof_req_works_for_satisfy_predicate() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"GE","value":18}} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 0); assert_eq!(claims.predicates.len(), 1); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); assert_eq!(claims_for_predicate_1.len(), 1); } #[test] fn prover_get_claims_for_proof_req_works_for_not_satisfy_predicate() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"GE","value":58}} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 0); assert_eq!(claims.predicates.len(), 1); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); assert_eq!(claims_for_predicate_1.len(), 0); } #[test] fn prover_get_claims_for_proof_req_works_for_multiply_attribute_and_predicates() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{ "attr1_uuid":{"schema_seq_no":1, "name":"name"}, "attr2_uuid":{"schema_seq_no":1, "name":"sex"} }, "requested_predicates":{ "predicate1_uuid":{"attr_name":"age","p_type":"GE","value":18}, "predicate2_uuid":{"attr_name":"height","p_type":"GE","value":160} }}"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 2); assert_eq!(claims.predicates.len(), 2); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 1); let claims_for_attr_2 = claims.attrs.get("attr2_uuid").unwrap(); assert_eq!(claims_for_attr_2.len(), 1); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); assert_eq!(claims_for_predicate_1.len(), 1); let claims_for_predicate_2 = claims.predicates.get("predicate2_uuid").unwrap(); assert_eq!(claims_for_predicate_2.len(), 1); } #[test] fn prover_get_claims_for_proof_req_works_for_invalid_wallet_handle() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"GE","value":58}} }"#; let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_get_claims_for_proof_req(invalid_wallet_handle, &proof_req); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod prover_create_proof_works { use super::*; #[test] fn prover_create_proof_works() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"GE","value":18}} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let claims_for_predicate = claims.predicates.get("predicate1_uuid").unwrap(); let claim_for_predicate = claims_for_predicate[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{"predicate1_uuid":"{}"}} }}"#, claim_for_attr.claim_uuid, claim_for_predicate.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons).unwrap(); } #[test] fn prover_create_proof_works_for_using_not_satisfy_claim() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let claims = AnoncredsUtils::prover_get_claims(wallet_handle, r#"{}"#).unwrap(); let claims: Vec = serde_json::from_str(&claims).unwrap(); let claim_uuid = claims[0].clone().claim_uuid; let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"some_attr"}}, "requested_predicates":{} }"#; let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let res = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_proof_works_for_invalid_wallet_handle() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim_for_attr.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let invalid_wallet_handle = wallet_handle + 100; let res = AnoncredsUtils::prover_create_proof(invalid_wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::WalletInvalidHandle); } } mod verifier_verify_proof { use super::*; #[test] fn verifier_verify_proof_works_for_correct_proof() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#); let claim_def = format!(r#"{{"ref":1,"signature_type":"CL","origin":"{}", "data":{{"primary":{{"n":"94759924268422840873493186881483285628376767714620627055233230078254863658476446487556117977593248501523199451418346650764648601684276437772084327637083000213497377603495837360299641742248892290843802071224822481683143989223918276185323177379400413928352871249494885563503003839960930062341074783742062464846448855510814252519824733234277681749977392772900212293652238651538092092030867161752390937372967233462027620699196724949212432236376627703446877808405786247217818975482797381180714523093913559060716447170497587855871901716892114835713057965087473682457896508094049813280368069805661739141591558517233009123957","s":"3589207374161609293256840431433442367968556468254553005135697551692970564853243905310862234226531556373974144223993822323573625466428920716249949819187529684239371465431718456502388533731367046146704547241076626874082510133130124364613881638153345624380195335138152993132904167470515345775215584510356780117368593105284564368954871044494967246738070895990267205643985529060025311535539534155086912661927003271053443110788963970349858709526217650537936123121324492871282397691771309596632805099306241616501610166028401599243350835158479028294769235556557248339060399322556412171888114265194198405765574333538019124846","rms":"57150374376895616256492932008792437185713712934712117819417607831438470701645904776986426606717466732609284990796923331049549544903261623636958698296956103821068569714644825742048584174696465882627177060166162341112552851798863535031243458188976013190131935905789786836375734914391914349188643340535242562896244661798678234667651641013894284156416773868299435641426810968290584996112925365638881750944407842890875840705650290814965768221299488400872767679122749231050406680432079499973527780212310700022178178822528199576164498116369689770884051691678056831493476045361227274839673581033532995523269047577973637307053","r":{{"age":"94304485801056920773231824603827244147437820123357994068540328541540143488826838939836897544389872126768239056314698953816072289663428273075648246498659039419931054256171488371404693243192741923382499918184822032756852725234903892700640856294525441486319095181804549558538523888770076173572615957495813339649470619615099181648313548341951673407624414494737018574238782648822189142664108450534642272145962844003886059737965854042074083374478426875684184904488545593139633653407062308621502392373426120986761417580127895634822264744063122368296502161439648408926687989964483291459079738447940651025900007635890755686910","sex":"29253365609829921413347591854991689007250272038394995372767401325848195298844802462252851926995846503104090589196060683329875231216529049681648909174047403783834364995363938741001507091534282239210301727771803410513303526378812888571225762557471133950393342500638551458868147905023198508660460641434022020257614450354085808398293279060446966692082427506909617283562394303716193372887306176319841941848888379308208426966697446699225783646634631703732019477632822374479322570142967559738439193417309205283438893083349863592921249218168590490390313109776446516881569691499831380592661740653935515397472059631417493981532","name":"25134437486609445980011967476486104706321061312022352268621323694861467756181853100693555519614894168921947814126694858839278103549577703105305116890325322098078409416441750313062396467567140699008203113519528887729951138845002409659317083029073793314514377377412805387401717457417895322600145580639449003584446356048213839274172751441145076183734269045919984853749007476629365146654240675320041155618450449041510280560040162429566008590065069477149918088087715269037925211599101597422023202484497946662159070023999719865939258557778022770035320019440597702090334486792710436579355608406897769514395306079855023848170","height":"59326960517737425423547279838932030505937927873589489863081026714907925093402287263487670945897247474465655528290016645774365383046524346223348261262488616342337864633104758662753452450299389775751012589698563659277683974188553993694220606310980581680471280640591973543996299789038056921309016983827578247477799948667666717056420270448516049047961099547588510086600581628091290215485826514170097211360599793229701811672966818089371089216189744274422526431130783428589346341196561742409198605034972210917502326180305735092988639850309253190875578501020679137562856724998821945605494355779034135306337094344532980411836"}},"rctxt":"9641986614889199796257508700106896585587271615330980339636468819377346498767697681332046156705231986464570206666984343024200482683981302064613556104594051003956610353281701880542337665385482309134369756144345334575765116656633321636736946947493150642615481313285221467998414924865943067790561494301461899025374692884841352282256044388512875752628313052128404892424405230961678931620525106856624692942373538946467902799339061714326383378018581568876147181355325663707572429090278505823900491548970098691127791086305310899642155499128171811034581730190877600697624903963241473287185133286356124371104261592694271730029","z":"77594127026421654059198621152153180600664927707984020918609426112642522289621323453889995053400171879296098965678384769043918218957929606187082395048777546641833348694470081024386996548890150355901703252426977094536933434556202865213941384425538749866521536494046548509344678288447175898173634381514948562261015286492185924659638474376885655055568341574638453213864956407243206035973349529545863886325462867413885904072942842465859476940638839087894582648849969332663627779378998245133055807038199937421971988505911494931665143822588532097754480882750243126847177560978100527491344463525107644125030963904001009159559"}},"revocation":null}}}}"#, ISSUER_DID); let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, claim_def); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":{"revealed_attrs":{"name":"1139481716457488690172217916278103335"},"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988340","e":"13427639393364185909415877973872458621259927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274586162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843388153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"schema_seq_no":1,"revoc_reg_seq_no":null,"issuer_did":"did"}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); } #[test] fn verifier_verify_proof_works_for_proof_does_not_correspond_to_request() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"sex"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"height","p_type":"GE","value":180}}}} }}"#); let claim_def = r#"{"public_key":{"n":"94759924268422840873493186881483285628376767714620627055233230078254863658476446487556117977593248501523199451418346650764648601684276437772084327637083000213497377603495837360299641742248892290843802071224822481683143989223918276185323177379400413928352871249494885563503003839960930062341074783742062464846448855510814252519824733234277681749977392772900212293652238651538092092030867161752390937372967233462027620699196724949212432236376627703446877808405786247217818975482797381180714523093913559060716447170497587855871901716892114835713057965087473682457896508094049813280368069805661739141591558517233009123957","s":"3589207374161609293256840431433442367968556468254553005135697551692970564853243905310862234226531556373974144223993822323573625466428920716249949819187529684239371465431718456502388533731367046146704547241076626874082510133130124364613881638153345624380195335138152993132904167470515345775215584510356780117368593105284564368954871044494967246738070895990267205643985529060025311535539534155086912661927003271053443110788963970349858709526217650537936123121324492871282397691771309596632805099306241616501610166028401599243350835158479028294769235556557248339060399322556412171888114265194198405765574333538019124846","rms":"57150374376895616256492932008792437185713712934712117819417607831438470701645904776986426606717466732609284990796923331049549544903261623636958698296956103821068569714644825742048584174696465882627177060166162341112552851798863535031243458188976013190131935905789786836375734914391914349188643340535242562896244661798678234667651641013894284156416773868299435641426810968290584996112925365638881750944407842890875840705650290814965768221299488400872767679122749231050406680432079499973527780212310700022178178822528199576164498116369689770884051691678056831493476045361227274839673581033532995523269047577973637307053","r":{"age":"94304485801056920773231824603827244147437820123357994068540328541540143488826838939836897544389872126768239056314698953816072289663428273075648246498659039419931054256171488371404693243192741923382499918184822032756852725234903892700640856294525441486319095181804549558538523888770076173572615957495813339649470619615099181648313548341951673407624414494737018574238782648822189142664108450534642272145962844003886059737965854042074083374478426875684184904488545593139633653407062308621502392373426120986761417580127895634822264744063122368296502161439648408926687989964483291459079738447940651025900007635890755686910","sex":"29253365609829921413347591854991689007250272038394995372767401325848195298844802462252851926995846503104090589196060683329875231216529049681648909174047403783834364995363938741001507091534282239210301727771803410513303526378812888571225762557471133950393342500638551458868147905023198508660460641434022020257614450354085808398293279060446966692082427506909617283562394303716193372887306176319841941848888379308208426966697446699225783646634631703732019477632822374479322570142967559738439193417309205283438893083349863592921249218168590490390313109776446516881569691499831380592661740653935515397472059631417493981532","name":"25134437486609445980011967476486104706321061312022352268621323694861467756181853100693555519614894168921947814126694858839278103549577703105305116890325322098078409416441750313062396467567140699008203113519528887729951138845002409659317083029073793314514377377412805387401717457417895322600145580639449003584446356048213839274172751441145076183734269045919984853749007476629365146654240675320041155618450449041510280560040162429566008590065069477149918088087715269037925211599101597422023202484497946662159070023999719865939258557778022770035320019440597702090334486792710436579355608406897769514395306079855023848170","height":"59326960517737425423547279838932030505937927873589489863081026714907925093402287263487670945897247474465655528290016645774365383046524346223348261262488616342337864633104758662753452450299389775751012589698563659277683974188553993694220606310980581680471280640591973543996299789038056921309016983827578247477799948667666717056420270448516049047961099547588510086600581628091290215485826514170097211360599793229701811672966818089371089216189744274422526431130783428589346341196561742409198605034972210917502326180305735092988639850309253190875578501020679137562856724998821945605494355779034135306337094344532980411836"},"rctxt":"9641986614889199796257508700106896585587271615330980339636468819377346498767697681332046156705231986464570206666984343024200482683981302064613556104594051003956610353281701880542337665385482309134369756144345334575765116656633321636736946947493150642615481313285221467998414924865943067790561494301461899025374692884841352282256044388512875752628313052128404892424405230961678931620525106856624692942373538946467902799339061714326383378018581568876147181355325663707572429090278505823900491548970098691127791086305310899642155499128171811034581730190877600697624903963241473287185133286356124371104261592694271730029","z":"77594127026421654059198621152153180600664927707984020918609426112642522289621323453889995053400171879296098965678384769043918218957929606187082395048777546641833348694470081024386996548890150355901703252426977094536933434556202865213941384425538749866521536494046548509344678288447175898173634381514948562261015286492185924659638474376885655055568341574638453213864956407243206035973349529545863886325462867413885904072942842465859476940638839087894582648849969332663627779378998245133055807038199937421971988505911494931665143822588532097754480882750243126847177560978100527491344463525107644125030963904001009159559"},"public_key_revocation":null,"schema_seq_no":1,"signature_type":"CL"}"#; let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, claim_def); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":{"revealed_attrs":{"name":"1139481716457488690172217916278103335"},"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988340","e":"13427639393364185909415877973872458621259927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274586162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843388153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"schema_seq_no":1,"revoc_reg_seq_no":null,"issuer_did":"did"}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let res = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn verifier_verify_proof_works_for_wrong_proof() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#); let claim_def = format!(r#"{{"ref":1,"signature_type":"CL","origin":"{}", "data":{{"primary":{{"n":"94759924268422840873493186881483285628376767714620627055233230078254863658476446487556117977593248501523199451418346650764648601684276437772084327637083000213497377603495837360299641742248892290843802071224822481683143989223918276185323177379400413928352871249494885563503003839960930062341074783742062464846448855510814252519824733234277681749977392772900212293652238651538092092030867161752390937372967233462027620699196724949212432236376627703446877808405786247217818975482797381180714523093913559060716447170497587855871901716892114835713057965087473682457896508094049813280368069805661739141591558517233009123957","s":"3589207374161609293256840431433442367968556468254553005135697551692970564853243905310862234226531556373974144223993822323573625466428920716249949819187529684239371465431718456502388533731367046146704547241076626874082510133130124364613881638153345624380195335138152993132904167470515345775215584510356780117368593105284564368954871044494967246738070895990267205643985529060025311535539534155086912661927003271053443110788963970349858709526217650537936123121324492871282397691771309596632805099306241616501610166028401599243350835158479028294769235556557248339060399322556412171888114265194198405765574333538019124846","rms":"57150374376895616256492932008792437185713712934712117819417607831438470701645904776986426606717466732609284990796923331049549544903261623636958698296956103821068569714644825742048584174696465882627177060166162341112552851798863535031243458188976013190131935905789786836375734914391914349188643340535242562896244661798678234667651641013894284156416773868299435641426810968290584996112925365638881750944407842890875840705650290814965768221299488400872767679122749231050406680432079499973527780212310700022178178822528199576164498116369689770884051691678056831493476045361227274839673581033532995523269047577973637307053","r":{{"age":"94304485801056920773231824603827244147437820123357994068540328541540143488826838939836897544389872126768239056314698953816072289663428273075648246498659039419931054256171488371404693243192741923382499918184822032756852725234903892700640856294525441486319095181804549558538523888770076173572615957495813339649470619615099181648313548341951673407624414494737018574238782648822189142664108450534642272145962844003886059737965854042074083374478426875684184904488545593139633653407062308621502392373426120986761417580127895634822264744063122368296502161439648408926687989964483291459079738447940651025900007635890755686910","sex":"29253365609829921413347591854991689007250272038394995372767401325848195298844802462252851926995846503104090589196060683329875231216529049681648909174047403783834364995363938741001507091534282239210301727771803410513303526378812888571225762557471133950393342500638551458868147905023198508660460641434022020257614450354085808398293279060446966692082427506909617283562394303716193372887306176319841941848888379308208426966697446699225783646634631703732019477632822374479322570142967559738439193417309205283438893083349863592921249218168590490390313109776446516881569691499831380592661740653935515397472059631417493981532","name":"25134437486609445980011967476486104706321061312022352268621323694861467756181853100693555519614894168921947814126694858839278103549577703105305116890325322098078409416441750313062396467567140699008203113519528887729951138845002409659317083029073793314514377377412805387401717457417895322600145580639449003584446356048213839274172751441145076183734269045919984853749007476629365146654240675320041155618450449041510280560040162429566008590065069477149918088087715269037925211599101597422023202484497946662159070023999719865939258557778022770035320019440597702090334486792710436579355608406897769514395306079855023848170","height":"59326960517737425423547279838932030505937927873589489863081026714907925093402287263487670945897247474465655528290016645774365383046524346223348261262488616342337864633104758662753452450299389775751012589698563659277683974188553993694220606310980581680471280640591973543996299789038056921309016983827578247477799948667666717056420270448516049047961099547588510086600581628091290215485826514170097211360599793229701811672966818089371089216189744274422526431130783428589346341196561742409198605034972210917502326180305735092988639850309253190875578501020679137562856724998821945605494355779034135306337094344532980411836"}},"rctxt":"9641986614889199796257508700106896585587271615330980339636468819377346498767697681332046156705231986464570206666984343024200482683981302064613556104594051003956610353281701880542337665385482309134369756144345334575765116656633321636736946947493150642615481313285221467998414924865943067790561494301461899025374692884841352282256044388512875752628313052128404892424405230961678931620525106856624692942373538946467902799339061714326383378018581568876147181355325663707572429090278505823900491548970098691127791086305310899642155499128171811034581730190877600697624903963241473287185133286356124371104261592694271730029","z":"77594127026421654059198621152153180600664927707984020918609426112642522289621323453889995053400171879296098965678384769043918218957929606187082395048777546641833348694470081024386996548890150355901703252426977094536933434556202865213941384425538749866521536494046548509344678288447175898173634381514948562261015286492185924659638474376885655055568341574638453213864956407243206035973349529545863886325462867413885904072942842465859476940638839087894582648849969332663627779378998245133055807038199937421971988505911494931665143822588532097754480882750243126847177560978100527491344463525107644125030963904001009159559"}},"revocation":null}}}}"#, ISSUER_DID); let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, claim_def); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":{"revealed_attrs":{"name":"1139481716457488690172217916278103335"},"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988326","e":"13427639393364185909415877973872458621256927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274746162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843369153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"schema_seq_no":1,"revoc_reg_seq_no":null,"issuer_did":"did"}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert_eq!(valid, false); } } } mod medium_cases { use super::*; mod issuer_create_and_store_claim_def { use super::*; #[test] fn issuer_create_and_store_claim_def_works_for_invalid_schema() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = r#"{"seqNo":1, "name":"name","version":"1.0", "keys":["name"]}"#; let res = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, ISSUER_DID, &schema, None, false); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_and_store_claim_def_works_for_invalid_did() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = r#"{"seqNo":1, "data":{"name":"name","version":"1.0","keys":[]}}"#; let res = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, "invalid_base58_String", &schema, None, false); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_and_store_claim_def_works_for_empty_schema_keys() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = r#"{"seqNo":1, "data":{"name":"name","version":"1.0","keys":[]}}"#; let res = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, &schema, ISSUER_DID, None, false); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_and_store_claim_def_works_for_correct_signature_type() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = AnoncredsUtils::get_gvt_schema_json(1); let res = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, &schema, ISSUER_DID, Some("CL"), false); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_and_store_claim_def_works_for_invalid_signature_type() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let schema = AnoncredsUtils::get_gvt_schema_json(1); let res = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, &schema, ISSUER_DID, Some("some_type"), false); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_store_claim_offer { use super::*; #[test] fn prover_store_claim_offer_works_for_invalid_issuer_did() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = r#"{"issuer_did":"invalid_base58_string", "schema_seq_no":1}"#; let res = AnoncredsUtils::prover_store_claim_offer(wallet_handle, &claim_offer_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_get_claim_offers { use super::*; #[test] fn prover_get_claim_offers_works_for_invalid_filter_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let res = AnoncredsUtils::prover_get_claim_offers(wallet_handle, r#"{"schema_seq_no":"1"}"#); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_get_claim_offers_works_for_different_wallets() { AnoncredsUtils::init_common_wallet(); let wallet_handle_1 = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); let wallet_handle_2 = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); let claim_offer_json_1 = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); let claim_offer_json_2 = AnoncredsUtils::get_claim_offer(ISSUER_DID, 2); let claim_offer_json_3 = AnoncredsUtils::get_claim_offer("CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", 2); AnoncredsUtils::prover_store_claim_offer(wallet_handle_1, &claim_offer_json_1).unwrap(); AnoncredsUtils::prover_store_claim_offer(wallet_handle_2, &claim_offer_json_2).unwrap(); AnoncredsUtils::prover_store_claim_offer(wallet_handle_2, &claim_offer_json_3).unwrap(); let claim_offers = AnoncredsUtils::prover_get_claim_offers(wallet_handle_2, &format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID)).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers).unwrap(); assert_eq!(claim_offers.len(), 1); assert!(claim_offers.contains(&ClaimOffer { issuer_did: ISSUER_DID.to_string(), schema_seq_no: 2 })); } } mod prover_create_master_secret { use super::*; #[test] fn prover_create_master_secret_works_for_duplicate_name() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); AnoncredsUtils::prover_create_master_secret(wallet_handle, "master_secret_name_duplicate").unwrap(); let res = AnoncredsUtils::prover_create_master_secret(wallet_handle, "master_secret_name_duplicate"); assert_eq!(res.unwrap_err(), ErrorCode::AnoncredsMasterSecretDuplicateNameError); } #[test] fn prover_create_master_secret_works_for_empty_name() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let res = AnoncredsUtils::prover_create_master_secret(wallet_handle, ""); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidParam3); } } mod prover_create_and_store_claim_req { use super::*; #[test] fn prover_create_and_store_claim_req_works_for_invalid_claim_offer() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = r#"{"schema_seq_no":1}"#; let res = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", claim_offer_json, &claim_def, COMMON_MASTER_SECRET); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_and_store_claim_req_works_for_invalid_claim_def() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); let claim_def = r#"{ "schema_seq_no":1, "signature_type":"CL", "public_key":{ "n":"121212", "s":"432192" } }"#; let res = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, claim_def, COMMON_MASTER_SECRET); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_and_store_claim_req_works_for_invalid_master_secret() { let (wallet_handle, claim_def) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); let res = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def, "invalid_master_secret_name"); assert_eq!(res.unwrap_err(), ErrorCode::WalletNotFoundError); } } mod issuer_create_claim { use super::*; #[test] fn issuer_create_claim_works_for_for_invalid_claim_req_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_req = format!(r#"{{"blinded_ms"{{"prover_did":"CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW"","ur":null}},"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID); let claim_json = AnoncredsUtils::get_gvt_claim_json(); let res = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn issuer_create_claim_works_for_for_invalid_claim_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_req = format!(r#"{{"blinded_ms":{{"prover_did":"CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW","u":"54172737564529332710724213139048941083013176891644677117322321823630308734620627329227591845094100636256829761959157314784293939045176621327154990908459072821826818718739696323299787928173535529024556540323709578850706993294234966440826690899266872682790228513973999212370574548239877108511283629423807338632435431097339875665075453785141722989098387895970395982432709011505864533727415552566715069675346220752584449560407261446567731711814188836703337365986725429656195275616846543535707364215498980750860746440672050640048215761507774996460985293327604627646056062013419674090094698841792968543317468164175921100038","ur":null}},"issuer_did":"{}","schema_seq_no":1}}"#, ISSUER_DID); let claim_json = r#"{ "sex":"male", "name":"Alex", "height":"175", "age":"28" }"#; let res = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_store_claim { use super::*; #[test] fn prover_store_claim_works_without_claim_req() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let claim_json = format!(r#"{{"claim":{{"sex":["male","1"],"age":["28","28"],"name":["Alex","1"],"height":["175","175"]}}, "issuer_did":"{}", "revoc_reg_seq_no":null, "schema_seq_no":10, "signature":{{"primary_claim":{{"m2":"1","a":"1","e":"2","v":"3"}},"non_revocation_claim":null}}}}"#, ISSUER_DID); let res = AnoncredsUtils::prover_store_claim(wallet_handle, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::WalletNotFoundError); } #[test] fn prover_store_claim_works_for_invalid_claim_json() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, 1); AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW", &claim_offer_json, &claim_def_json, COMMON_MASTER_SECRET).unwrap(); let claim_json = r#"{"claim":{"sex":["male","1"],"age":["28","28"],"name":["Alex","1"],"height":["175","175"]}, "issuer_did":1," revoc_reg_seq_no":null, "schema_seq_no":1}"#; let res = AnoncredsUtils::prover_store_claim(wallet_handle, &claim_json); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_get_claims { use super::*; #[test] fn prover_get_claims_works_for_invalid_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let res = AnoncredsUtils::prover_get_claims(wallet_handle, r#"{"schema_seq_no": "1"}"#); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_get_claims_for_proof_req { use super::*; #[test] fn prover_get_claims_for_proof_req_works_for_empty_req() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 0); assert_eq!(claims.predicates.len(), 0); } #[test] fn prover_get_claims_for_proof_req_works_for_invalid_proof_req() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_predicates":{} }"#; let res = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_get_claims_for_proof_req_works_for_revealed_attr_with_other_schema_seq_no() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":2, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 1); assert_eq!(claims.predicates.len(), 0); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 0); } #[test] fn prover_get_claims_for_proof_req_works_for_revealed_attr_for_specific_issuer() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"issuer_did":"NcYxiDXkpYi6ov5FcYDi1e", "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 1); assert_eq!(claims.predicates.len(), 0); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 1); } #[test] fn prover_get_claims_for_proof_req_works_for_revealed_attr_with_other_issuer() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"issuer_did":"Ac23dAXkpYi6ov5FcYDi1e", "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 1); assert_eq!(claims.predicates.len(), 0); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(claims_for_attr_1.len(), 0); } #[test] fn prover_get_claims_for_proof_req_works_for_satisfy_predicate_by_specific_issuer_and_schema() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"GE","value":18,"schema_seq_no":1,"issuer_did":"NcYxiDXkpYi6ov5FcYDi1e"}} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(claims.attrs.len(), 0); assert_eq!(claims.predicates.len(), 1); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); assert_eq!(claims_for_predicate_1.len(), 1); } #[test] fn prover_get_claims_for_proof_req_works_for_invalid_predicate() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age"}} }"#; let res = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_get_claims_for_proof_req_works_for_invalid_predicate_type() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{}, "requested_predicates":{"predicate1_uuid":{"attr_name":"age","p_type":"LE","value":58}} }"#; let res = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod prover_create_proof_works { use super::*; #[test] fn prover_create_proof_works_for_invalid_master_secret() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim_for_attr.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let res = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, "invalid_master_secret_name", &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::WalletNotFoundError); } #[test] fn prover_create_proof_works_for_invalid_schemas_json() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim_for_attr.claim_uuid); let schemas_json = r#"{}"#; let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let res = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_proof_works_for_invalid_claim_defs_json() { let (wallet_handle, _) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim_for_attr.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = r#"{}"#; let revoc_regs_jsons = "{}"; let res = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn prover_create_proof_works_for_invalid_requested_claims_json() { let (wallet_handle, claim_def_json) = AnoncredsUtils::init_common_wallet(); let proof_req = r#"{"nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{"attr1_uuid":{"schema_seq_no":1, "name":"name"}}, "requested_predicates":{} }"#; let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr1_uuid").unwrap(); let claim_for_attr = claims_for_attr[0].clone(); let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_predicates":{{}} }}"#); let schemas_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim_for_attr.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let res = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req, &requested_claims_json, &schemas_json, COMMON_MASTER_SECRET, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } mod verifier_verify_proof { use super::*; #[test] fn verifier_verify_proof_works_for_invalid_proof_json() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#); let claim_def = r#"{"public_key":{"n":"94759924268422840873493186881483285628376767714620627055233230078254863658476446487556117977593248501523199451418346650764648601684276437772084327637083000213497377603495837360299641742248892290843802071224822481683143989223918276185323177379400413928352871249494885563503003839960930062341074783742062464846448855510814252519824733234277681749977392772900212293652238651538092092030867161752390937372967233462027620699196724949212432236376627703446877808405786247217818975482797381180714523093913559060716447170497587855871901716892114835713057965087473682457896508094049813280368069805661739141591558517233009123957","s":"3589207374161609293256840431433442367968556468254553005135697551692970564853243905310862234226531556373974144223993822323573625466428920716249949819187529684239371465431718456502388533731367046146704547241076626874082510133130124364613881638153345624380195335138152993132904167470515345775215584510356780117368593105284564368954871044494967246738070895990267205643985529060025311535539534155086912661927003271053443110788963970349858709526217650537936123121324492871282397691771309596632805099306241616501610166028401599243350835158479028294769235556557248339060399322556412171888114265194198405765574333538019124846","rms":"57150374376895616256492932008792437185713712934712117819417607831438470701645904776986426606717466732609284990796923331049549544903261623636958698296956103821068569714644825742048584174696465882627177060166162341112552851798863535031243458188976013190131935905789786836375734914391914349188643340535242562896244661798678234667651641013894284156416773868299435641426810968290584996112925365638881750944407842890875840705650290814965768221299488400872767679122749231050406680432079499973527780212310700022178178822528199576164498116369689770884051691678056831493476045361227274839673581033532995523269047577973637307053","r":{"age":"94304485801056920773231824603827244147437820123357994068540328541540143488826838939836897544389872126768239056314698953816072289663428273075648246498659039419931054256171488371404693243192741923382499918184822032756852725234903892700640856294525441486319095181804549558538523888770076173572615957495813339649470619615099181648313548341951673407624414494737018574238782648822189142664108450534642272145962844003886059737965854042074083374478426875684184904488545593139633653407062308621502392373426120986761417580127895634822264744063122368296502161439648408926687989964483291459079738447940651025900007635890755686910","sex":"29253365609829921413347591854991689007250272038394995372767401325848195298844802462252851926995846503104090589196060683329875231216529049681648909174047403783834364995363938741001507091534282239210301727771803410513303526378812888571225762557471133950393342500638551458868147905023198508660460641434022020257614450354085808398293279060446966692082427506909617283562394303716193372887306176319841941848888379308208426966697446699225783646634631703732019477632822374479322570142967559738439193417309205283438893083349863592921249218168590490390313109776446516881569691499831380592661740653935515397472059631417493981532","name":"25134437486609445980011967476486104706321061312022352268621323694861467756181853100693555519614894168921947814126694858839278103549577703105305116890325322098078409416441750313062396467567140699008203113519528887729951138845002409659317083029073793314514377377412805387401717457417895322600145580639449003584446356048213839274172751441145076183734269045919984853749007476629365146654240675320041155618450449041510280560040162429566008590065069477149918088087715269037925211599101597422023202484497946662159070023999719865939258557778022770035320019440597702090334486792710436579355608406897769514395306079855023848170","height":"59326960517737425423547279838932030505937927873589489863081026714907925093402287263487670945897247474465655528290016645774365383046524346223348261262488616342337864633104758662753452450299389775751012589698563659277683974188553993694220606310980581680471280640591973543996299789038056921309016983827578247477799948667666717056420270448516049047961099547588510086600581628091290215485826514170097211360599793229701811672966818089371089216189744274422526431130783428589346341196561742409198605034972210917502326180305735092988639850309253190875578501020679137562856724998821945605494355779034135306337094344532980411836"},"rctxt":"9641986614889199796257508700106896585587271615330980339636468819377346498767697681332046156705231986464570206666984343024200482683981302064613556104594051003956610353281701880542337665385482309134369756144345334575765116656633321636736946947493150642615481313285221467998414924865943067790561494301461899025374692884841352282256044388512875752628313052128404892424405230961678931620525106856624692942373538946467902799339061714326383378018581568876147181355325663707572429090278505823900491548970098691127791086305310899642155499128171811034581730190877600697624903963241473287185133286356124371104261592694271730029","z":"77594127026421654059198621152153180600664927707984020918609426112642522289621323453889995053400171879296098965678384769043918218957929606187082395048777546641833348694470081024386996548890150355901703252426977094536933434556202865213941384425538749866521536494046548509344678288447175898173634381514948562261015286492185924659638474376885655055568341574638453213864956407243206035973349529545863886325462867413885904072942842465859476940638839087894582648849969332663627779378998245133055807038199937421971988505911494931665143822588532097754480882750243126847177560978100527491344463525107644125030963904001009159559"},"public_key_revocation":null,"schema_seq_no":1,"signature_type":"CL"}"#; let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, claim_def); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988340","e":"13427639393364185909415877973872458621259927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274586162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843388153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"issuer_did":"NcYxiDXkpYi6ov5FcYDi1e","revoc_reg_seq_no":null}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let res = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn verifier_verify_proof_works_for_invalid_schemas() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#); let claim_def = r#"{"public_key":{"n":"94759924268422840873493186881483285628376767714620627055233230078254863658476446487556117977593248501523199451418346650764648601684276437772084327637083000213497377603495837360299641742248892290843802071224822481683143989223918276185323177379400413928352871249494885563503003839960930062341074783742062464846448855510814252519824733234277681749977392772900212293652238651538092092030867161752390937372967233462027620699196724949212432236376627703446877808405786247217818975482797381180714523093913559060716447170497587855871901716892114835713057965087473682457896508094049813280368069805661739141591558517233009123957","s":"3589207374161609293256840431433442367968556468254553005135697551692970564853243905310862234226531556373974144223993822323573625466428920716249949819187529684239371465431718456502388533731367046146704547241076626874082510133130124364613881638153345624380195335138152993132904167470515345775215584510356780117368593105284564368954871044494967246738070895990267205643985529060025311535539534155086912661927003271053443110788963970349858709526217650537936123121324492871282397691771309596632805099306241616501610166028401599243350835158479028294769235556557248339060399322556412171888114265194198405765574333538019124846","rms":"57150374376895616256492932008792437185713712934712117819417607831438470701645904776986426606717466732609284990796923331049549544903261623636958698296956103821068569714644825742048584174696465882627177060166162341112552851798863535031243458188976013190131935905789786836375734914391914349188643340535242562896244661798678234667651641013894284156416773868299435641426810968290584996112925365638881750944407842890875840705650290814965768221299488400872767679122749231050406680432079499973527780212310700022178178822528199576164498116369689770884051691678056831493476045361227274839673581033532995523269047577973637307053","r":{"age":"94304485801056920773231824603827244147437820123357994068540328541540143488826838939836897544389872126768239056314698953816072289663428273075648246498659039419931054256171488371404693243192741923382499918184822032756852725234903892700640856294525441486319095181804549558538523888770076173572615957495813339649470619615099181648313548341951673407624414494737018574238782648822189142664108450534642272145962844003886059737965854042074083374478426875684184904488545593139633653407062308621502392373426120986761417580127895634822264744063122368296502161439648408926687989964483291459079738447940651025900007635890755686910","sex":"29253365609829921413347591854991689007250272038394995372767401325848195298844802462252851926995846503104090589196060683329875231216529049681648909174047403783834364995363938741001507091534282239210301727771803410513303526378812888571225762557471133950393342500638551458868147905023198508660460641434022020257614450354085808398293279060446966692082427506909617283562394303716193372887306176319841941848888379308208426966697446699225783646634631703732019477632822374479322570142967559738439193417309205283438893083349863592921249218168590490390313109776446516881569691499831380592661740653935515397472059631417493981532","name":"25134437486609445980011967476486104706321061312022352268621323694861467756181853100693555519614894168921947814126694858839278103549577703105305116890325322098078409416441750313062396467567140699008203113519528887729951138845002409659317083029073793314514377377412805387401717457417895322600145580639449003584446356048213839274172751441145076183734269045919984853749007476629365146654240675320041155618450449041510280560040162429566008590065069477149918088087715269037925211599101597422023202484497946662159070023999719865939258557778022770035320019440597702090334486792710436579355608406897769514395306079855023848170","height":"59326960517737425423547279838932030505937927873589489863081026714907925093402287263487670945897247474465655528290016645774365383046524346223348261262488616342337864633104758662753452450299389775751012589698563659277683974188553993694220606310980581680471280640591973543996299789038056921309016983827578247477799948667666717056420270448516049047961099547588510086600581628091290215485826514170097211360599793229701811672966818089371089216189744274422526431130783428589346341196561742409198605034972210917502326180305735092988639850309253190875578501020679137562856724998821945605494355779034135306337094344532980411836"},"rctxt":"9641986614889199796257508700106896585587271615330980339636468819377346498767697681332046156705231986464570206666984343024200482683981302064613556104594051003956610353281701880542337665385482309134369756144345334575765116656633321636736946947493150642615481313285221467998414924865943067790561494301461899025374692884841352282256044388512875752628313052128404892424405230961678931620525106856624692942373538946467902799339061714326383378018581568876147181355325663707572429090278505823900491548970098691127791086305310899642155499128171811034581730190877600697624903963241473287185133286356124371104261592694271730029","z":"77594127026421654059198621152153180600664927707984020918609426112642522289621323453889995053400171879296098965678384769043918218957929606187082395048777546641833348694470081024386996548890150355901703252426977094536933434556202865213941384425538749866521536494046548509344678288447175898173634381514948562261015286492185924659638474376885655055568341574638453213864956407243206035973349529545863886325462867413885904072942842465859476940638839087894582648849969332663627779378998245133055807038199937421971988505911494931665143822588532097754480882750243126847177560978100527491344463525107644125030963904001009159559"},"public_key_revocation":null,"schema_seq_no":1,"signature_type":"CL"}"#; let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_xyz_schema_json(1)); let claim_defs_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, claim_def); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":{"revealed_attrs":{"name":"1139481716457488690172217916278103335"},"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988340","e":"13427639393364185909415877973872458621259927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274586162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843388153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"issuer_did":"NcYxiDXkpYi6ov5FcYDi1e","revoc_reg_seq_no":null}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let res = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } #[test] fn verifier_verify_proof_works_for_invalid_claim_defs() { AnoncredsUtils::init_common_wallet(); let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":1,"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#); let schemas_json = format!(r#"{{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{}}}"#, AnoncredsUtils::get_gvt_schema_json(1)); let claim_defs_json = format!("{{}}"); let revoc_regs_jsons = "{}"; let proof_json = r#"{"proofs":{"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd":{"proof":{"primary_proof":{"eq_proof":{"revealed_attrs":{"name":"1139481716457488690172217916278103335"},"a_prime":"47629821806628155353444789773246165920681315271529392722265555946090524267165563309836167110610840740533588118152308411732923636370660640410661034994521654033599863817144282118006097899736622728860229305231675970853294584911572355833537271010861501353858292189045263114095480601737776505186511389129055847562085611741257601964074827979121349153316235245772819207422031038042586202074331681302501661153569340935741290924699468188826629478130140797677338573924284871118002193526319478550852287453975107498037063076866410320160118555629090040954555043934303307652160345244864713226315470541231435958298648179413077988340","e":"13427639393364185909415877973872458621259927563729922146828001652769380799419438410309469022979920689628523901764614163117469683925816443","v":"852136445143816932026946294488424887907102968158908948827421962603492187508454543239422067899916472317305416590471170842186669606584356963437132366711335927890209765986844538775191207999204354235774464468525274918097404114453069375363594310105209141774763909570100638835926337238009617444858777301355087706167735590386774813901740600054753028260344014744801229032610106838480523182317262113911183640784111960909501662169298536941919854667754097841344375972975021196106884215734228415868248724905018661498061287694439466570946597514142085096419985189064172035527690786158872698717583830848410994616274586162550376126607414773916066374234063208380831144157533076866210628625236440222547584539349936639548061601416341705483504386186280800509889531835172071717956251546280392606775903107774727736794828168898273891724336881907672405328368540895104468091907771325910937575557566831844131159128453840354307814975621978196047820","m":{"age":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","height":"7064132689652704067914104576495132313294680087958177180391515757079548676035445873279966783996928425154050462229933823707574545166617858646442019030600136959459527533262821184869","sex":"16084497853957041205729191269508720470626311156190485518484640641677445098603656354458362520541393995692536218820724164533958162674375198846036330444513484319280148335515891811530"},"m1":"154906224259819061652290487122980839849626068919893070220438585977323162319993111920906032317552959103520053742608858935542877608981244065301675821390065831113115709272412144796159984624494428122971995557415296140268002332169405587907128359886810433617416529821500995701094400375272097687818064435577784795275","m2":"13805395408072590464827983892588030341708765524663545700917462089376137940485022437657208204460048097312372685954050370540389593952001973312378647790917367330461398089529292217752"},"ge_proofs":[{"u":{"1":"7698818972783845439601187851976452936638792889455287252542709653271706844173743185409084669157965935169942655008606334521674712818637940377261656468700786810566551698412412949418","0":"11703047052430512223413711314521545616119146623040600935686474696241801697819280425232876917607198335376453682738553665221410353412906194951254558355994401995990233992518110582450","3":"13210777821918317858818819091924507295018522783042111457450035423463340571245465760486275059291363621513532153389441883097799049597687545496359999443320001567152794884095192951040","2":"15219471780524079156861690098171693383497641272226737821992208834301871102152362116211452788300889697214391366996966539871625433480959011635688106136537800706217506402845296449689"},"r":{"1":"46043242109380749151527145850513330956077996622769158245225343392397735706292106535150958053995712629189143692293204979798837951212291825184346767969751978730000071952944305252032332015837054475531407691352179423131405515518588355918925056889302269768343499864256747177988825578647189563088068257214198650437730618330249172716051559993880468542083352885474175039320848153156858562341041960950299312991459780503345784440261679263045723337629951517601461685539857683027034345542399365706329805317943096391758978877658949910614447086409173234155028671453929715706057153381022697673192590033507204548864311227048268516889390503318015295207078022755834130221198717787608473222789491216667698651180077661375273569115943192","0":"135472587547410377947826119498467634347118057359097899596599164976338466445104141784869016998150489852448547539824768048351359572626675997498079394825940306636285481821620973655797996638210760710325933304918452142858879806106214845499670718704532018129553348815327362843246706518826311676917538452317818631484884032929252959289913274829848084561421467966320595980172006456003183536232790787521924655750157145207798486087511869939940023266736153366338179116840490184005332351004990854691988404031259910319601383696749511809898297656135548118786342107367065232798999979296280467063561892962526945512167505847049907450058650930480352253243357594344686769208712964458923557777584158831146374282687397585726706489164423632","DELTA":"93540839493959971552865423901789226093328763011922445919928571946113703515842729132879472109395228387208764738970926484618949870591214627692618668077375153559192701474693025462226656116549337248146652482501255820930607033869432220667968682424554711616471973627651716863421554516577716366331699848682958681216261888139409101603059124344125075525791543312721162515584942523419876134808829569829529457617639955678189490257208141837196965948342373022812790844435050648360150869293836349223060722858500537182872294143846213258360218898475766641125493477502149553491502593654061863323857297998048614447925371606038801933864960337435890254277043261512846682042139570000962051463878026338583242360548041329046695667868842400","3":"1227675452527605924725300993571504188580051470857656204064614533296779844072852823820754766175236321050062349182891221840452517985644028521499240739391613871973822807731772613052644168369405390658793869751915172749739844553410726807277698347769400977274750672880389943392076308065414059539317340070691852044062594715307024113666759844200606183662256825096857658837519571386467051003466014468855293015652584667669998830524947537781865745830650392641812221679438090257444660715937570193098993118585554478799821072396238689063767016402460690760792908977364175126682041704095200572282644311025594681667826054722587271200221036938804846621444065128275082392082327596239358623150786484106872933657139420542280145197712634108","2":"596248147592834822582469335300585333722415132713749620075902332764163096347819006925876158892694742461036531935093982309708492066217459300117157420442081698140277277546563570823996272914068575482008392971932777453900260626542725308060927710122631763045025742980634216666560934260634907599194353151523256914796667535940073668465664206971169038864484235442207811974981191879443614478897291543702607764944403808380921189291059195014621592027660463072969363556421687131446107696579365265893962197300447027501604372738056016734644378437907931412654753728514905671605635291285742886484416973884856055084605172305967034292646171874483670469193852404511746786039743401185954843446037600121496137915619789351744485264614840070"},"mj":"1117601261519431120446925325460734824239475567013636538481947258329666056692767097795046086413732472111811628751812987521644198549167671875326968410921589186689138994171774838662","alpha":"76727612740067576380015106087224381023260815407331375101920043509817863645705120013304683427627332447210083684516403565749916480947649443674885388155460323163682547865307733144184097845709556309570345707127872162476432029772452433292049079349274445907295491125915363620615679995457134810061392296263970553630102299601689685622244925494554558218277670233361938142224820526392365740420502452466959099546877778248089664282581792213376636587293479012783947088070052463503335266180110771978445892744225891676396288437005847308189508347446490710626231658457908472341606549292437553353163031111068977301305043175839949352742711874426231072729977019365761072816602400121302646283352164756787266537474728685656685493249314400351742964904006326192403855909148605656818024621453179832395687665671245528217931951331393482249182516107670379946496778373","t":{"1":"37203689290881948278188715497642400459048942241931994079434400288578680362970117779048886269388440270597283202033458042171954610700745461571112086648991639439510380585728148682202768590972068041537531136529323260832899360551065706810590032715173070285762675403853992183366951113799098912676809373169763887110420539387555392787590966452796271491986622992160642135480293110112269570862265489120557014181468118619500321000966443141863893743211690388599242584469856365803370202569641902205925191670838354052104480074127555862332399641076324738839120815544432811566503174551735326387678621283249883091766325861497740614317","3":"58486787977689017034592833190899828017343431922483563651969628402499947729293364026001243898136737211851089198526360764391403150763769829047179796728616126204105160762333590343947446892105646111520243793053992399512412375936746396187319527051818920531870855183738837254656664620975569939859368862778444291640228229744805843388153451336792379036403300211151424879060241580540910888241769468335914016289938374111481091198264912969768783884602931940994543804730631920434719776196148182987249363641941951160704928605829395517074202388967815738516252602903999010405305463910751219873354588685197134114358234107748126140977","0":"60771874648036182010335841594233428920565254732600738082343398028553347795361460295011584446745121430144172025428394361648540904134739046923992231536160801306934272250969829886396340824213814702904457884984387666505055153957942221822193548673145705543973635530652570436109428474727638128773540793530691399549837156239786231362112148914687724325416768262058486101761972044802628459748878200584371058300150212485731451700436345975266860685549673168984700174294811561393162860595319582236734968601457003780816977537443267217411297266600994916897237305128142313335280264655603445636393371224354539882875937093696844430903","DELTA":"32816484171372208266594641116109072545171919234551585018140151846920408763078147655907777031259225522515086979967895258126318315788662577171150780535509410112003001556402222994276811926864642497249250763185467678044678144507739529818566125668667424447792097244624010084189629269472698722402896445274092470014229247479740671263651727480322483037149584904549203417226525624083290572692241241259382947122018271686649224741832992966652878170311798126004447080305528487720923103595513611363001766063956060990267107048028416069435287244770875463867263571308182619338433913487209319707428378896314619624990311543563016697299","2":"36428320569485697540634597755814766104888687488985202673924762266313135133244610404742081973550848160712054769198012193456278135847215508952327879544434490828380496286187725750283788811367824465072001959950807751252194618152990469069074061195618692339915840384087350671392595652921761835083158086795163935060896053332506433434451836095710383871272788002621913967538399141417857031787255744141437237474972197102809365346359345477248611632307159641948507043668113827177494748159094045928919209335044052792843664865311991178972383241855607627188111601119780878072683890170539599447876998109080150992209773901144245398001"},"predicate":{"attr_name":"age","p_type":"GE","value":18}}]},"non_revoc_proof":null},"issuer_did":"NcYxiDXkpYi6ov5FcYDi1e","revoc_reg_seq_no":null}},"aggregated_proof":{"c_hash":"33103550379681684069592829341967479618752165928802550870585275205292715916069","c_list":[[1,121,77,5,144,154,14,192,190,190,145,180,128,71,22,60,168,20,46,163,139,194,71,165,220,188,121,76,25,146,231,114,65,54,69,68,19,200,250,192,47,123,157,132,74,50,28,69,226,195,243,118,45,63,237,197,216,202,206,101,33,56,225,200,128,3,89,12,182,38,113,221,165,119,228,201,156,201,172,136,59,64,51,72,164,198,49,228,223,117,80,64,166,226,37,8,29,146,186,80,210,119,76,252,4,255,62,218,112,163,164,147,247,190,108,76,140,191,76,217,214,184,152,179,193,149,15,70,197,46,90,60,255,247,197,219,252,73,76,0,125,104,114,22,182,161,110,36,162,103,27,42,88,18,161,237,198,43,177,189,181,86,135,207,71,114,0,26,175,12,199,125,25,124,178,87,36,208,251,15,191,127,202,148,152,43,142,92,191,7,89,153,130,195,223,248,176,109,97,164,126,162,181,124,237,130,155,197,66,59,40,197,72,84,32,100,64,55,227,60,214,143,200,200,89,115,236,172,145,56,100,73,20,242,233,95,130,58,112,153,120,115,119,42,199,30,205,88,223,42,196,184,41,19,100,19,244],[1,225,103,238,42,147,91,191,110,69,154,53,57,156,124,43,174,155,76,202,193,98,128,38,207,126,66,70,161,96,109,127,174,44,203,198,177,238,118,117,89,227,170,155,44,251,35,119,219,29,100,173,26,144,95,50,177,4,40,234,117,174,210,192,172,57,160,198,42,199,212,243,240,114,59,91,207,68,57,38,198,2,73,18,16,209,182,145,206,71,17,69,222,49,36,120,72,117,169,107,238,208,235,216,24,183,201,81,15,83,242,45,136,184,166,26,142,136,228,58,229,235,88,169,238,134,205,96,85,9,122,53,147,100,183,114,92,54,125,178,125,75,127,116,50,88,109,152,22,4,121,252,190,18,190,130,143,138,59,231,38,131,176,54,19,194,218,67,144,122,91,43,86,73,233,48,193,30,183,183,191,238,216,167,101,28,185,43,118,64,242,16,62,239,177,27,109,144,67,221,175,202,4,92,130,74,24,20,151,15,227,225,142,71,145,46,192,248,87,57,183,142,253,52,20,56,153,220,234,25,67,116,225,179,211,116,161,37,64,34,48,155,1,1,159,157,37,31,202,19,229,152,23,138,183,126,55],[1,38,181,193,191,72,2,239,34,83,49,36,179,160,82,112,172,98,255,63,60,22,177,249,67,215,220,198,181,7,49,254,133,243,221,214,47,64,229,82,11,94,175,57,86,152,229,192,184,96,136,116,226,123,128,217,23,244,19,204,36,44,123,208,88,24,217,120,145,139,25,233,227,5,119,90,47,147,1,115,92,39,119,194,167,17,229,39,163,167,237,14,116,234,106,252,216,54,33,233,21,54,183,130,144,161,177,142,177,240,51,73,21,202,188,103,244,153,204,219,123,231,139,135,189,155,143,28,4,180,44,148,0,27,103,26,13,203,31,32,166,67,84,87,23,72,234,236,20,1,84,70,86,76,192,164,235,124,86,128,78,230,119,155,95,121,125,20,244,181,121,250,169,9,67,85,213,177,139,111,187,183,114,165,249,177,161,181,175,46,226,66,86,84,124,86,69,143,217,158,161,30,107,133,44,239,89,209,24,150,1,238,122,144,138,179,121,114,90,13,212,209,60,126,37,62,177,180,131,222,168,2,201,156,169,220,224,53,8,203,220,215,163,104,195,184,73,35,241,182,177,80,41,253,230,90,173],[1,32,145,96,219,241,190,19,195,129,219,50,148,152,107,12,189,225,103,171,149,252,193,243,136,132,195,44,19,20,247,140,160,91,230,78,31,242,85,213,65,185,1,91,12,69,118,80,26,135,102,131,4,108,130,230,83,91,176,249,196,56,128,127,82,72,106,49,211,94,133,40,86,72,42,187,199,216,191,223,208,206,121,118,15,167,255,228,57,206,158,217,64,205,212,178,8,248,129,183,221,98,70,54,37,55,47,81,120,59,186,238,165,0,70,173,137,193,232,180,125,211,237,182,249,191,173,107,129,164,148,231,116,225,66,66,71,156,39,248,164,253,234,140,205,177,140,117,47,21,15,242,31,113,118,91,143,89,213,86,143,135,21,46,35,199,214,107,111,65,65,19,26,171,130,16,19,102,145,210,210,61,51,169,148,169,118,182,106,107,253,100,214,232,52,103,180,96,249,254,71,6,11,119,48,129,213,223,205,93,20,117,26,187,32,151,212,137,203,17,237,208,150,72,23,225,235,122,188,34,105,115,0,160,168,251,191,22,242,238,207,74,142,154,66,94,149,191,215,194,134,6,165,244,167,233,241],[1,207,77,250,146,127,242,229,44,172,182,201,183,242,32,242,182,129,233,10,8,180,23,191,163,21,238,158,5,27,216,146,253,173,127,99,95,168,209,132,242,196,242,34,25,25,249,211,51,236,164,153,175,61,65,150,82,251,174,102,186,47,195,82,44,90,252,184,74,89,251,177,254,108,151,136,230,220,93,224,173,247,244,116,132,59,170,215,194,30,87,84,166,147,57,156,201,207,132,203,222,191,253,15,19,228,173,81,156,4,51,121,227,159,50,18,148,129,205,42,42,227,252,138,62,176,115,227,253,52,125,110,178,167,132,244,14,116,195,194,172,44,45,63,38,121,215,136,68,230,21,108,133,159,197,179,94,78,233,107,236,114,92,165,248,22,124,161,23,142,236,224,175,233,134,25,97,150,131,61,220,203,104,154,199,247,146,47,205,56,209,0,133,132,18,103,136,8,202,37,29,100,105,12,232,74,33,6,255,202,96,170,52,229,244,4,235,2,201,125,86,168,179,224,130,81,54,221,185,184,187,141,0,114,98,38,70,225,228,60,157,53,210,238,60,216,215,154,48,73,3,157,192,245,81,170,49],[1,3,244,229,158,71,18,146,198,202,27,2,231,37,13,145,243,84,112,220,61,174,4,175,104,200,64,146,193,20,174,126,42,157,168,76,165,21,50,216,82,211,180,73,244,54,227,200,19,157,25,228,81,37,64,201,19,138,175,50,246,169,11,45,74,194,131,236,127,177,41,242,130,55,112,182,98,22,99,48,153,83,161,250,65,89,3,97,6,5,171,54,223,87,98,103,23,200,212,177,140,155,151,252,125,45,176,55,92,41,56,2,252,32,149,60,3,168,209,193,23,168,230,182,72,193,230,224,5,15,58,63,93,196,33,93,76,188,30,70,31,136,64,204,223,2,230,210,243,255,135,193,52,132,248,160,22,18,164,71,77,80,112,229,120,116,210,225,2,19,139,35,0,214,5,246,9,106,136,204,0,148,97,21,222,153,57,177,162,11,243,252,7,242,34,239,245,50,104,74,221,92,73,13,142,10,184,250,246,167,240,46,230,86,207,181,12,133,81,119,143,164,88,114,223,243,179,208,175,84,161,27,11,225,36,37,177,112,85,81,184,163,223,159,36,9,247,20,13,230,215,108,117,35,99,117,211]]},"requested_proof":{"revealed_attrs":{"attr1_uuid":["claim::277478db-bf57-42c3-8530-b1b13cfe0bfd","Alex","1139481716457488690172217916278103335"]},"unrevealed_attrs":{},"self_attested_attrs":{},"predicates":{"predicate1_uuid":"claim::277478db-bf57-42c3-8530-b1b13cfe0bfd"}}}"#; let res = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); } } } mod demos { use super::*; #[cfg(feature = "interoperability_tests")] use utils::types::ClaimDefinitionData; #[cfg(feature = "interoperability_tests")] use std::process::Command; #[cfg(feature = "interoperability_tests")] use std::io::prelude::*; #[cfg(feature = "interoperability_tests")] use std::net::TcpStream; #[cfg(feature = "interoperability_tests")] use std::{thread, time}; #[cfg(feature = "interoperability_tests")] #[test] fn interoperability_test_pysovrin_is_issuer() { TestUtils::cleanup_storage(); let pool_name = "pool1"; let xtype = "default"; //1. Create Prover wallet, get wallet handle let prover_wallet_handle = WalletUtils::create_and_open_wallet(pool_name, Some(xtype)).unwrap(); let schema_seq_no = 1; let schema = AnoncredsUtils::get_gvt_schema_json(schema_seq_no); //2. Prover create Master Secret let master_secret_name = "prover_master_secret"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name).unwrap(); //3. Prover store Claim Offer received from Issuer let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &claim_offer_json).unwrap(); //4. Prover get Claim Offers let filter_json = format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID); let claim_offers_json = AnoncredsUtils::prover_get_claim_offers(prover_wallet_handle, &filter_json).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers_json).unwrap(); assert!(claim_offers.len() == 1); let claim_offer_json = serde_json::to_string(&claim_offers[0]).unwrap(); Command::new("python3") .arg("/home/indy/indy-anoncreds/anoncreds/test/test_interoperability_with_libsovrin_pysovrin_is_issuer.py") .spawn().expect("failed to execute process"); thread::sleep(time::Duration::from_millis(3000)); let mut stream = TcpStream::connect("127.0.0.1:1234").unwrap(); let _ = stream.write(r#"{"type":"get_claim_def"}"#.as_bytes()); let mut buf = vec![0; 10240]; stream.read(&mut buf).unwrap(); buf.retain(|&element| element != 0); let claim_def_data: ClaimDefinitionData = serde_json::from_str(&String::from_utf8(buf).unwrap()).unwrap(); let claim_def = ClaimDefinition { issuer_did: ISSUER_DID.to_string(), signature_type: "CL".to_string(), schema_seq_no: schema_seq_no, data: claim_def_data }; let claim_def_json = serde_json::to_string(&claim_def).unwrap(); //5. Prover create Claim Request let prover_did = "BzfFCYk"; let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer_json, &claim_def_json, master_secret_name).unwrap(); let _ = stream.write(format!(r#"{{"type":"issue_claim", "data": {}}}"#, claim_req).as_bytes()); let mut buf = vec![0; 10240]; stream.read(&mut buf).unwrap(); let _ = stream.write(r#"{"type":"close"}"#.as_bytes()); buf.retain(|&element| element != 0); let mut claim_json: ClaimJson = serde_json::from_str(&String::from_utf8(buf).unwrap()).unwrap(); claim_json.schema_seq_no = Some(schema_seq_no); claim_json.issuer_did = Some(ISSUER_DID.to_string()); // 6. Prover store received Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &serde_json::to_string(&claim_json).unwrap()).unwrap(); // 7. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}, "attr2_uuid":{{"schema_seq_no":{},"name":"sex"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#, schema_seq_no, schema_seq_no); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(prover_wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); info!("claims_json: {}", &claims_json); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(1, claims_for_attr_1.len()); let claim = claims_for_attr_1[0].clone(); // 8. Prover create Proof let self_attested_value = "value"; let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{"self1":"{}"}}, "requested_attrs":{{"attr1_uuid":["{}",true], "attr2_uuid":["{}", false]}}, "requested_predicates":{{"predicate1_uuid":"{}"}} }}"#, self_attested_value, claim.claim_uuid, claim.claim_uuid, claim.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, schema); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(prover_wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name, &claim_defs_json, &revoc_regs_jsons).unwrap(); let proof: ProofJson = serde_json::from_str(&proof_json).unwrap(); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr1_uuid").unwrap(); assert_eq!(value, "Alex"); proof.requested_proof.unrevealed_attrs.get("attr2_uuid").unwrap(); let value = proof.requested_proof.self_attested_attrs.get("self1").unwrap(); assert_eq!(value, self_attested_value); // 9. Verifier verify proof let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); TestUtils::cleanup_storage(); } #[cfg(feature = "interoperability_tests")] #[test] fn interoperability_test_pysovrin_is_verifier() { TestUtils::cleanup_storage(); let pool_name = "pool1"; let xtype = "default"; //1. Create Issuer wallet, get wallet handle let issuer_wallet_handle = WalletUtils::create_and_open_wallet(pool_name, Some(xtype)).unwrap(); //2. Create Prover wallet, get wallet handle let prover_wallet_handle = WalletUtils::create_and_open_wallet(pool_name, Some(xtype)).unwrap(); //3. Issuer create claim definition let schema_seq_no = 1; let schema = AnoncredsUtils::get_gvt_schema_json(schema_seq_no); let claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_wallet_handle, &ISSUER_DID, &schema, None, false).unwrap(); Command::new("python3") .arg("/home/indy/indy-anoncreds/anoncreds/test/test_interoperability_with_libsovrin_pysovrin_is_verifier.py") .spawn().expect("failed to execute process"); thread::sleep(time::Duration::from_millis(3000)); let mut stream = TcpStream::connect("127.0.0.1:1234").unwrap(); let _ = stream.write(format!(r#"{{"type":"receive_claim_def", "data": {}}}"#, claim_def_json).as_bytes()); //4. Prover create Master Secret let master_secret_name = "prover_master_secret"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name).unwrap(); //5. Prover store Claim Offer received from Issuer let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &claim_offer_json).unwrap(); //6. Prover get Claim Offers let filter_json = format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID); let claim_offers_json = AnoncredsUtils::prover_get_claim_offers(prover_wallet_handle, &filter_json).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers_json).unwrap(); assert!(claim_offers.len() == 1); let claim_offer_json = serde_json::to_string(&claim_offers[0]).unwrap(); //7. Prover create Claim Request let prover_did = "BzfFCYk"; let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer_json, &claim_def_json, master_secret_name).unwrap(); //8. Issuer create Claim let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, xclaim_json) = AnoncredsUtils::issuer_create_claim(issuer_wallet_handle, &claim_req, &claim_json).unwrap(); // 9. Prover store received Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &xclaim_json).unwrap(); let _ = stream.write(r#"{"type":"get_proof_request"}"#.as_bytes()); let mut buf = vec![0; 10240]; stream.read(&mut buf).unwrap(); buf.retain(|&element| element != 0); let proof_req_json = String::from_utf8(buf).unwrap(); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(prover_wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr = claims.attrs.get("attr_uuid").unwrap(); assert_eq!(1, claims_for_attr.len()); let claim = claims_for_attr[0].clone(); // 11. Prover create Proof let self_attested_value = "value"; let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{"self1":"{}"}}, "requested_attrs":{{"attr_uuid":["{}",true]}}, "requested_predicates":{{"predicate_uuid":"{}"}} }}"#, self_attested_value, claim.claim_uuid, claim.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, schema); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(prover_wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name, &claim_defs_json, &revoc_regs_jsons).unwrap(); let _ = stream.write(format!(r#"{{"type":"check_proof", "data": {}}}"#, proof_json).as_bytes()); let mut buf = vec![0; 102400]; stream.read(&mut buf).unwrap(); let _ = stream.write(r#"{"type":"close"}"#.as_bytes()); buf.retain(|&element| element != 0); let valid = String::from_utf8(buf).unwrap(); assert_eq!("true", valid); TestUtils::cleanup_storage(); } #[cfg(feature = "interoperability_tests")] #[test] fn interoperability_test_pysovrin_is_prover() { TestUtils::cleanup_storage(); let schema_seq_no = 1; let schema = AnoncredsUtils::get_gvt_schema_json(schema_seq_no); Command::new("python3") .arg("/home/indy/indy-anoncreds/anoncreds/test/test_interoperability_with_libsovrin_pysovrin_is_prover.py") .spawn().expect("failed to execute process"); thread::sleep(time::Duration::from_millis(3000)); let mut stream = TcpStream::connect("127.0.0.1:1234").unwrap(); let _ = stream.write(r#"{"type":"get_claim_def"}"#.as_bytes()); let mut buf = vec![0; 10240]; stream.read(&mut buf).unwrap(); buf.retain(|&element| element != 0); let claim_def_data: ClaimDefinitionData = serde_json::from_str(&String::from_utf8(buf).unwrap()).unwrap(); let claim_def = ClaimDefinition { issuer_did: ISSUER_DID.to_string(), signature_type: "CL".to_string(), schema_seq_no: schema_seq_no, data: claim_def_data }; let claim_def_json = serde_json::to_string(&claim_def).unwrap(); // 7. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr_uuid":{{"schema_seq_no":{},"name":"name"}}}}, "requested_predicates":{{"predicate_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#, schema_seq_no); let _ = stream.write(format!(r#"{{"type":"get_proof", "data": {}}}"#, proof_req_json).as_bytes()); let mut buf = vec![0; 102400]; stream.read(&mut buf).unwrap(); buf.retain(|&element| element != 0); let proof: ProofJson = serde_json::from_str(&String::from_utf8(buf).unwrap()).unwrap(); println!("proof: {:?}", proof); let _ = stream.write(r#"{"type":"close"}"#.as_bytes()); let schemas_json = format!(r#"{{"{}":{}}}"#, 1, schema); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr_uuid").unwrap(); assert_eq!(value, "Alex"); let proof_json = serde_json::to_string(&proof).unwrap(); let claim_defs_json = format!(r#"{{"{}":{}}}"#, 1, claim_def_json); let revoc_regs_jsons = "{}"; // 9. Verifier verify proof let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); TestUtils::cleanup_storage(); } #[test] fn verifier_verify_proof_works_for_proof_does_not_correspond_proof_request() { TestUtils::cleanup_storage(); //1. Create wallet, get wallet handle let wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //2. Issuer create claim definition let schema_seq_no = 1; let schema = AnoncredsUtils::get_gvt_schema_json(schema_seq_no); let claim_def_json = AnoncredsUtils::issuer_create_claim_definition(wallet_handle, &ISSUER_DID, &schema, None, false).unwrap(); //3. Prover create Master Secret let master_secret_name = "prover_master_secret"; AnoncredsUtils::prover_create_master_secret(wallet_handle, master_secret_name).unwrap(); //4. Prover create Claim Request let prover_did = "BzfFCYk"; let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, schema_seq_no); let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(wallet_handle, prover_did, &claim_offer_json, &claim_def_json, master_secret_name).unwrap(); //5. Issuer create Claim let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, xclaim_json) = AnoncredsUtils::issuer_create_claim(wallet_handle, &claim_req, &claim_json).unwrap(); // 6. Prover store received Claim AnoncredsUtils::prover_store_claim(wallet_handle, &xclaim_json).unwrap(); // 7. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}}}, "requested_predicates":{{}} }}"#, schema_seq_no); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); let claim = claims_for_attr_1[0].clone(); // 8. Prover create Proof let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{}} }}"#, claim.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, schema); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name, &claim_defs_json, &revoc_regs_jsons).unwrap(); // 9. Verifier verify proof let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#, schema_seq_no); let res = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons); assert_eq!(res.unwrap_err(), ErrorCode::CommonInvalidStructure); TestUtils::cleanup_storage(); } #[test] fn anoncreds_works_for_single_issuer_single_prover() { TestUtils::cleanup_storage(); //1. Create Issuer wallet, get wallet handle let issuer_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //2. Create Prover wallet, get wallet handle let prover_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //3. Issuer create claim definition let schema_seq_no = 1; let schema = AnoncredsUtils::get_gvt_schema_json(schema_seq_no); let claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_wallet_handle, &ISSUER_DID, &schema, None, false).unwrap(); //4. Prover create Master Secret let master_secret_name = "prover_master_secret"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name).unwrap(); //5. Prover store Claim Offer received from Issuer let claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &claim_offer_json).unwrap(); //6. Prover get Claim Offers let filter_json = format!(r#"{{"issuer_did":"{}"}}"#, ISSUER_DID); let claim_offers_json = AnoncredsUtils::prover_get_claim_offers(prover_wallet_handle, &filter_json).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers_json).unwrap(); assert!(claim_offers.len() == 1); let claim_offer_json = serde_json::to_string(&claim_offers[0]).unwrap(); //7. Prover create Claim Request let prover_did = "BzfFCYk"; let claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer_json, &claim_def_json, master_secret_name).unwrap(); //8. Issuer create Claim let claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, xclaim_json) = AnoncredsUtils::issuer_create_claim(issuer_wallet_handle, &claim_req, &claim_json).unwrap(); // 9. Prover store received Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &xclaim_json).unwrap(); // 10. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}, "attr2_uuid":{{"schema_seq_no":{},"name":"sex"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}}} }}"#, schema_seq_no, schema_seq_no); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(prover_wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); info!("claims_json: {}", &claims_json); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(1, claims_for_attr_1.len()); let claim = claims_for_attr_1[0].clone(); // 11. Prover create Proof let self_attested_value = "value"; let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{"self1":"{}"}}, "requested_attrs":{{"attr1_uuid":["{}", true], "attr2_uuid":["{}", false]}}, "requested_predicates":{{"predicate1_uuid":"{}"}} }}"#, self_attested_value, claim.claim_uuid, claim.claim_uuid, claim.claim_uuid); let schemas_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, schema); let claim_defs_json = format!(r#"{{"{}":{}}}"#, claim.claim_uuid, claim_def_json); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(prover_wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name, &claim_defs_json, &revoc_regs_jsons).unwrap(); let proof: ProofJson = serde_json::from_str(&proof_json).unwrap(); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr1_uuid").unwrap(); assert_eq!(value, "Alex"); proof.requested_proof.unrevealed_attrs.get("attr2_uuid").unwrap(); let value = proof.requested_proof.self_attested_attrs.get("self1").unwrap(); assert_eq!(value, self_attested_value); // 12. Verifier verify proof let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); TestUtils::cleanup_storage(); } #[test] fn anoncreds_works_for_multiply_issuer_single_prover() { TestUtils::cleanup_storage(); let issuer2_did = "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW"; let prover_did = "BzfFCYk"; //1. Issuer1 create wallet, get wallet handles let issuer_gvt_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //2. Issuer2 create wallet, get wallet handles let issuer_xyz_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //3. Prover create wallet, get wallet handles let prover_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); let mut schemas: HashMap = HashMap::new(); let mut claim_defs: HashMap = HashMap::new(); //4. Issuer1 create claim definition by gvt schema let gvt_schema_seq_no = 1; let gvt_schema = AnoncredsUtils::get_gvt_schema_json(gvt_schema_seq_no); let gvt_claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_gvt_wallet_handle, &ISSUER_DID, &gvt_schema, None, false).unwrap(); schemas.insert(gvt_schema_seq_no, gvt_schema.clone()); claim_defs.insert(ISSUER_DID.to_string(), gvt_claim_def_json.clone()); //5. Issuer2 create claim definition by xyz schema let xyz_schema_seq_no = 2; let xyz_schema = AnoncredsUtils::get_xyz_schema_json(xyz_schema_seq_no); let xyz_claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_xyz_wallet_handle, &issuer2_did, &xyz_schema, None, false).unwrap(); schemas.insert(xyz_schema_seq_no, xyz_schema.clone()); claim_defs.insert(issuer2_did.to_string(), xyz_claim_def_json.clone()); //6. Prover create Master Secret for Issuer1 let master_secret_name_1 = "prover_master_secret_issuer_1"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name_1).unwrap(); //7. Prover create Master Secret for Issuer2 let master_secret_name_2 = "prover_master_secret_issuer_2"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name_2).unwrap(); //8. Prover store Claim Offer received from Issuer1 let issuer1_claim_offer_json = AnoncredsUtils::get_claim_offer(ISSUER_DID, gvt_schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &issuer1_claim_offer_json).unwrap(); //9. Prover store Claim Offer received from Issuer2 let issuer2_claim_offer_json = AnoncredsUtils::get_claim_offer(issuer2_did, xyz_schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &issuer2_claim_offer_json).unwrap(); //10. Prover get Claim Offers let filter_json = "{}"; let claim_offers_json = AnoncredsUtils::prover_get_claim_offers(prover_wallet_handle, &filter_json).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers_json).unwrap(); assert_eq!(2, claim_offers.len()); let claim_offer_1 = claim_offers[0].clone(); let claim_offer_2 = claim_offers[1].clone(); let claim_offer_1_json = serde_json::to_string(&claim_offer_1).unwrap(); let claim_offer_2_json = serde_json::to_string(&claim_offer_2).unwrap(); //11. Prover create Claim Request for gvt claim offer let claim_offer = if claim_offer_1.issuer_did == ISSUER_DID { claim_offer_1_json.clone() } else { claim_offer_2_json.clone() }; let gvt_claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer, &gvt_claim_def_json, master_secret_name_1).unwrap(); //12. Issuer create GVT Claim let gvt_claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, gvt_claim_json) = AnoncredsUtils::issuer_create_claim(issuer_gvt_wallet_handle, &gvt_claim_req, &gvt_claim_json).unwrap(); //13. Prover store received GVT Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &gvt_claim_json).unwrap(); //14. Prover create Claim Request for xyz claim offer let claim_offer = if claim_offer_2.issuer_did == issuer2_did { claim_offer_2_json.clone() } else { claim_offer_1_json.clone() }; let xyz_claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer, &xyz_claim_def_json, master_secret_name_1).unwrap(); //15. Issuer create XYZ Claim let xyz_claim_json = AnoncredsUtils::get_xyz_claim_json(); let (_, xyz_claim_json) = AnoncredsUtils::issuer_create_claim(issuer_xyz_wallet_handle, &xyz_claim_req, &xyz_claim_json).unwrap(); // 16. Prover store received XYZ Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &xyz_claim_json).unwrap(); // 17. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}, "attr2_uuid":{{"schema_seq_no":{},"name":"status"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}, "predicate2_uuid":{{"attr_name":"period","p_type":"GE","value":5}}}} }}"#, gvt_schema_seq_no, xyz_schema_seq_no); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(prover_wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); let claims_for_attr_2 = claims.attrs.get("attr2_uuid").unwrap(); assert_eq!(1, claims_for_attr_1.len()); assert_eq!(1, claims_for_attr_2.len()); let claim_for_attr_1 = claims_for_attr_1[0].clone(); let claim_for_attr_2 = claims_for_attr_2[0].clone(); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); let claims_for_predicate_2 = claims.predicates.get("predicate2_uuid").unwrap(); assert_eq!(1, claims_for_predicate_1.len()); assert_eq!(1, claims_for_predicate_2.len()); let claim_for_predicate_1 = claims_for_predicate_1[0].clone(); let claim_for_predicate_2 = claims_for_predicate_2[0].clone(); // 18. Prover create Proof let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true], "attr2_uuid":["{}",true]}}, "requested_predicates":{{"predicate1_uuid":"{}", "predicate2_uuid":"{}"}} }}"#, claim_for_attr_1.claim_uuid, claim_for_attr_2.claim_uuid, claim_for_predicate_1.claim_uuid, claim_for_predicate_2.claim_uuid); let unique_claims = AnoncredsUtils::get_unique_claims(&claims); let schemas_json = format!(r#"{{"{}":{},"{}":{}}}"#, unique_claims[0].claim_uuid, schemas.get(&unique_claims[0].schema_seq_no).unwrap(), unique_claims[1].claim_uuid, schemas.get(&unique_claims[1].schema_seq_no).unwrap()); let claim_defs_json = format!(r#"{{"{}":{},"{}":{}}}"#, unique_claims[0].claim_uuid, claim_defs.get(&unique_claims[0].issuer_did).unwrap(), unique_claims[1].claim_uuid, claim_defs.get(&unique_claims[1].issuer_did).unwrap()); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(prover_wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name_1, &claim_defs_json, &revoc_regs_jsons).unwrap(); let proof: ProofJson = serde_json::from_str(&proof_json).unwrap(); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr1_uuid").unwrap(); assert_eq!(value, "Alex"); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr2_uuid").unwrap(); assert_eq!(value, "partial"); // 19. Verifier verify proof let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); TestUtils::cleanup_storage(); } #[test] fn anoncreds_works_for_single_issuer_multiply_claims_single_prover() { TestUtils::cleanup_storage(); let issuer_did = "CnEDk9HrMnmiHXEV1WFgbVCRteYnPqsJwrTdcZaNhFVW"; let prover_did = "BzfFCYk"; //1. Issuer create wallet, get wallet handles let issuer_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); //2. Prover create wallet, get wallet handles let prover_wallet_handle = WalletUtils::create_and_open_wallet("pool1", None).unwrap(); let mut schemas: HashMap = HashMap::new(); let mut claim_defs: HashMap = HashMap::new(); //3. Issuer create claim definition by gvt schema let gvt_schema_seq_no = 1; let gvt_schema = AnoncredsUtils::get_gvt_schema_json(gvt_schema_seq_no); let gvt_claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_wallet_handle, &issuer_did, &gvt_schema, None, false).unwrap(); schemas.insert(gvt_schema_seq_no, gvt_schema.clone()); claim_defs.insert(AnoncredsUtils::get_claim_def_id(issuer_did, gvt_schema_seq_no), gvt_claim_def_json.clone()); //4. Issuer create claim definition by xyz schema let xyz_schema_seq_no = 2; let xyz_schema = AnoncredsUtils::get_xyz_schema_json(xyz_schema_seq_no); let xyz_claim_def_json = AnoncredsUtils::issuer_create_claim_definition(issuer_wallet_handle, &issuer_did, &xyz_schema, None, false).unwrap(); schemas.insert(xyz_schema_seq_no, xyz_schema.clone()); claim_defs.insert(AnoncredsUtils::get_claim_def_id(issuer_did, xyz_schema_seq_no), xyz_claim_def_json.clone()); //5. Prover create Master Secret for Issuer1 let master_secret_name = "prover_master_secret_issuer"; AnoncredsUtils::prover_create_master_secret(prover_wallet_handle, master_secret_name).unwrap(); //6. Prover store GVT Claim Offer received from Issuer let issuer_claim_offer_json = AnoncredsUtils::get_claim_offer(issuer_did, gvt_schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &issuer_claim_offer_json).unwrap(); //7. Prover store XYZ Claim Offer received from Issuer let issuer_claim_offer_json = AnoncredsUtils::get_claim_offer(issuer_did, xyz_schema_seq_no); AnoncredsUtils::prover_store_claim_offer(prover_wallet_handle, &issuer_claim_offer_json).unwrap(); //8. Prover get Claim Offers let filter_json = format!(r#"{{"issuer_did":"{}"}}"#, issuer_did); let claim_offers_json = AnoncredsUtils::prover_get_claim_offers(prover_wallet_handle, &filter_json).unwrap(); let claim_offers: Vec = serde_json::from_str(&claim_offers_json).unwrap(); assert_eq!(2, claim_offers.len()); let claim_offer_1 = claim_offers[0].clone(); let claim_offer_2 = claim_offers[1].clone(); let claim_offer_1_json = serde_json::to_string(&claim_offer_1).unwrap(); let claim_offer_2_json = serde_json::to_string(&claim_offer_2).unwrap(); //9. Prover create Claim Request for gvt claim offer let claim_offer = if claim_offer_1.schema_seq_no == gvt_schema_seq_no { claim_offer_1_json.clone() } else { claim_offer_2_json.clone() }; let gvt_claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer, &gvt_claim_def_json, master_secret_name).unwrap(); //10. Issuer create GVT Claim let gvt_claim_json = AnoncredsUtils::get_gvt_claim_json(); let (_, gvt_claim_json) = AnoncredsUtils::issuer_create_claim(issuer_wallet_handle, &gvt_claim_req, &gvt_claim_json).unwrap(); //11. Prover store received GVT Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &gvt_claim_json).unwrap(); //12. Prover create Claim Request for xyz claim offer let claim_offer = if claim_offer_2.schema_seq_no == xyz_schema_seq_no { claim_offer_2_json.clone() } else { claim_offer_1_json.clone() }; let xyz_claim_req = AnoncredsUtils::prover_create_and_store_claim_req(prover_wallet_handle, prover_did, &claim_offer, &xyz_claim_def_json, master_secret_name).unwrap(); //13. Issuer create XYZ Claim let xyz_claim_json = AnoncredsUtils::get_xyz_claim_json(); let (_, xyz_claim_json) = AnoncredsUtils::issuer_create_claim(issuer_wallet_handle, &xyz_claim_req, &xyz_claim_json).unwrap(); //14. Prover store received XYZ Claim AnoncredsUtils::prover_store_claim(prover_wallet_handle, &xyz_claim_json).unwrap(); //15. Prover gets Claims for Proof Request let proof_req_json = format!(r#"{{ "nonce":"123432421212", "name":"proof_req_1", "version":"0.1", "requested_attrs":{{"attr1_uuid":{{"schema_seq_no":{},"name":"name"}}}}, "requested_predicates":{{"predicate1_uuid":{{"attr_name":"age","p_type":"GE","value":18}}, "predicate2_uuid":{{"attr_name":"period","p_type":"GE","value":5}}}} }}"#, gvt_schema_seq_no); let claims_json = AnoncredsUtils::prover_get_claims_for_proof_req(prover_wallet_handle, &proof_req_json).unwrap(); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); assert_eq!(1, claims.attrs.len()); assert_eq!(2, claims.predicates.len()); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); assert_eq!(1, claims_for_attr_1.len()); let claim_for_attr_1 = claims_for_attr_1[0].clone(); let claims_for_predicate_1 = claims.predicates.get("predicate1_uuid").unwrap(); let claims_for_predicate_2 = claims.predicates.get("predicate2_uuid").unwrap(); assert_eq!(1, claims_for_predicate_1.len()); assert_eq!(1, claims_for_predicate_2.len()); let claim_for_predicate_1 = claims_for_predicate_1[0].clone(); let claim_for_predicate_2 = claims_for_predicate_2[0].clone(); //16. Prover create Proof let requested_claims_json = format!(r#"{{ "self_attested_attributes":{{}}, "requested_attrs":{{"attr1_uuid":["{}",true]}}, "requested_predicates":{{"predicate1_uuid":"{}", "predicate2_uuid":"{}"}} }}"#, claim_for_attr_1.claim_uuid, claim_for_predicate_1.claim_uuid, claim_for_predicate_2.claim_uuid); let unique_claims = AnoncredsUtils::get_unique_claims(&claims); let schemas_json = format!(r#"{{"{}":{},"{}":{}}}"#, unique_claims[0].claim_uuid, schemas.get(&unique_claims[0].schema_seq_no).unwrap(), unique_claims[1].claim_uuid, schemas.get(&unique_claims[1].schema_seq_no).unwrap()); let claim_def_id1 = AnoncredsUtils::get_claim_def_id(&unique_claims[0].issuer_did, unique_claims[0].schema_seq_no); let claim_def_id2 = AnoncredsUtils::get_claim_def_id(&unique_claims[1].issuer_did, unique_claims[1].schema_seq_no); let claim_defs_json = format!(r#"{{"{}":{},"{}":{}}}"#, unique_claims[0].claim_uuid, claim_defs.get(&claim_def_id1).unwrap(), unique_claims[1].claim_uuid, claim_defs.get(&claim_def_id2).unwrap()); let revoc_regs_jsons = "{}"; let proof_json = AnoncredsUtils::prover_create_proof(prover_wallet_handle, &proof_req_json, &requested_claims_json, &schemas_json, &master_secret_name, &claim_defs_json, &revoc_regs_jsons).unwrap(); let proof: ProofJson = serde_json::from_str(&proof_json).unwrap(); let &(_, ref value, _) = proof.requested_proof.revealed_attrs.get("attr1_uuid").unwrap(); assert_eq!(value, "Alex"); //17. Verifier verify proof let valid = AnoncredsUtils::verifier_verify_proof(&proof_req_json, &proof_json, &schemas_json, &claim_defs_json, &revoc_regs_jsons).unwrap(); assert!(valid); TestUtils::cleanup_storage(); } }