From b1c626e10841f66b26b15164cbdcfba8d0bf254f Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 10 Jan 2024 19:01:20 -0600 Subject: [PATCH] remove account keys check --- token/transfer-hook/interface/src/onchain.rs | 68 -------------------- 1 file changed, 68 deletions(-) diff --git a/token/transfer-hook/interface/src/onchain.rs b/token/transfer-hook/interface/src/onchain.rs index dc5b78c5787..cca63c4bd81 100644 --- a/token/transfer-hook/interface/src/onchain.rs +++ b/token/transfer-hook/interface/src/onchain.rs @@ -129,24 +129,6 @@ pub fn add_extra_accounts_for_execute_cpi<'a>( .find(|&x| x.key == program_id) .ok_or(TransferHookError::IncorrectAccount)?; - // Check to make sure the provided keys are in the instruction - if [ - source_info.key, - mint_info.key, - destination_info.key, - authority_info.key, - ] - .iter() - .any(|&key| { - !cpi_instruction - .accounts - .iter() - .any(|meta| meta.pubkey == *key) - || !cpi_account_infos.iter().any(|info| info.key == key) - }) { - Err(TransferHookError::IncorrectAccount)?; - } - let mut execute_instruction = instruction::execute( program_id, source_info.key, @@ -429,56 +411,6 @@ mod tests { validate_state_account_info.clone(), ]; - // Fail missing key - let mut cpi_instruction_missing_key = Instruction::new_with_bytes( - spl_token_2022_program_id, - &[], - vec![ - // source missing - AccountMeta::new_readonly(mint_pubkey, false), - AccountMeta::new(destination_pubkey, false), - AccountMeta::new_readonly(authority_pubkey, true), - ], - ); - assert_eq!( - add_extra_accounts_for_execute_cpi( - &mut cpi_instruction_missing_key, // Missing key - &mut cpi_account_infos, - &transfer_hook_program_id, - source_account_info.clone(), - mint_account_info.clone(), - destination_account_info.clone(), - authority_account_info.clone(), - amount, - &additional_account_infos, - ) - .unwrap_err(), - TransferHookError::IncorrectAccount.into() - ); - - // Fail missing account info - let mut cpi_account_infos_missing_infos = vec![ - source_account_info.clone(), - mint_account_info.clone(), - // destination missing - authority_account_info.clone(), - ]; - assert_eq!( - add_extra_accounts_for_execute_cpi( - &mut cpi_instruction, - &mut cpi_account_infos_missing_infos, // Missing account info - &transfer_hook_program_id, - source_account_info.clone(), - mint_account_info.clone(), - destination_account_info.clone(), - authority_account_info.clone(), - amount, - &additional_account_infos, - ) - .unwrap_err(), - TransferHookError::IncorrectAccount.into() - ); - // Fail missing validation info from additional account infos let additional_account_infos_missing_infos = vec![ extra_meta_1_account_info.clone(),