Skip to content

Commit

Permalink
Some finalization
Browse files Browse the repository at this point in the history
  • Loading branch information
Denis committed Jul 27, 2021
1 parent a1d1464 commit 239cc1c
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 100 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ impl<E: Curve> PedersenBlindingProof<E> {
);
let g = Point::<E>::generator();
let e = Sha256::new()
.chain_points([&g.to_point(), h, &com, &a])
.chain_points([g.as_point(), h, &com, &a])
.chain_scalar(&m)
.result_scalar();

Expand All @@ -65,7 +65,7 @@ impl<E: Curve> PedersenBlindingProof<E> {
let g = Point::<E>::generator();
let h = Point::<E>::base_point2();
let e = Sha256::new()
.chain_points([&g.to_point(), h, &proof.com, &proof.a])
.chain_points([g.as_point(), h, &proof.com, &proof.a])
.chain_scalar(&proof.m)
.result_scalar();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,13 +77,13 @@ impl Party1FirstMessage {
// we use hash based commitment
let pk_commitment_blind_factor = BigInt::sample(SECURITY_BITS);
let pk_commitment = HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(public_share.to_bytes(true).as_ref()),
&BigInt::from_bytes(&public_share.to_bytes(true)),
&pk_commitment_blind_factor,
);

let zk_pok_blind_factor = BigInt::sample(SECURITY_BITS);
let zk_pok_commitment = HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(d_log_proof.pk_t_rand_commitment.to_bytes(true).as_ref()),
&BigInt::from_bytes(&d_log_proof.pk_t_rand_commitment.to_bytes(true)),
&zk_pok_blind_factor,
);
let ec_key_pair = EcKeyPair {
Expand Down Expand Up @@ -115,13 +115,13 @@ impl Party1FirstMessage {

let pk_commitment_blind_factor = BigInt::sample(SECURITY_BITS);
let pk_commitment = HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(public_share.to_bytes(true).as_ref()),
&BigInt::from_bytes(&public_share.to_bytes(true)),
&pk_commitment_blind_factor,
);

let zk_pok_blind_factor = BigInt::sample(SECURITY_BITS);
let zk_pok_commitment = HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(d_log_proof.pk_t_rand_commitment.to_bytes(true).as_ref()),
&BigInt::from_bytes(&d_log_proof.pk_t_rand_commitment.to_bytes(true)),
&zk_pok_blind_factor,
);

Expand Down Expand Up @@ -214,7 +214,7 @@ impl Party2SecondMessage {
let mut flag = true;
if party_one_pk_commitment
!= &HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(party_one_public_share.to_bytes(true).as_ref()),
&BigInt::from_bytes(&party_one_public_share.to_bytes(true)),
&party_one_pk_commitment_blind_factor,
)
{
Expand All @@ -223,12 +223,7 @@ impl Party2SecondMessage {

if party_one_zk_pok_commitment
!= &HashCommitment::create_commitment_with_user_defined_randomness(
&BigInt::from_bytes(
party_one_d_log_proof
.pk_t_rand_commitment
.to_bytes(true)
.as_ref(),
),
&BigInt::from_bytes(&party_one_d_log_proof.pk_t_rand_commitment.to_bytes(true)),
&party_one_zk_pok_blind_factor,
)
{
Expand Down
6 changes: 6 additions & 0 deletions src/elliptic/curves/wrappers/arithmetic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,8 @@ macro_rules! matrix {
}

fn addition_of_two_points<E: Curve>(result: E::Point) -> Point<E> {
// Safety: addition of two points of group order is always either a zero point or point of group
// order: `A + B = aG + bG = (a + b)G`
unsafe { Point::from_raw_unchecked(result) }
}

Expand All @@ -152,6 +154,8 @@ matrix! {
}

fn subtraction_of_two_point<E: Curve>(result: E::Point) -> Point<E> {
// Safety: subtraction of two points of group order is always either a zero point or point of group
// order: `A - B = aG - bG = (a - b)G`
unsafe { Point::from_raw_unchecked(result) }
}

Expand All @@ -175,6 +179,8 @@ matrix! {
}

fn multiplication_of_point_at_scalar<E: Curve>(result: E::Point) -> Point<E> {
// Safety: multiplication of point of group order at a scalar is always either a zero point or
// point of group order: `kA = kaG`
unsafe { Point::from_raw_unchecked(result) }
}

Expand Down
84 changes: 0 additions & 84 deletions src/elliptic/curves/wrappers/format.rs

This file was deleted.

1 change: 0 additions & 1 deletion src/elliptic/curves/wrappers/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ mod arithmetic;
mod encoded_point;
mod encoded_scalar;
pub mod error;
mod format;
mod generator;
mod point;
mod scalar;
Expand Down
5 changes: 3 additions & 2 deletions src/elliptic/curves/wrappers/point.rs
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,7 @@ impl<E: Curve> Point<E> {
/// Tries to parse a point in (un)compressed form
///
/// Whether it's in compressed or uncompressed form will be deduced from its length
pub fn from_bytes(bytes: impl AsRef<[u8]>) -> Result<Self, PointFromBytesError> {
pub fn from_bytes(bytes: &[u8]) -> Result<Self, PointFromBytesError> {
let p = E::Point::deserialize(bytes.as_ref())
.map_err(|_: DeserializationError| PointFromBytesError::DeserializationError)?;
Self::from_raw(p).map_err(PointFromBytesError::InvalidPoint)
Expand Down Expand Up @@ -223,7 +223,7 @@ impl<E: Curve> Point<E> {

/// Constructs a `Point<E>` from reference to low-level [ECPoint] implementor
///
/// Unsafe equivalent of [from_raw](Self::from_raw). It debug asserts that given `raw_point` is
/// Unsafe equivalent of [from_raw_ref](Self::from_raw_ref). It debug asserts that given `raw_point` is
/// valid (the assertion is optimized out in release builds by default).
///
/// # Safety
Expand All @@ -238,6 +238,7 @@ impl<E: Curve> Point<E> {
/// [check_point_order_equals_group_order]: crate::elliptic::curves::ECPoint::check_point_order_equals_group_order
/// [is_zero]: crate::elliptic::curves::ECPoint::is_zero
pub unsafe fn from_raw_ref_unchecked(raw_point: &E::Point) -> &Self {
debug_assert!(raw_point.is_zero() || raw_point.check_point_order_equals_group_order());
// Safety: Self is repr(transparent) wrapper over E::Point => cast is sound
&*(raw_point as *const E::Point as *const Self)
}
Expand Down

0 comments on commit 239cc1c

Please sign in to comment.