diff --git a/frost-core/src/signing_key.rs b/frost-core/src/signing_key.rs index 04323e1f..a9b7517c 100644 --- a/frost-core/src/signing_key.rs +++ b/frost-core/src/signing_key.rs @@ -28,9 +28,14 @@ where pub fn deserialize( bytes: <::Field as Field>::Serialization, ) -> Result, Error> { - <::Field as Field>::deserialize(&bytes) - .map(|scalar| SigningKey { scalar }) - .map_err(|e| e.into()) + let scalar = + <::Field as Field>::deserialize(&bytes).map_err(Error::from)?; + + if scalar == <::Field as Field>::zero() { + return Err(Error::MalformedSigningKey); + } + + Ok(Self { scalar }) } /// Serialize `SigningKey` to bytes diff --git a/frost-core/src/tests/ciphersuite_generic.rs b/frost-core/src/tests/ciphersuite_generic.rs index 523777a4..08a7e9ef 100644 --- a/frost-core/src/tests/ciphersuite_generic.rs +++ b/frost-core/src/tests/ciphersuite_generic.rs @@ -6,12 +6,20 @@ use std::{ use crate::{ frost::{self, Identifier}, - Error, Field, Group, Signature, VerifyingKey, + Error, Field, Group, Signature, SigningKey, VerifyingKey, }; use rand_core::{CryptoRng, RngCore}; use crate::Ciphersuite; +/// Test if creating a zero SigningKey fails +pub fn check_zero_key_fails() { + let zero = <<::Group as Group>::Field>::zero(); + let encoded_zero = <<::Group as Group>::Field>::serialize(&zero); + let r = SigningKey::::deserialize(encoded_zero); + assert_eq!(r, Err(Error::MalformedSigningKey)); +} + /// Test share generation with a Ciphersuite pub fn check_share_generation(mut rng: R) { let secret = crate::SigningKey::::new(&mut rng); diff --git a/frost-ed25519/tests/integration_tests.rs b/frost-ed25519/tests/integration_tests.rs index c729c75e..3dd8a2eb 100644 --- a/frost-ed25519/tests/integration_tests.rs +++ b/frost-ed25519/tests/integration_tests.rs @@ -3,6 +3,11 @@ use lazy_static::lazy_static; use rand::thread_rng; use serde_json::Value; +#[test] +fn check_zero_key_fails() { + frost_core::tests::ciphersuite_generic::check_zero_key_fails::(); +} + #[test] fn check_sign_with_dkg() { let rng = thread_rng(); diff --git a/frost-ed448/tests/integration_tests.rs b/frost-ed448/tests/integration_tests.rs index 90956ccb..323048ec 100644 --- a/frost-ed448/tests/integration_tests.rs +++ b/frost-ed448/tests/integration_tests.rs @@ -3,6 +3,11 @@ use lazy_static::lazy_static; use rand::thread_rng; use serde_json::Value; +#[test] +fn check_zero_key_fails() { + frost_core::tests::ciphersuite_generic::check_zero_key_fails::(); +} + #[test] fn check_sign_with_dkg() { let rng = thread_rng(); diff --git a/frost-p256/tests/integration_tests.rs b/frost-p256/tests/integration_tests.rs index 406181b5..317f5746 100644 --- a/frost-p256/tests/integration_tests.rs +++ b/frost-p256/tests/integration_tests.rs @@ -3,6 +3,11 @@ use lazy_static::lazy_static; use rand::thread_rng; use serde_json::Value; +#[test] +fn check_zero_key_fails() { + frost_core::tests::ciphersuite_generic::check_zero_key_fails::(); +} + #[test] fn check_sign_with_dkg() { let rng = thread_rng(); diff --git a/frost-ristretto255/tests/integration_tests.rs b/frost-ristretto255/tests/integration_tests.rs index 9d479a7d..3150ba7c 100644 --- a/frost-ristretto255/tests/integration_tests.rs +++ b/frost-ristretto255/tests/integration_tests.rs @@ -3,6 +3,11 @@ use lazy_static::lazy_static; use rand::thread_rng; use serde_json::Value; +#[test] +fn check_zero_key_fails() { + frost_core::tests::ciphersuite_generic::check_zero_key_fails::(); +} + #[test] fn check_sign_with_dkg() { let rng = thread_rng(); diff --git a/frost-secp256k1/tests/integration_tests.rs b/frost-secp256k1/tests/integration_tests.rs index f6cb05da..7607e351 100644 --- a/frost-secp256k1/tests/integration_tests.rs +++ b/frost-secp256k1/tests/integration_tests.rs @@ -3,6 +3,11 @@ use lazy_static::lazy_static; use rand::thread_rng; use serde_json::Value; +#[test] +fn check_zero_key_fails() { + frost_core::tests::ciphersuite_generic::check_zero_key_fails::(); +} + #[test] fn check_sign_with_dkg() { let rng = thread_rng();