Enum solana_sdk::stake::instruction::StakeInstruction
source · pub enum StakeInstruction {
Show 13 variants
Initialize(Authorized, Lockup),
Authorize(Pubkey, StakeAuthorize),
DelegateStake,
Split(u64),
Withdraw(u64),
Deactivate,
SetLockup(LockupArgs),
Merge,
AuthorizeWithSeed(AuthorizeWithSeedArgs),
InitializeChecked,
AuthorizeChecked(StakeAuthorize),
AuthorizeCheckedWithSeed(AuthorizeCheckedWithSeedArgs),
SetLockupChecked(LockupCheckedArgs),
}
Variants§
Initialize(Authorized, Lockup)
Initialize a stake with lockup and authorization information
Account references
[WRITE]
Uninitialized stake account[]
Rent sysvar
Authorized carries pubkeys that must sign staker transactions and withdrawer transactions. Lockup carries information about withdrawal restrictions
Authorize(Pubkey, StakeAuthorize)
Authorize a key to manage stake or withdrawal
Account references
[WRITE]
Stake account to be updated[]
Clock sysvar[SIGNER]
The stake or withdraw authority- Optional:
[SIGNER]
Lockup authority, if updating StakeAuthorize::Withdrawer before lockup expiration
DelegateStake
Delegate a stake to a particular vote account
Account references
[WRITE]
Initialized stake account to be delegated[]
Vote account to which this stake will be delegated[]
Clock sysvar[]
Stake history sysvar that carries stake warmup/cooldown history[]
Address of config account that carries stake config[SIGNER]
Stake authority
The entire balance of the staking account is staked. DelegateStake can be called multiple times, but re-delegation is delayed by one epoch
Split(u64)
Split u64 tokens and stake off a stake account into another stake account.
Account references
[WRITE]
Stake account to be split; must be in the Initialized or Stake state[WRITE]
Uninitialized stake account that will take the split-off amount[SIGNER]
Stake authority
Withdraw(u64)
Withdraw unstaked lamports from the stake account
Account references
[WRITE]
Stake account from which to withdraw[WRITE]
Recipient account[]
Clock sysvar[]
Stake history sysvar that carries stake warmup/cooldown history[SIGNER]
Withdraw authority- Optional:
[SIGNER]
Lockup authority, if before lockup expiration
The u64 is the portion of the stake account balance to be withdrawn,
must be <= StakeAccount.lamports - staked_lamports
.
Deactivate
Deactivates the stake in the account
Account references
[WRITE]
Delegated stake account[]
Clock sysvar[SIGNER]
Stake authority
SetLockup(LockupArgs)
Set stake lockup
If a lockup is not active, the withdraw authority may set a new lockup If a lockup is active, the lockup custodian may update the lockup parameters
Account references
[WRITE]
Initialized stake account[SIGNER]
Lockup authority or withdraw authority
Merge
Merge two stake accounts.
Both accounts must have identical lockup and authority keys. A merge is possible between two stakes in the following states with no additional conditions:
- two deactivated stakes
- an inactive stake into an activating stake during its activation epoch
For the following cases, the voter pubkey and vote credits observed must match:
- two activated stakes
- two activating accounts that share an activation epoch, during the activation epoch
All other combinations of stake states will fail to merge, including all “transient” states, where a stake is activating or deactivating with a non-zero effective stake.
Account references
[WRITE]
Destination stake account for the merge[WRITE]
Source stake account for to merge. This account will be drained[]
Clock sysvar[]
Stake history sysvar that carries stake warmup/cooldown history[SIGNER]
Stake authority
AuthorizeWithSeed(AuthorizeWithSeedArgs)
Authorize a key to manage stake or withdrawal with a derived key
Account references
[WRITE]
Stake account to be updated[SIGNER]
Base key of stake or withdraw authority[]
Clock sysvar- Optional:
[SIGNER]
Lockup authority, if updating StakeAuthorize::Withdrawer before lockup expiration
InitializeChecked
Initialize a stake with authorization information
This instruction is similar to Initialize
except that the withdraw authority
must be a signer, and no lockup is applied to the account.
Account references
[WRITE]
Uninitialized stake account[]
Rent sysvar[]
The stake authority[SIGNER]
The withdraw authority
AuthorizeChecked(StakeAuthorize)
Authorize a key to manage stake or withdrawal
This instruction behaves like Authorize
with the additional requirement that the new
stake or withdraw authority must also be a signer.
Account references
[WRITE]
Stake account to be updated[]
Clock sysvar[SIGNER]
The stake or withdraw authority[SIGNER]
The new stake or withdraw authority- Optional:
[SIGNER]
Lockup authority, if updating StakeAuthorize::Withdrawer before lockup expiration
AuthorizeCheckedWithSeed(AuthorizeCheckedWithSeedArgs)
Authorize a key to manage stake or withdrawal with a derived key
This instruction behaves like AuthorizeWithSeed
with the additional requirement that
the new stake or withdraw authority must also be a signer.
Account references
[WRITE]
Stake account to be updated[SIGNER]
Base key of stake or withdraw authority[]
Clock sysvar[SIGNER]
The new stake or withdraw authority- Optional:
[SIGNER]
Lockup authority, if updating StakeAuthorize::Withdrawer before lockup expiration
SetLockupChecked(LockupCheckedArgs)
Set stake lockup
This instruction behaves like SetLockup
with the additional requirement that
the new lockup authority also be a signer.
If a lockup is not active, the withdraw authority may set a new lockup If a lockup is active, the lockup custodian may update the lockup parameters
Account references
[WRITE]
Initialized stake account[SIGNER]
Lockup authority or withdraw authority- Optional:
[SIGNER]
New lockup authority
Trait Implementations§
source§impl Clone for StakeInstruction
impl Clone for StakeInstruction
source§fn clone(&self) -> StakeInstruction
fn clone(&self) -> StakeInstruction
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for StakeInstruction
impl Debug for StakeInstruction
source§impl<'de> Deserialize<'de> for StakeInstruction
impl<'de> Deserialize<'de> for StakeInstruction
source§fn deserialize<__D>(
__deserializer: __D
) -> Result<StakeInstruction, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>( __deserializer: __D ) -> Result<StakeInstruction, <__D as Deserializer<'de>>::Error>where __D: Deserializer<'de>,
source§impl PartialEq<StakeInstruction> for StakeInstruction
impl PartialEq<StakeInstruction> for StakeInstruction
source§fn eq(&self, other: &StakeInstruction) -> bool
fn eq(&self, other: &StakeInstruction) -> bool
self
and other
values to be equal, and is used
by ==
.