dleq 0.4.1

Implementation of single and cross-curve Discrete Log Equality proofs
use core::ops::Deref;

use rand_core::OsRng;

use zeroize::Zeroize;

use group::{
  ff::{Field, PrimeFieldBits},
  prime::PrimeGroup,
};
use multiexp::BatchVerifier;

use transcript::{Transcript, RecommendedTranscript};

use crate::cross_group::schnorr::SchnorrPoK;

fn test_schnorr<G: PrimeGroup + Zeroize>()
where
  G::Scalar: PrimeFieldBits + Zeroize,
{
  let transcript = RecommendedTranscript::new(b"Schnorr Test");

  let mut batch = BatchVerifier::new(10);
  for _ in 0 .. 10 {
    let private = Zeroizing::new(G::Scalar::random(&mut OsRng));
    SchnorrPoK::prove(&mut OsRng, &mut transcript.clone(), G::generator(), &private).verify(
      &mut OsRng,
      &mut transcript.clone(),
      G::generator(),
      G::generator() * private.deref(),
      &mut batch,
    );
  }

  assert!(batch.verify_vartime());
}

#[test]
fn test_secp256k1() {
  test_schnorr::<k256::ProjectivePoint>();
}

#[test]
fn test_ed25519() {
  test_schnorr::<dalek_ff_group::EdwardsPoint>();
}