pub struct Staking {}
Expand description
Staking-related interactions with the NEAR Protocol and the staking pools.
The Staking
struct provides methods to interact with NEAR staking, including querying staking pools, validators, and delegators,
as well as delegating and withdrawing from staking pools.
§Examples
use near_api::*;
let staking_pools = Staking::active_staking_pools().fetch_from_testnet().await?;
println!("Staking pools: {:?}", staking_pools);
Implementations§
Source§impl Staking
impl Staking
Sourcepub fn active_staking_pools() -> QueryBuilder<PostprocessHandler<BTreeSet<AccountId>, ViewStateHandler>>
pub fn active_staking_pools() -> QueryBuilder<PostprocessHandler<BTreeSet<AccountId>, ViewStateHandler>>
Returns a list of active staking pools (std::collections::BTreeSet<AccountId>]) by querying the staking pools factory contract.
Please note that it might fail on the mainnet as the staking pool factory is super huge.
§Example
use near_api::*;
let staking_pools = Staking::active_staking_pools().fetch_from_testnet().await?;
println!("Staking pools: {:?}", staking_pools);
Sourcepub fn epoch_validators_info() -> ValidatorQueryBuilder<RpcValidatorHandler>
pub fn epoch_validators_info() -> ValidatorQueryBuilder<RpcValidatorHandler>
Returns a list of validators and their stake (near_primitives::views::EpochValidatorInfo) for the current epoch.
§Example
use near_api::*;
let validators = Staking::epoch_validators_info().fetch_from_testnet().await?;
println!("Validators: {:?}", validators);
Sourcepub fn validators_stake() -> ValidatorQueryBuilder<PostprocessHandler<BTreeMap<AccountId, NearToken>, RpcValidatorHandler>>
pub fn validators_stake() -> ValidatorQueryBuilder<PostprocessHandler<BTreeMap<AccountId, NearToken>, RpcValidatorHandler>>
Returns a map of validators and their stake (BTreeMap<AccountId, NearToken>) for the current epoch.
§Example
use near_api::*;
let validators = Staking::validators_stake().fetch_from_testnet().await?;
println!("Validators: {:?}", validators);
Sourcepub fn staking_pool_reward_fee(
pool: AccountId,
) -> QueryBuilder<CallResultHandler<RewardFeeFraction>>
pub fn staking_pool_reward_fee( pool: AccountId, ) -> QueryBuilder<CallResultHandler<RewardFeeFraction>>
Prepares a new contract query (get_reward_fee_fraction
) for fetching the reward fee fraction of the staking pool (Data<RewardFeeFraction>).
The call depends that the contract implements StakingPool
§Example
use near_api::*;
let reward_fee = Staking::staking_pool_reward_fee("pool.testnet".parse()?)
.fetch_from_testnet().await?;
println!("Reward fee: {:?}", reward_fee);
Sourcepub fn staking_pool_delegators(
pool: AccountId,
) -> QueryBuilder<CallResultHandler<u64>>
pub fn staking_pool_delegators( pool: AccountId, ) -> QueryBuilder<CallResultHandler<u64>>
Prepares a new contract query (get_number_of_accounts
) for fetching the number of delegators of the staking pool (Data<u64>).
The call depends that the contract implements StakingPool
§Example
use near_api::*;
let delegators = Staking::staking_pool_delegators("pool.testnet".parse()?)
.fetch_from_testnet()
.await?;
println!("Delegators: {:?}", delegators);
Sourcepub fn staking_pool_total_stake(
pool: AccountId,
) -> QueryBuilder<PostprocessHandler<NearToken, CallResultHandler<u128>>>
pub fn staking_pool_total_stake( pool: AccountId, ) -> QueryBuilder<PostprocessHandler<NearToken, CallResultHandler<u128>>>
Prepares a new contract query (get_total_staked_balance
) for fetching the total stake of the staking pool (NearToken).
The call depends that the contract implements StakingPool
§Example
use near_api::*;
let total_stake = Staking::staking_pool_total_stake("pool.testnet".parse()?)
.fetch_from_testnet()
.await?;
println!("Total stake: {:?}", total_stake);
Sourcepub fn staking_pool_info(
pool: AccountId,
) -> MultiQueryBuilder<PostprocessHandler<StakingPoolInfo, MultiQueryHandler<(CallResultHandler<RewardFeeFraction>, CallResultHandler<u64>, CallResultHandler<u128>)>>>
pub fn staking_pool_info( pool: AccountId, ) -> MultiQueryBuilder<PostprocessHandler<StakingPoolInfo, MultiQueryHandler<(CallResultHandler<RewardFeeFraction>, CallResultHandler<u64>, CallResultHandler<u128>)>>>
Returns a full information about the staking pool (StakingPoolInfo).
This is a complex query that requires 3 calls (get_reward_fee_fraction, get_number_of_accounts, get_total_staked_balance) to the staking pool contract.
The call depends that the contract implements StakingPool
§Example
use near_api::*;
let staking_pool_info = Staking::staking_pool_info("pool.testnet".parse()?)
.fetch_from_testnet()
.await?;
println!("Staking pool info: {:?}", staking_pool_info);
Sourcepub const fn delegation(account_id: AccountId) -> Delegation
pub const fn delegation(account_id: AccountId) -> Delegation
Returns a new Delegation
struct for interacting with the staking pool on behalf of the account.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Staking
impl RefUnwindSafe for Staking
impl Send for Staking
impl Sync for Staking
impl Unpin for Staking
impl UnwindSafe for Staking
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.