// -*- coding: utf-8; mode: rust; -*- // // To the extent possible under law, the authors have waived all // copyright and related or neighboring rights to zkp, // using the Creative Commons "CC0" public domain dedication. See // for full // details. // // Authors: // - Henry de Valence #![feature(test)] extern crate bincode; extern crate curve25519_dalek; extern crate serde; #[macro_use] extern crate serde_derive; extern crate sha2; #[macro_use] extern crate lox_zkp; extern crate test; mod cmz { // Proof statement for "credential presentation with 10 hidden attributes" from CMZ'13. define_proof! { cred_show_10, "CMZ cred show n=10", (m_1, m_2, m_3, m_4, m_5, m_6, m_7, m_8, m_9, m_10, z_1, z_2, z_3, z_4, z_5, z_6, z_7, z_8, z_9, z_10, minus_z_Q), (C_1, C_2, C_3, C_4, C_5, C_6, C_7, C_8, C_9, C_10, P, Q, V), (X_1, X_2, X_3, X_4, X_5, X_6, X_7, X_8, X_9, X_10, A, B) : C_1 = (m_1 * P + z_1 * A), C_2 = (m_2 * P + z_2 * A), C_3 = (m_3 * P + z_3 * A), C_4 = (m_4 * P + z_4 * A), C_5 = (m_5 * P + z_5 * A), C_6 = (m_6 * P + z_6 * A), C_7 = (m_7 * P + z_7 * A), C_8 = (m_8 * P + z_8 * A), C_9 = (m_9 * P + z_9 * A), C_10 = (m_10* P + z_10 * A), V = (m_1*X_1 + m_2*X_2 + m_3*X_3 + m_4*X_4 + m_5*X_5 + m_6*X_6 + m_7*X_7 + m_8*X_8 + m_9*X_9 + m_10*X_10 + minus_z_Q*Q) } } define_proof! {dleq, "DLEQ proof", (x), (A, B, H), (G) : A = (x * G), B = (x * H) }