From 96eaccf4bcca48958ebd843e5fd28bbda333c2c9 Mon Sep 17 00:00:00 2001 From: Michael Vines Date: Tue, 12 Jul 2022 13:21:07 -0700 Subject: [PATCH] getStakeActivation now correctly returns the inactivate lamports for deactivat{ed,ing} stake account in all cases --- rpc/src/rpc.rs | 42 +++++++++++++++++++++++------------------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/rpc/src/rpc.rs b/rpc/src/rpc.rs index 084d1172d07db3..46a515e9a5b39f 100644 --- a/rpc/src/rpc.rs +++ b/rpc/src/rpc.rs @@ -1739,24 +1739,24 @@ impl JsonRpcRequestProcessor { .state() .map_err(|_| Error::invalid_params("Invalid param: not a stake account".to_string()))?; let delegation = stake_state.delegation(); - if delegation.is_none() { - match stake_state.meta() { - None => { - return Err(Error::invalid_params( - "Invalid param: stake account not initialized".to_string(), - )); - } - Some(meta) => { - let rent_exempt_reserve = meta.rent_exempt_reserve; - return Ok(RpcStakeActivation { - state: StakeActivationState::Inactive, - active: 0, - inactive: stake_account.lamports().saturating_sub(rent_exempt_reserve), - }); - } + + let rent_exempt_reserve = stake_state + .meta() + .ok_or_else(|| { + Error::invalid_params("Invalid param: stake account not initialized".to_string()) + })? + .rent_exempt_reserve; + + let delegation = match delegation { + None => { + return Ok(RpcStakeActivation { + state: StakeActivationState::Inactive, + active: 0, + inactive: stake_account.lamports().saturating_sub(rent_exempt_reserve), + }) } - } - let delegation = delegation.unwrap(); + Some(delegation) => delegation, + }; let stake_history_account = bank .get_account(&stake_history::id()) @@ -1782,8 +1782,12 @@ impl JsonRpcRequestProcessor { let inactive_stake = match stake_activation_state { StakeActivationState::Activating => activating, StakeActivationState::Active => 0, - StakeActivationState::Deactivating => delegation.stake.saturating_sub(effective), - StakeActivationState::Inactive => delegation.stake, + StakeActivationState::Deactivating => stake_account + .lamports() + .saturating_sub(effective + rent_exempt_reserve), + StakeActivationState::Inactive => { + stake_account.lamports().saturating_sub(rent_exempt_reserve) + } }; Ok(RpcStakeActivation { state: stake_activation_state,