Enum solana_program::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
sourceimpl Clone for StakeInstruction
impl Clone for StakeInstruction
sourcefn clone(&self) -> StakeInstruction
fn clone(&self) -> StakeInstruction
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more