From dabacb9d140be26ae0c052d912e71fd60ca302d4 Mon Sep 17 00:00:00 2001 From: David Wolinsky Date: Mon, 16 Oct 2023 22:41:29 -0700 Subject: [PATCH] [authenticator] improve error messages --- api/types/src/transaction.rs | 30 +++++++++++++------------- types/src/transaction/authenticator.rs | 16 +++++++++----- 2 files changed, 26 insertions(+), 20 deletions(-) diff --git a/api/types/src/transaction.rs b/api/types/src/transaction.rs index b6ad79fa59062..2458627f8312a 100755 --- a/api/types/src/transaction.rs +++ b/api/types/src/transaction.rs @@ -1323,21 +1323,21 @@ impl TryFrom for AccountAuthenticator { let mut signatures = vec![]; for indexed_signature in value.signatures { - let signature = match indexed_signature.signature { - Signature::Ed25519(s) => { - let signature = s - .inner() - .try_into() - .context("Failed to parse given public_key bytes as Ed25519Signature")?; - AnySignature::ed25519(signature) - }, - Signature::Secp256k1Ecdsa(s) => { - let signature = s.inner().try_into().context( - "Failed to parse given public_key bytes as Secp256k1EcdsaSignature", - )?; - AnySignature::secp256k1_ecdsa(signature) - }, - }; + let signature = + match indexed_signature.signature { + Signature::Ed25519(s) => { + let signature = s.inner().try_into().context( + "Failed to parse given public_key bytes as Ed25519Signature", + )?; + AnySignature::ed25519(signature) + }, + Signature::Secp256k1Ecdsa(s) => { + let signature = s.inner().try_into().context( + "Failed to parse given signature as Secp256k1EcdsaSignature", + )?; + AnySignature::secp256k1_ecdsa(signature) + }, + }; signatures.push((indexed_signature.index, signature)); } diff --git a/types/src/transaction/authenticator.rs b/types/src/transaction/authenticator.rs index 70b37a7fa548f..4ca08de5b5ad5 100644 --- a/types/src/transaction/authenticator.rs +++ b/types/src/transaction/authenticator.rs @@ -740,7 +740,8 @@ impl MultiKeyAuthenticator { pub fn new(public_keys: MultiKey, signatures: Vec<(u8, AnySignature)>) -> Result { ensure!( public_keys.len() < (u8::MAX as usize), - "Too many public keys in MultiKeyAuthenticator." + "Too many public keys, {}, in MultiKeyAuthenticator.", + public_keys.len(), ); let mut signatures_bitmap = aptos_bitvec::BitVec::with_num_bits(public_keys.len() as u16); @@ -749,11 +750,14 @@ impl MultiKeyAuthenticator { for (idx, signature) in signatures { ensure!( (idx as usize) < public_keys.len(), - "Signature index is out of public key range." + "Signature index is out of public key range, {} < {}.", + idx, + public_keys.len(), ); ensure!( !signatures_bitmap.is_set(idx as u16), - "Duplicate signature index." + "Duplicate signature index, {}.", + idx ); signatures_bitmap.set(idx as u16); any_signatures.push(signature); @@ -783,11 +787,13 @@ impl MultiKeyAuthenticator { pub fn verify(&self, message: &T) -> Result<()> { ensure!( self.signatures_bitmap.count_ones() as usize == self.signatures.len(), - "Mismatch in signatures and signatures_bitmap" + "Mismatch in number of signatures and the number of bits set in the signatures_bitmap, {} != {}.", self.signatures_bitmap.count_ones(), self.signatures.len(), ); ensure!( self.signatures.len() >= self.public_keys.signatures_required() as usize, - "Not enough signatures for verification" + "Not enough signatures for verification, {} < {}.", + self.signatures.len(), + self.public_keys.signatures_required(), ); for (idx, signature) in std::iter::zip(self.signatures_bitmap.iter_ones(), self.signatures.iter())