From 31732353c65b4488d094e26bd572911fafd4ce10 Mon Sep 17 00:00:00 2001 From: Nagaprasad V R <81755170+Nagaprasadvr@users.noreply.github.com> Date: Thu, 14 Mar 2024 23:13:34 +0530 Subject: [PATCH] relax stake split destination check (#162) * relax stake split destination check * change stake_account error handling logic * fmt * modify logic * change error message when account is neither owned by stake program or system program * add a comment explaining nested ifs in stake_account error handling * fix typos in comments * update comment (cherry picked from commit 6bcb77dcfa3544d43919aee8671802be0ae67adc) --- cli/src/stake.rs | 28 ++++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/cli/src/stake.rs b/cli/src/stake.rs index f4bb8329278d94..8f890a1c0146f4 100644 --- a/cli/src/stake.rs +++ b/cli/src/stake.rs @@ -56,6 +56,7 @@ use { }, stake_history::{Epoch, StakeHistory}, system_instruction::{self, SystemError}, + system_program, sysvar::{clock, stake_history}, transaction::Transaction, }, @@ -1980,15 +1981,26 @@ pub fn process_split_stake( let rent_exempt_reserve = if !sign_only { if let Ok(stake_account) = rpc_client.get_account(&split_stake_account_address) { - let err_msg = if stake_account.owner == stake::program::id() { - format!("Stake account {split_stake_account_address} already exists") + if stake_account.owner == stake::program::id() { + return Err(CliError::BadParameter(format!( + "Stake account {split_stake_account_address} already exists" + )) + .into()); + } else if stake_account.owner == system_program::id() { + if !stake_account.data.is_empty() { + return Err(CliError::BadParameter(format!( + "Account {split_stake_account_address} has data and cannot be used to split stake" + )) + .into()); + } + // if `stake_account`'s owner is the system_program and its data is + // empty, `stake_account` is allowed to receive the stake split } else { - format!( - "Account {split_stake_account_address} already exists and is not a stake \ - account" - ) - }; - return Err(CliError::BadParameter(err_msg).into()); + return Err(CliError::BadParameter(format!( + "Account {split_stake_account_address} already exists and cannot be used to split stake" + )) + .into()); + } } let minimum_balance =