pub trait Config<I: 'static = ()>: Config + Config<RuntimeEvent: From<Event<Self, I>>> {
Show 19 associated items
    type Currency: Currency<Self::AccountId> + ReservableCurrency<Self::AccountId>;
    type RejectOrigin: EnsureOrigin<Self::RuntimeOrigin>;
    type RuntimeEvent: From<Event<Self, I>> + IsType<<Self as Config>::RuntimeEvent>;
    type SpendPeriod: Get<BlockNumberFor<Self, I>>;
    type Burn: Get<Permill>;
    type PalletId: Get<PalletId>;
    type BurnDestination: OnUnbalanced<NegativeImbalanceOf<Self, I>>;
    type WeightInfo: WeightInfo;
    type SpendFunds: SpendFunds<Self, I>;
    type MaxApprovals: Get<u32>;
    type SpendOrigin: EnsureOrigin<Self::RuntimeOrigin, Success = BalanceOf<Self, I>>;
    type AssetKind: Parameter + MaxEncodedLen;
    type Beneficiary: Parameter + MaxEncodedLen;
    type BeneficiaryLookup: StaticLookup<Target = Self::Beneficiary>;
    type Paymaster: Pay<Beneficiary = Self::Beneficiary, AssetKind = Self::AssetKind>;
    type BalanceConverter: ConversionFromAssetBalance<<Self::Paymaster as Pay>::Balance, Self::AssetKind, BalanceOf<Self, I>>;
    type PayoutPeriod: Get<BlockNumberFor<Self, I>>;
    type BenchmarkHelper: ArgumentsFactory<Self::AssetKind, Self::Beneficiary>;
    type BlockNumberProvider: BlockNumberProvider;
}Expand description
Configuration trait of this pallet.
The main purpose of this trait is to act as an interface between this pallet and the runtime in which it is embedded in. A type, function, or constant in this trait is essentially left to be configured by the runtime that includes this pallet.
Consequently, a runtime that wants to include this pallet must implement this trait.
Required Associated Types§
Sourcetype Currency: Currency<Self::AccountId> + ReservableCurrency<Self::AccountId>
 
type Currency: Currency<Self::AccountId> + ReservableCurrency<Self::AccountId>
The staking balance.
Sourcetype RejectOrigin: EnsureOrigin<Self::RuntimeOrigin>
 
type RejectOrigin: EnsureOrigin<Self::RuntimeOrigin>
Origin from which rejections must come.
Sourcetype RuntimeEvent: From<Event<Self, I>> + IsType<<Self as Config>::RuntimeEvent>
 
type RuntimeEvent: From<Event<Self, I>> + IsType<<Self as Config>::RuntimeEvent>
The overarching event type.
Sourcetype SpendPeriod: Get<BlockNumberFor<Self, I>>
 
type SpendPeriod: Get<BlockNumberFor<Self, I>>
Period between successive spends.
Sourcetype PalletId: Get<PalletId>
 
type PalletId: Get<PalletId>
The treasury’s pallet id, used for deriving its sovereign account ID.
Sourcetype BurnDestination: OnUnbalanced<NegativeImbalanceOf<Self, I>>
 
type BurnDestination: OnUnbalanced<NegativeImbalanceOf<Self, I>>
Handler for the unbalanced decrease when treasury funds are burned.
Sourcetype WeightInfo: WeightInfo
 
type WeightInfo: WeightInfo
Weight information for extrinsics in this pallet.
Sourcetype SpendFunds: SpendFunds<Self, I>
 
type SpendFunds: SpendFunds<Self, I>
Runtime hooks to external pallet using treasury to compute spend funds.
Sourcetype MaxApprovals: Get<u32>
 
type MaxApprovals: Get<u32>
DEPRECATED: associated with spend_local call and will be removed in May 2025.
Refer to https://github.com/paritytech/polkadot-sdk/pull/5961 for migration to spend.
The maximum number of approvals that can wait in the spending queue.
NOTE: This parameter is also used within the Bounties Pallet extension if enabled.
Sourcetype SpendOrigin: EnsureOrigin<Self::RuntimeOrigin, Success = BalanceOf<Self, I>>
 
type SpendOrigin: EnsureOrigin<Self::RuntimeOrigin, Success = BalanceOf<Self, I>>
The origin required for approving spends from the treasury outside of the proposal
process. The Success value is the maximum amount in a native asset that this origin
is allowed to spend at a time.
Sourcetype AssetKind: Parameter + MaxEncodedLen
 
type AssetKind: Parameter + MaxEncodedLen
Type parameter representing the asset kinds to be spent from the treasury.
Sourcetype Beneficiary: Parameter + MaxEncodedLen
 
type Beneficiary: Parameter + MaxEncodedLen
Type parameter used to identify the beneficiaries eligible to receive treasury spends.
Sourcetype BeneficiaryLookup: StaticLookup<Target = Self::Beneficiary>
 
type BeneficiaryLookup: StaticLookup<Target = Self::Beneficiary>
Converting trait to take a source type and convert to Self::Beneficiary.
Sourcetype Paymaster: Pay<Beneficiary = Self::Beneficiary, AssetKind = Self::AssetKind>
 
type Paymaster: Pay<Beneficiary = Self::Beneficiary, AssetKind = Self::AssetKind>
Type for processing spends of Self::AssetKind in favor of Self::Beneficiary.
Sourcetype BalanceConverter: ConversionFromAssetBalance<<Self::Paymaster as Pay>::Balance, Self::AssetKind, BalanceOf<Self, I>>
 
type BalanceConverter: ConversionFromAssetBalance<<Self::Paymaster as Pay>::Balance, Self::AssetKind, BalanceOf<Self, I>>
Type for converting the balance of an Self::AssetKind to the balance of the native
asset, solely for the purpose of asserting the result against the maximum allowed spend
amount of the Self::SpendOrigin.
Sourcetype PayoutPeriod: Get<BlockNumberFor<Self, I>>
 
type PayoutPeriod: Get<BlockNumberFor<Self, I>>
The period during which an approved treasury spend has to be claimed.
Sourcetype BenchmarkHelper: ArgumentsFactory<Self::AssetKind, Self::Beneficiary>
 
type BenchmarkHelper: ArgumentsFactory<Self::AssetKind, Self::Beneficiary>
Helper type for benchmarks.
Sourcetype BlockNumberProvider: BlockNumberProvider
 
type BlockNumberProvider: BlockNumberProvider
Provider for the block number. Normally this is the frame_system pallet.
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.