Crate pallet_balances
source ·Expand description
Balances Pallet
The Balances pallet provides functionality for handling accounts and balances.
Overview
The Balances pallet provides functions for:
- Getting and setting free balances.
- Retrieving total, reserved and unreserved balances.
- Repatriating a reserved balance to a beneficiary account that exists.
- Transferring a balance between accounts (when not reserved).
- Slashing an account balance.
- Account creation and removal.
- Managing total issuance.
- Setting and managing locks.
Terminology
-
Existential Deposit: The minimum balance required to create or keep an account open. This prevents “dust accounts” from filling storage. When the free plus the reserved balance (i.e. the total balance) fall below this, then the account is said to be dead; and it loses its functionality as well as any prior history and all information on it is removed from the chain’s state. No account should ever have a total balance that is strictly between 0 and the existential deposit (exclusive). If this ever happens, it indicates either a bug in this pallet or an erroneous raw mutation of storage.
-
Total Issuance: The total number of units in existence in a system.
-
Reaping an account: The act of removing an account by resetting its nonce. Happens after its total balance has become zero (or, strictly speaking, less than the Existential Deposit).
-
Free Balance: The portion of a balance that is not reserved. The free balance is the only balance that matters for most operations.
-
Reserved Balance: Reserved balance still belongs to the account holder, but is suspended. Reserved balance can still be slashed, but only after all the free balance has been slashed.
-
Imbalance: A condition when some funds were credited or debited without equal and opposite accounting (i.e. a difference between total issuance and account balances). Functions that result in an imbalance will return an object of the
Imbalance
trait that can be managed within your runtime logic. (If an imbalance is simply dropped, it should automatically maintain any book-keeping such as total issuance.) -
Lock: A freeze on a specified amount of an account’s free balance until a specified block number. Multiple locks always operate over the same funds, so they “overlay” rather than “stack”.
Implementations
The Balances pallet provides implementations for the following traits. If these traits provide the functionality that you need, then you can avoid coupling with the Balances pallet.
Currency
: Functions for dealing with a fungible assets system.ReservableCurrency
:NamedReservableCurrency
: Functions for dealing with assets that can be reserved from an account.LockableCurrency
: Functions for dealing with accounts that allow liquidity restrictions.Imbalance
: Functions for handling imbalances between total issuance in the system and account balances. Must be used when a function creates new funds (e.g. a reward) or destroys some funds (e.g. a system fee).
Interface
Dispatchable Functions
transfer_allow_death
- Transfer some liquid free balance to another account.force_set_balance
- Set the balances of a given account. The origin of this call must be root.
Usage
The following examples show how to use the Balances pallet in your custom pallet.
Examples from the FRAME
The Contract pallet uses the Currency
trait to handle gas payment, and its types inherit from
Currency
:
use frame_support::traits::Currency;
pub type BalanceOf<T> = <<T as Config>::Currency as Currency<<T as frame_system::Config>::AccountId>>::Balance;
pub type NegativeImbalanceOf<T> = <<T as Config>::Currency as Currency<<T as frame_system::Config>::AccountId>>::NegativeImbalance;
The Staking pallet uses the LockableCurrency
trait to lock a stash account’s funds:
use frame_support::traits::{WithdrawReasons, LockableCurrency};
use sp_runtime::traits::Bounded;
pub trait Config: frame_system::Config {
type Currency: LockableCurrency<Self::AccountId, Moment=frame_system::pallet_prelude::BlockNumberFor<Self>>;
}
fn update_ledger<T: Config>(
controller: &T::AccountId,
ledger: &StakingLedger<T>
) {
T::Currency::set_lock(
STAKING_ID,
&ledger.stash,
ledger.total,
WithdrawReasons::all()
);
// <Ledger<T>>::insert(controller, ledger); // Commented out as we don't have access to Staking's storage here.
}
Genesis config
The Balances pallet depends on the GenesisConfig
.
Assumptions
- Total issued balanced of all accounts should be less than
Config::Balance::max_value()
. - Existential Deposit is set to a value greater than zero.
Note, you may find the Balances pallet still functions with an ED of zero in some circumstances, however this is not a configuration which is generally supported, nor will it be.
Re-exports
pub use weights::WeightInfo;
pub use pallet::*;
Modules
- The
pallet
module in each FRAME pallet hosts the most important items needed to construct this pallet. - Autogenerated weights for pallet_balances
Structs
- All balance information for an account.
- A single lock on a balance. There can be many of these on an account and they “overlap”, so the same balance is frozen by multiple locks.
- An identifier and balance.
- Opaque, move-only struct with private fields that serves as a token denoting that funds have been destroyed without any equal and opposite accounting.
- Opaque, move-only struct with private fields that serves as a token denoting that funds have been created without any equal and opposite accounting.
- Store named reserved balance.
Enums
- Simplified reasons for withdrawing balance.