From f49e38b43f0b82363ee7dd776200c5c4d8684c39 Mon Sep 17 00:00:00 2001 From: Murisi Tarusenga Date: Mon, 2 Sep 2024 08:00:39 +0200 Subject: [PATCH] Ensure that the number of used public keys exceeds the account threshold. --- crates/sdk/src/signing.rs | 34 ++++++++++++++++++++++++++++++---- 1 file changed, 30 insertions(+), 4 deletions(-) diff --git a/crates/sdk/src/signing.rs b/crates/sdk/src/signing.rs index 746cda2bf3b..e0de4f8c008 100644 --- a/crates/sdk/src/signing.rs +++ b/crates/sdk/src/signing.rs @@ -253,8 +253,8 @@ where } // Then try to sign the raw header using the hardware wallet - for pubkey in signing_data.public_keys { - if !used_pubkeys.contains(&pubkey) && pubkey != signing_data.fee_payer { + for pubkey in &signing_data.public_keys { + if !used_pubkeys.contains(pubkey) && *pubkey != signing_data.fee_payer { if let Ok(ntx) = sign( tx.clone(), pubkey.clone(), @@ -281,7 +281,10 @@ where Ok(fee_payer_keypair) => { tx.sign_wrapper(fee_payer_keypair); } - Err(_) => { + // The case where tge fee payer also signs the inner transaction + Err(_) + if signing_data.public_keys.contains(&signing_data.fee_payer) => + { *tx = sign( tx.clone(), signing_data.fee_payer.clone(), @@ -289,9 +292,32 @@ where user_data, ) .await?; + used_pubkeys.insert(signing_data.fee_payer.clone()); + } + // The case where the fee payer does not sign the inner transaction + Err(_) => { + *tx = sign( + tx.clone(), + signing_data.fee_payer.clone(), + HashSet::from([Signable::FeeHeader]), + user_data, + ) + .await?; } } - Ok(()) + // Then make sure that the number of public keys used exceeds the threshold + let used_pubkeys_len = used_pubkeys + .len() + .try_into() + .expect("Public keys associated with account exceed 127"); + if used_pubkeys_len < signing_data.threshold { + Err(Error::from(TxSubmitError::MissingSigningKeys( + signing_data.threshold, + used_pubkeys_len, + ))) + } else { + Ok(()) + } } /// Return the necessary data regarding an account to be able to generate a