Skip to content

Commit

Permalink
Remove Deref impl for BLS structs
Browse files Browse the repository at this point in the history
instead use the inner reference with `<data>.0`
  • Loading branch information
tessico committed Nov 30, 2022
1 parent a00c769 commit 7149b1a
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 29 deletions.
37 changes: 10 additions & 27 deletions primitives/src/signatures/bls.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,14 +27,6 @@ use zeroize::Zeroize;
#[derive(Clone, Debug, Zeroize)]
pub struct BLSSignKey(SecretKey);

impl core::ops::Deref for BLSSignKey {
type Target = SecretKey;

fn deref(&self) -> &Self::Target {
&self.0
}
}

impl CanonicalSerialize for BLSSignKey {
fn serialized_size(&self) -> usize {
BLS_SIG_KEY_SIZE
Expand Down Expand Up @@ -64,15 +56,7 @@ impl CanonicalDeserialize for BLSSignKey {
/// Newtype wrapper for a BLS Signature.
#[tagged(tag::BLSSIG)]
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct BLSSignature(Signature);

impl core::ops::Deref for BLSSignature {
type Target = Signature;

fn deref(&self) -> &Self::Target {
&self.0
}
}
pub struct BLSSignature(pub(crate) Signature);

impl CanonicalSerialize for BLSSignature {
fn serialized_size(&self) -> usize {
Expand Down Expand Up @@ -105,14 +89,6 @@ impl CanonicalDeserialize for BLSSignature {
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct BLSVerKey(PublicKey);

impl core::ops::Deref for BLSVerKey {
type Target = PublicKey;

fn deref(&self) -> &Self::Target {
&self.0
}
}

impl CanonicalSerialize for BLSVerKey {
fn serialized_size(&self) -> usize {
BLS_SIG_VERKEY_SIZE
Expand Down Expand Up @@ -190,7 +166,7 @@ impl SignatureScheme for BLSSignatureScheme {
msg: M,
_prng: &mut R,
) -> Result<Self::Signature, PrimitivesError> {
Ok(BLSSignature(sk.sign(
Ok(BLSSignature(sk.0.sign(
msg.as_ref(),
Self::CS_ID.as_bytes(),
&[],
Expand All @@ -204,7 +180,14 @@ impl SignatureScheme for BLSSignatureScheme {
msg: M,
sig: &Self::Signature,
) -> Result<(), PrimitivesError> {
match sig.verify(false, msg.as_ref(), Self::CS_ID.as_bytes(), &[], vk, true) {
match sig.0.verify(
false,
msg.as_ref(),
Self::CS_ID.as_bytes(),
&[],
&vk.0,
true,
) {
BLST_ERROR::BLST_SUCCESS => Ok(()),
e => Err(PrimitivesError::VerificationError(format!("{:?}", e))),
}
Expand Down
4 changes: 2 additions & 2 deletions primitives/src/vrf/blsvrf.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ impl Vrf for BLSVRFScheme {
_pp: &Self::PublicParameter,
proof: &Self::Proof,
) -> Result<Self::Output, PrimitivesError> {
let proof_serialized = proof.serialize();
let proof_serialized = proof.0.serialize();
let mut hasher = (*self.hasher).box_clone();
hasher.update(&proof_serialized);
let output = hasher.finalize();
Expand Down Expand Up @@ -151,7 +151,7 @@ mod test {

// check the VRF output vs. hashing the proof directly
let mut hasher = H::new();
hasher.update(vrf_proof.serialize());
hasher.update(vrf_proof.0.serialize());
let direct_hash_output = hasher.finalize().to_vec();
assert_eq!(direct_hash_output, vrf_output);

Expand Down

0 comments on commit 7149b1a

Please sign in to comment.