Skip to content

Commit

Permalink
sdk: Add new version of StakeState to avoid breaking downstream use…
Browse files Browse the repository at this point in the history
…rs (#32736)

* sdk: Rename `StakeState` -> `StakeStateWithFlags`

* Add back `StakeFlags` with a deprecation warning
  • Loading branch information
joncinque authored Aug 8, 2023
1 parent ef318c2 commit 8e4a9a9
Show file tree
Hide file tree
Showing 24 changed files with 782 additions and 466 deletions.
20 changes: 10 additions & 10 deletions account-decoder/src/parse_stake.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,24 +6,24 @@ use {
bincode::deserialize,
solana_sdk::{
clock::{Epoch, UnixTimestamp},
stake::state::{Authorized, Delegation, Lockup, Meta, Stake, StakeState},
stake::state::{Authorized, Delegation, Lockup, Meta, Stake, StakeStateWithFlags},
},
};

pub fn parse_stake(data: &[u8]) -> Result<StakeAccountType, ParseAccountError> {
let stake_state: StakeState = deserialize(data)
let stake_state: StakeStateWithFlags = deserialize(data)
.map_err(|_| ParseAccountError::AccountNotParsable(ParsableAccount::Stake))?;
let parsed_account = match stake_state {
StakeState::Uninitialized => StakeAccountType::Uninitialized,
StakeState::Initialized(meta) => StakeAccountType::Initialized(UiStakeAccount {
StakeStateWithFlags::Uninitialized => StakeAccountType::Uninitialized,
StakeStateWithFlags::Initialized(meta) => StakeAccountType::Initialized(UiStakeAccount {
meta: meta.into(),
stake: None,
}),
StakeState::Stake(meta, stake, _) => StakeAccountType::Delegated(UiStakeAccount {
StakeStateWithFlags::Stake(meta, stake, _) => StakeAccountType::Delegated(UiStakeAccount {
meta: meta.into(),
stake: Some(stake.into()),
}),
StakeState::RewardsPool => StakeAccountType::RewardsPool,
StakeStateWithFlags::RewardsPool => StakeAccountType::RewardsPool,
};
Ok(parsed_account)
}
Expand Down Expand Up @@ -146,7 +146,7 @@ mod test {
#[test]
#[allow(deprecated)]
fn test_parse_stake() {
let stake_state = StakeState::Uninitialized;
let stake_state = StakeStateWithFlags::Uninitialized;
let stake_data = serialize(&stake_state).unwrap();
assert_eq!(
parse_stake(&stake_data).unwrap(),
Expand All @@ -167,7 +167,7 @@ mod test {
lockup,
};

let stake_state = StakeState::Initialized(meta);
let stake_state = StakeStateWithFlags::Initialized(meta);
let stake_data = serialize(&stake_state).unwrap();
assert_eq!(
parse_stake(&stake_data).unwrap(),
Expand Down Expand Up @@ -200,7 +200,7 @@ mod test {
credits_observed: 10,
};

let stake_state = StakeState::Stake(meta, stake, StakeFlags::empty());
let stake_state = StakeStateWithFlags::Stake(meta, stake, StakeFlags::empty());
let stake_data = serialize(&stake_state).unwrap();
assert_eq!(
parse_stake(&stake_data).unwrap(),
Expand Down Expand Up @@ -230,7 +230,7 @@ mod test {
})
);

let stake_state = StakeState::RewardsPool;
let stake_state = StakeStateWithFlags::RewardsPool;
let stake_data = serialize(&stake_state).unwrap();
assert_eq!(
parse_stake(&stake_data).unwrap(),
Expand Down
10 changes: 5 additions & 5 deletions cli/src/cluster_query.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ use {
rpc_port::DEFAULT_RPC_PORT_STR,
signature::Signature,
slot_history,
stake::{self, state::StakeState},
stake::{self, state::StakeStateWithFlags},
system_instruction,
sysvar::{
self,
Expand Down Expand Up @@ -1768,7 +1768,7 @@ pub fn process_show_stakes(
// Use server-side filtering if only one vote account is provided
if vote_account_pubkeys.len() == 1 {
program_accounts_config.filters = Some(vec![
// Filter by `StakeState::Stake(_, _)`
// Filter by `StakeStateWithFlags::Stake(_, _)`
RpcFilterType::Memcmp(Memcmp::new_base58_encoded(0, &[2, 0, 0, 0])),
// Filter by `Delegation::voter_pubkey`, which begins at byte offset 124
RpcFilterType::Memcmp(Memcmp::new_base58_encoded(
Expand Down Expand Up @@ -1809,7 +1809,7 @@ pub fn process_show_stakes(
for (stake_pubkey, stake_account) in all_stake_accounts {
if let Ok(stake_state) = stake_account.state() {
match stake_state {
StakeState::Initialized(_) => {
StakeStateWithFlags::Initialized(_) => {
if vote_account_pubkeys.is_none() {
stake_accounts.push(CliKeyedStakeState {
stake_pubkey: stake_pubkey.to_string(),
Expand All @@ -1824,7 +1824,7 @@ pub fn process_show_stakes(
});
}
}
StakeState::Stake(_, stake, _) => {
StakeStateWithFlags::Stake(_, stake, _) => {
if vote_account_pubkeys.is_none()
|| vote_account_pubkeys
.unwrap()
Expand Down Expand Up @@ -2157,7 +2157,7 @@ impl RentLengthValue {
pub fn length(&self) -> usize {
match self {
Self::Nonce => NonceState::size(),
Self::Stake => StakeState::size_of(),
Self::Stake => StakeStateWithFlags::size_of(),
Self::System => 0,
Self::Vote => VoteState::size_of(),
Self::Bytes(l) => *l,
Expand Down
31 changes: 17 additions & 14 deletions cli/src/stake.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,10 @@ use {
stake::{
self,
instruction::{self as stake_instruction, LockupArgs, StakeError},
state::{Authorized, Lockup, Meta, StakeActivationStatus, StakeAuthorize, StakeState},
state::{
Authorized, Lockup, Meta, StakeActivationStatus, StakeAuthorize,
StakeStateWithFlags,
},
tools::{acceptable_reference_epoch_credits, eligible_for_deactivate_delinquent},
},
stake_history::{Epoch, StakeHistory},
Expand Down Expand Up @@ -1422,7 +1425,7 @@ pub fn process_create_stake_account(
}

let minimum_balance =
rpc_client.get_minimum_balance_for_rent_exemption(StakeState::size_of())?;
rpc_client.get_minimum_balance_for_rent_exemption(StakeStateWithFlags::size_of())?;

if lamports < minimum_balance {
return Err(CliError::BadParameter(format!(
Expand Down Expand Up @@ -1500,8 +1503,8 @@ pub fn process_stake_authorize(
let authority = config.signers[*authority];
if let Some(current_stake_account) = current_stake_account {
let authorized = match current_stake_account {
StakeState::Stake(Meta { authorized, .. }, ..) => Some(authorized),
StakeState::Initialized(Meta { authorized, .. }) => Some(authorized),
StakeStateWithFlags::Stake(Meta { authorized, .. }, ..) => Some(authorized),
StakeStateWithFlags::Initialized(Meta { authorized, .. }) => Some(authorized),
_ => None,
};
if let Some(authorized) = authorized {
Expand Down Expand Up @@ -1630,7 +1633,7 @@ pub fn process_deactivate_stake_account(

let vote_account_address = match stake_account.state() {
Ok(stake_state) => match stake_state {
StakeState::Stake(_, stake, _) => stake.delegation.voter_pubkey,
StakeStateWithFlags::Stake(_, stake, _) => stake.delegation.voter_pubkey,
_ => {
return Err(CliError::BadParameter(format!(
"{stake_account_address} is not a delegated stake account",
Expand Down Expand Up @@ -1895,7 +1898,7 @@ pub fn process_split_stake(
}

let minimum_balance =
rpc_client.get_minimum_balance_for_rent_exemption(StakeState::size_of())?;
rpc_client.get_minimum_balance_for_rent_exemption(StakeStateWithFlags::size_of())?;

if lamports < minimum_balance {
return Err(CliError::BadParameter(format!(
Expand Down Expand Up @@ -2116,8 +2119,8 @@ pub fn process_stake_set_lockup(
if !sign_only {
let state = get_stake_account_state(rpc_client, stake_account_pubkey, config.commitment)?;
let lockup = match state {
StakeState::Stake(Meta { lockup, .. }, ..) => Some(lockup),
StakeState::Initialized(Meta { lockup, .. }) => Some(lockup),
StakeStateWithFlags::Stake(Meta { lockup, .. }, ..) => Some(lockup),
StakeStateWithFlags::Initialized(Meta { lockup, .. }) => Some(lockup),
_ => None,
};
if let Some(lockup) = lockup {
Expand Down Expand Up @@ -2184,14 +2187,14 @@ fn u64_some_if_not_zero(n: u64) -> Option<u64> {

pub fn build_stake_state(
account_balance: u64,
stake_state: &StakeState,
stake_state: &StakeStateWithFlags,
use_lamports_unit: bool,
stake_history: &StakeHistory,
clock: &Clock,
new_rate_activation_epoch: Option<Epoch>,
) -> CliStakeState {
match stake_state {
StakeState::Stake(
StakeStateWithFlags::Stake(
Meta {
rent_exempt_reserve,
authorized,
Expand Down Expand Up @@ -2248,16 +2251,16 @@ pub fn build_stake_state(
..CliStakeState::default()
}
}
StakeState::RewardsPool => CliStakeState {
StakeStateWithFlags::RewardsPool => CliStakeState {
stake_type: CliStakeType::RewardsPool,
account_balance,
..CliStakeState::default()
},
StakeState::Uninitialized => CliStakeState {
StakeStateWithFlags::Uninitialized => CliStakeState {
account_balance,
..CliStakeState::default()
},
StakeState::Initialized(Meta {
StakeStateWithFlags::Initialized(Meta {
rent_exempt_reserve,
authorized,
lockup,
Expand Down Expand Up @@ -2285,7 +2288,7 @@ fn get_stake_account_state(
rpc_client: &RpcClient,
stake_account_pubkey: &Pubkey,
commitment_config: CommitmentConfig,
) -> Result<StakeState, Box<dyn std::error::Error>> {
) -> Result<StakeStateWithFlags, Box<dyn std::error::Error>> {
let stake_account = rpc_client
.get_account_with_commitment(stake_account_pubkey, commitment_config)?
.value
Expand Down
Loading

0 comments on commit 8e4a9a9

Please sign in to comment.