Crate pallet_capacity
source ·Expand description
Managages staking to the network for Capacity
Quick Links
- Configuration:
Config
- Extrinsics:
Call
- Runtime API:
CapacityRuntimeApi
- Event Enum:
Event
- Error Enum:
Error
Capacity Pallet
The Capacity Pallet manages the staking and balances for Capacity, an alternative payment system on Frequency.
Summary
Capacity is an alternative to paying with tokens for a limited set of calls. These Capacity eligible extrinsics are noted in each pallet’s documentation with “Capacity” in the Payment column of the extrinsics section. Tokens can be staked to generate Capacity for a targeted Provider. The generated Capacity renews each Epoch. Learn more about Capacity.
Staking & Unstaking
Currently, the token to Capacity ratio is 50:1. For example, for a 5 token stake, a Provider would receive 0.1 Capacity. Staking and unstaking affect available Capacity immediately.
Capacity Epoch
A Capacity Epoch is a period consisting of a specific number of blocks, during which a Provider’s utilization of network Capacity is capped at the amount of generated Capacity targeted to that Provider. At the start of each new Epoch, the available Capacity is renewed for each Provider, regardless of how much they consumed in the prior Epoch. The duration of a Capacity Epoch is determined by Governance, and is currently set to 7200 blocks. With the current average block time of approximately 12 seconds, one Capacity Epoch lasts around 24 hours on Mainnet.
Thaw Period
After unstaking, the tokens will still be frozen for a set amount of time before they are unencumbered and able to be transferred.
The UnstakingThawPeriod
constant defines the number of Epochs that must pass before the tokens may be reclaimed for any use via withdrawUnstaked()
.
Currently it is set to 30 Epochs or ~30 days after unstaking.
Actions
The Capacity Pallet provides for:
- Staking to receive Capacity
- Unstaking & Thaw Period
- Capacity Epoch management
Interactions
Extrinsics
Name/Description | Caller | Payment | Key Events | Runtime Added |
---|---|---|---|---|
change_staking_target Change the target of a stake from one Provider to the other. | Token Account | Tokens | StakingTargetChanged | 1 |
claim_staking_rewards Mint and pay out eligible staking rewards from Provider Boosting. | Token Account | Tokens | ProviderBoostRewardClaimed | 1 |
provider_boost Lock tokens to grant Capacity to a Provider and earn token Rewards | Token Account | Tokens | ProviderBoosted | 1 |
stake Lock tokens to grant Capacity to a Provider | Token Account | Tokens | Staked | 1 |
unstake Begin the process of unlocking tokens by unstaking currently staked tokens | Token Account | Tokens | UnStaked | 1 |
withdraw_unstaked Complete the process of unlocking tokens staked by releasing locks on expired unlock chunks | Token Account | Tokens | StakeWithdrawn | 1 |
See Rust Docs for more details.
State Queries
Name | Description | Query | Runtime Added |
---|---|---|---|
Get Capacity Ledger | Returns the Capacity balance details for a Provider’s MSA Id | capacityLedger | 1 |
Get Current Epoch | Returns the current Capacity Epoch number | currentEpoch | 1 |
Get Current Epoch Info | Returns information about the current Capacity Epoch such as the starting block number | currentEpochInfo | 1 |
Current Era Info | Returns the index of the current era and the block when it started | currentEraInfo | 1 |
Current Era Provider Boost Total | Returns the total amount of token staked this Reward Era, as of the current block | currentProviderBoostTotal | 1 |
Provider Boost Histories | Returns the ProviderBoostHistory stored for the provided AccountId | providerBoostHistories | 1 |
Provider Boost Reward Pool | Returns the Provider Boost Reward Pool Chunk at the given index | providerBoostRewardBools | 1 |
Retargets | Returns the count of retargets and what era was the last retarget, for the provided AccountId. | retargets | 1 |
Get Staking Account Ledger | Returns information about an account’s current staking details | stakingAccountLedger | 1 |
Staking Target Ledger | Returns information about an account’s current staking details for a specific target Provider MSA Id | stakingTargetLedger | 1 |
Get Unstake Information | Returns the information about an account’s current unstaking details and the unlocking chunks | unstakeUnlocks | 1 |
RPCs
Custom RPCs are not enabled for this pallet. The following RuntimeAPI functions may be accessed by making a state call, for example:
const encodedAddr = api.registry.createType('AccountId32', booster.address); // where booster is a polkadot/keyring Keypair type
let result = await api.rcp.state.call('CapacityRuntimeApi_list_unclaimed_rewards', encodedAddr);
const decodedResult: Vec<UnclaimedRewardInfo> = api.registry.createType('Vec<UnclaimedRewardInfo>', result);
Name | Description | Query | Runtime Added |
---|---|---|---|
List unclaimed rewards | Returns a list of UnclaimedRewardInfo for the provided AccountId . | CapacityRuntimeApi_list_unclaimed_rewards | 1 |
See the Rust Docs for additional state queries and details.
Lazy Capacity Refill
Capacity is refilled on an as needed basis. Thus, the provider’s capacity balance retains the information of the last epoch. Upon use, if the last Epoch is less than the current Epoch, the balance is assumed to be the maximum as the reload “has” happened. Thus, the first use of Capacity in an Epoch will update the last Epoch number to match the current Epoch. If a provider does not use any Capacity in an Epoch, the provider’s capacity balance information is never updated for that Epoch.
Re-exports
Modules
- The
pallet
module in each FRAME pallet hosts the most important items needed to construct this pallet. - Types for the Capacity Pallet
- Autogenerated weights for
pallet_capacity
Structs
- Result of checking a Boost History item to see if it’s eligible for a reward.
Traits
- A trait for Non-transferable asset
- A trait for replenishing Capacity.
- A trait for checking that a target MSA can be staked to.
Functions
- Wraps
PREFIX
andPOSTFIX
around aVec<u8>
ReturnsPREFIX
++data
++POSTFIX
Type Aliases
- Some way of identifying an account on the chain. We intentionally make it equivalent to the public key of our transaction signing scheme.
- Balance is a generic type for the balance of an account.
- An index to a block.
- Message Source Id or msaId is the unique identifier for Message Source Accounts
- The type of a Reward Era