#![cfg_attr(not(feature = "std"), no_std)]
#![recursion_limit = "512"]
#![allow(clippy::identity_op)]
use cfg_primitives::{
constants::*,
liquidity_pools::GeneralCurrencyPrefix,
types::{
AccountId, Address, AuraId, Balance, BlockNumber, CollectionId, Hash, Hashing, Header,
IBalance, InvestmentId, ItemId, LoanId, Nonce, OrderId, PalletIndex, PoolEpochId,
PoolFeeId, PoolId, Signature, TrancheId, TrancheWeight,
},
LPGatewayQueueMessageNonce, LPGatewaySessionId,
};
use cfg_traits::{
investments::OrderManager, Millis, Permissions as PermissionsT, PoolUpdateGuard, PreConditions,
Seconds,
};
use cfg_types::{
domain_address::DomainAddress,
fee_keys::{Fee, FeeKey},
fixed_point::{Quantity, Rate, Ratio},
investments::InvestmentPortfolio,
locations::RestrictedTransferLocation,
oracles::OracleKey,
permissions::{
PermissionRoles, PermissionScope, PermissionedCurrencyRole, PoolRole, Role, UNION,
},
pools::PoolNav,
time::TimeProvider,
tokens::{
AssetStringLimit, CurrencyId, CustomMetadata, FilterCurrency, LocalAssetId,
StakingCurrency::BlockRewards as BlockRewardsCurrency,
},
};
use chainbridge::constants::DEFAULT_RELAYER_VOTE_THRESHOLD;
use cumulus_primitives_core::{AggregateMessageOrigin, ParaId};
use fp_rpc::TransactionStatus;
use frame_support::{
construct_runtime,
dispatch::DispatchClass,
genesis_builder_helper::{build_config, create_default_config},
pallet_prelude::{DispatchError, RuntimeDebug},
parameter_types,
traits::{
fungible::HoldConsideration,
tokens::{PayFromAccount, UnityAssetBalanceConversion},
AsEnsureOriginWithArg, ConstBool, ConstU32, ConstU64, Contains, EitherOf, EitherOfDiverse,
EqualPrivilegeOnly, Get, InstanceFilter, LinearStoragePrice, LockIdentifier, OnFinalize,
PalletInfoAccess, TransformOrigin, UnixTime, WithdrawReasons,
},
weights::{
constants::{BlockExecutionWeight, ExtrinsicBaseWeight, RocksDbWeight},
ConstantMultiplier, Weight,
},
PalletId,
};
use frame_system::{
limits::{BlockLength, BlockWeights},
EnsureRoot, EnsureSigned, EnsureWithSuccess,
};
use orml_traits::currency::MutationHooks;
use pallet_anchors::AnchorData;
use pallet_collective::EnsureMember;
use pallet_ethereum::{Call::transact, PostLogContent, Transaction as EthTransaction};
use pallet_evm::{
Account as EVMAccount, EnsureAddressNever, EnsureAddressRoot, FeeCalculator, GasWeightMapping,
Runner,
};
use pallet_liquidity_pools_gateway::message::GatewayMessage;
pub use pallet_loans::entities::{input::PriceCollectionInput, loans::ActiveLoanInfo};
use pallet_loans::types::cashflow::CashflowPayment;
use pallet_pool_system::{
pool_types::{PoolDetails, ScheduledUpdateDetails},
tranches::{TrancheIndex, TrancheLoc, TrancheSolution},
EpochSolution,
};
use pallet_restricted_tokens::{
FungibleInspectPassthrough, FungiblesInspectPassthrough, TransferDetails,
};
use pallet_transaction_payment::CurrencyAdapter;
use pallet_transaction_payment_rpc_runtime_api::{FeeDetails, RuntimeDispatchInfo};
use parity_scale_codec::{Decode, Encode, MaxEncodedLen};
use polkadot_runtime_common::{
xcm_sender::NoPriceForMessageDelivery, BlockHashCount, SlowAdjustingFeeUpdate,
};
use runtime_common::{
account_conversion::{AccountConverter, RuntimeAccountConverter},
asset_registry,
changes::FastDelay,
evm::{
self, BaseFeeThreshold, FindAuthorTruncated, GAS_LIMIT_POV_SIZE_RATIO,
GAS_LIMIT_STORAGE_GROWTH_RATIO, WEIGHT_PER_GAS,
},
fees::{DealWithFees, FeeToTreasury, WeightToFee},
gateway, instances,
instances::{CouncilCollective, TechnicalCollective, TechnicalMembership},
message_queue::{NarrowOriginToSibling, ParaIdToSibling},
oracle::{DigestedOracleRatioProvider, Feeder, OracleConverterBridge, OracleRatioProvider},
origins::gov::{
pallet_custom_origins,
types::{
AllOfCouncil, DispatchWhitelistedOrigin, EnsureRootOr, HalfOfCouncil, RefCancelOrigin,
RefKillerOrigin, TreasuryApproveOrigin, TwoThirdOfCouncil, WhitelistOrigin,
},
PoolAdmin, Treasurer,
},
permissions::{IsUnfrozenTrancheInvestor, PoolAdminCheck},
remarks::Remark,
rewards::SingleCurrencyMovement,
routing::{
EvmAccountCodeChecker, LPGatewayRouterProvider, MessageSerializer, RouterDispatcher,
RouterId,
},
transfer_filter::{PreLpTransfer, PreNativeTransfer},
xcm::AccountIdToLocation,
xcm_transactor, AllowanceDeposit, CurrencyED,
};
use scale_info::TypeInfo;
use sp_api::impl_runtime_apis;
use sp_core::{OpaqueMetadata, H160, H256, U256};
use sp_inherents::{CheckInherentsResult, InherentData};
use sp_runtime::{
create_runtime_str, generic, impl_opaque_keys,
traits::{
AccountIdConversion, BlakeTwo256, Block as BlockT, ConvertInto, DispatchInfoOf,
Dispatchable, IdentityLookup, PostDispatchInfoOf, UniqueSaturatedInto, Verify, Zero,
},
transaction_validity::{TransactionSource, TransactionValidity, TransactionValidityError},
ApplyExtrinsicResult, FixedI128, Perbill, Permill, Perquintill,
};
use sp_staking::currency_to_vote::U128CurrencyToVote;
use sp_std::{marker::PhantomData, prelude::*, vec::Vec};
use sp_version::RuntimeVersion;
use staging_xcm::v4::{Asset, Location};
use static_assertions::const_assert;
use crate::{tracks::TracksInfo, xcm::*};
mod migrations;
mod tracks;
mod weights;
pub mod xcm;
#[cfg(feature = "std")]
include!(concat!(env!("OUT_DIR"), "/wasm_binary.rs"));
impl_opaque_keys! {
pub struct SessionKeys {
pub aura: Aura,
pub block_rewards: BlockRewards,
}
}
#[sp_version::runtime_version]
pub const VERSION: RuntimeVersion = RuntimeVersion {
spec_name: create_runtime_str!("centrifuge-devel"),
impl_name: create_runtime_str!("centrifuge-devel"),
authoring_version: 1,
spec_version: 1403,
impl_version: 1,
apis: RUNTIME_API_VERSIONS,
transaction_version: 2,
state_version: 0,
};
#[cfg(any(feature = "std", test))]
pub fn native_version() -> sp_version::NativeVersion {
sp_version::NativeVersion {
runtime_version: VERSION,
can_author_with: Default::default(),
}
}
parameter_types! {
pub const MaximumBlockWeight: Weight = MAXIMUM_BLOCK_WEIGHT;
pub const Version: RuntimeVersion = VERSION;
pub RuntimeBlockLength: BlockLength =
BlockLength::max_with_normal_ratio(5 * 1024 * 1024, NORMAL_DISPATCH_RATIO);
pub RuntimeBlockWeights: BlockWeights = BlockWeights::builder()
.base_block(BlockExecutionWeight::get())
.for_class(DispatchClass::all(), |weights| {
weights.base_extrinsic = ExtrinsicBaseWeight::get();
})
.for_class(DispatchClass::Normal, |weights| {
weights.max_total = Some(NORMAL_DISPATCH_RATIO * MAXIMUM_BLOCK_WEIGHT);
})
.for_class(DispatchClass::Operational, |weights| {
weights.max_total = Some(MAXIMUM_BLOCK_WEIGHT);
weights.reserved = Some(
MAXIMUM_BLOCK_WEIGHT - NORMAL_DISPATCH_RATIO * MAXIMUM_BLOCK_WEIGHT
);
})
.avg_block_initialization(AVERAGE_ON_INITIALIZE_RATIO)
.build_or_panic();
pub const SS58Prefix: u8 = 136;
}
impl frame_system::Config for Runtime {
type AccountData = pallet_balances::AccountData<Balance>;
type AccountId = AccountId;
type BaseCallFilter = BaseCallFilter;
type Block = Block;
type BlockHashCount = BlockHashCount;
type BlockLength = RuntimeBlockLength;
type BlockWeights = RuntimeBlockWeights;
type DbWeight = RocksDbWeight;
type Hash = Hash;
type Hashing = Hashing;
type Lookup = sp_runtime::traits::AccountIdLookup<AccountId, ()>;
type MaxConsumers = frame_support::traits::ConstU32<16>;
type Nonce = Nonce;
type OnKilledAccount = ();
type OnNewAccount = ();
type OnSetCode = cumulus_pallet_parachain_system::ParachainSetCode<Self>;
type PalletInfo = PalletInfo;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type RuntimeOrigin = RuntimeOrigin;
type RuntimeTask = RuntimeTask;
type SS58Prefix = SS58Prefix;
type SystemWeightInfo = weights::frame_system::WeightInfo<Runtime>;
type Version = Version;
}
pub struct BaseCallFilter;
impl Contains<RuntimeCall> for BaseCallFilter {
fn contains(c: &RuntimeCall) -> bool {
match c {
RuntimeCall::PolkadotXcm(method) => match method {
pallet_xcm::Call::execute { .. }
| pallet_xcm::Call::transfer_assets { .. }
| pallet_xcm::Call::teleport_assets { .. } | pallet_xcm::Call::reserve_transfer_assets { .. } | pallet_xcm::Call::limited_reserve_transfer_assets { .. }
| pallet_xcm::Call::limited_teleport_assets { .. } => false,
pallet_xcm::Call::__Ignore { .. } => {
unimplemented!()
}
pallet_xcm::Call::send { .. }
| pallet_xcm::Call::force_xcm_version { .. }
| pallet_xcm::Call::force_suspension { .. }
| pallet_xcm::Call::force_default_xcm_version { .. }
| pallet_xcm::Call::force_subscribe_version_notify { .. }
| pallet_xcm::Call::force_unsubscribe_version_notify { .. } => true,
},
RuntimeCall::XcmTransactor(
pallet_xcm_transactor::Call::transact_through_derivative { .. },
) => false,
_ => true,
}
}
}
parameter_types! {
pub const ReservedXcmpWeight: Weight = MAXIMUM_BLOCK_WEIGHT.saturating_div(4);
pub const ReservedDmpWeight: Weight = MAXIMUM_BLOCK_WEIGHT.saturating_div(4);
pub const RelayOrigin: AggregateMessageOrigin = AggregateMessageOrigin::Parent;
}
impl cumulus_pallet_parachain_system::Config for Runtime {
type CheckAssociatedRelayNumber = cumulus_pallet_parachain_system::AnyRelayNumber;
type DmpQueue = frame_support::traits::EnqueueWithOrigin<MessageQueue, RelayOrigin>;
type OnSystemEvent = ();
type OutboundXcmpMessageSource = XcmpQueue;
type ReservedDmpWeight = ReservedDmpWeight;
type ReservedXcmpWeight = ReservedXcmpWeight;
type RuntimeEvent = RuntimeEvent;
type SelfParaId = staging_parachain_info::Pallet<Runtime>;
type WeightInfo = cumulus_pallet_parachain_system::weights::SubstrateWeight<Runtime>;
type XcmpMessageHandler = XcmpQueue;
}
impl staging_parachain_info::Config for Runtime {}
parameter_types! {
pub MessageQueueServiceWeight: Weight = Perbill::from_percent(35) * RuntimeBlockWeights::get().max_block;
}
impl pallet_message_queue::Config for Runtime {
type HeapSize = sp_core::ConstU32<{ 64 * 1024 }>;
type MaxStale = sp_core::ConstU32<8>;
#[cfg(feature = "runtime-benchmarks")]
type MessageProcessor =
pallet_message_queue::mock_helpers::NoopMessageProcessor<AggregateMessageOrigin>;
#[cfg(not(feature = "runtime-benchmarks"))]
type MessageProcessor = staging_xcm_builder::ProcessXcmMessage<
AggregateMessageOrigin,
staging_xcm_executor::XcmExecutor<XcmConfig>,
RuntimeCall,
>;
type QueueChangeHandler = NarrowOriginToSibling<XcmpQueue>;
type QueuePausedQuery = NarrowOriginToSibling<XcmpQueue>;
type RuntimeEvent = RuntimeEvent;
type ServiceWeight = MessageQueueServiceWeight;
type Size = u32;
type WeightInfo = pallet_message_queue::weights::SubstrateWeight<Runtime>;
}
impl cumulus_pallet_xcmp_queue::Config for Runtime {
type ChannelInfo = ParachainSystem;
type ControllerOrigin = EnsureRoot<AccountId>;
type ControllerOriginConverter = XcmOriginToTransactDispatchOrigin;
type MaxInboundSuspended = sp_core::ConstU32<1_000>;
type PriceForSiblingDelivery = NoPriceForMessageDelivery<ParaId>;
type RuntimeEvent = RuntimeEvent;
type VersionWrapper = PolkadotXcm;
type WeightInfo = weights::cumulus_pallet_xcmp_queue::WeightInfo<Runtime>;
type XcmpQueue = TransformOrigin<MessageQueue, AggregateMessageOrigin, ParaId, ParaIdToSibling>;
}
parameter_types! {
pub const MinimumPeriod: Millis = SLOT_DURATION / 2;
}
impl pallet_timestamp::Config for Runtime {
type MinimumPeriod = MinimumPeriod;
type Moment = Millis;
type OnTimestampSet = Aura;
type WeightInfo = weights::pallet_timestamp::WeightInfo<Runtime>;
}
parameter_types! {
pub const TransactionByteFee: Balance = 1 * (MICRO_CFG / 100);
pub const OperationalFeeMultiplier: u8 = 5;
}
impl pallet_transaction_payment::Config for Runtime {
type FeeMultiplierUpdate = SlowAdjustingFeeUpdate<Self>;
type LengthToFee = ConstantMultiplier<Balance, TransactionByteFee>;
type OnChargeTransaction = CurrencyAdapter<Balances, DealWithFees<Runtime>>;
type OperationalFeeMultiplier = OperationalFeeMultiplier;
type RuntimeEvent = RuntimeEvent;
type WeightToFee = WeightToFee;
}
parameter_types! {
pub const ExistentialDeposit: Balance = 1 * MICRO_CFG;
pub const MaxLocks: u32 = 50;
pub const MaxReserves: u32 = 50;
}
impl pallet_balances::Config for Runtime {
type AccountStore = System;
type Balance = Balance;
type DustRemoval = ();
type ExistentialDeposit = ExistentialDeposit;
type FreezeIdentifier = ();
type MaxFreezes = ConstU32<10>;
type MaxLocks = MaxLocks;
type MaxReserves = MaxReserves;
type ReserveIdentifier = [u8; 8];
type RuntimeEvent = RuntimeEvent;
type RuntimeFreezeReason = RuntimeFreezeReason;
type RuntimeHoldReason = RuntimeHoldReason;
type WeightInfo = weights::pallet_balances::WeightInfo<Self>;
}
parameter_types! {
pub const UncleGenerations: BlockNumber = 5;
}
impl pallet_authorship::Config for Runtime {
type EventHandler = (CollatorSelection,);
type FindAuthor = pallet_session::FindAccountFromAuthorIndex<Self, Aura>;
}
parameter_types! {
pub Period: u32 = 2 * MINUTES;
pub const Offset: u32 = 0;
}
impl pallet_session::Config for Runtime {
type Keys = SessionKeys;
type NextSessionRotation = pallet_session::PeriodicSessions<Period, Offset>;
type RuntimeEvent = RuntimeEvent;
type SessionHandler = <SessionKeys as sp_runtime::traits::OpaqueKeys>::KeyTypeIdProviders;
type SessionManager = CollatorSelection;
type ShouldEndSession = pallet_session::PeriodicSessions<Period, Offset>;
type ValidatorId = <Self as frame_system::Config>::AccountId;
type ValidatorIdOf = pallet_collator_selection::IdentityCollator;
type WeightInfo = weights::pallet_session::WeightInfo<Self>;
}
parameter_types! {
#[derive(scale_info::TypeInfo, Debug, PartialEq, Eq, Clone)]
pub const MaxAuthorities: u32 = 32;
}
impl pallet_aura::Config for Runtime {
type AllowMultipleBlocksPerSlot = ConstBool<false>;
type AuthorityId = AuraId;
type DisabledValidators = ();
type MaxAuthorities = MaxAuthorities;
}
impl cumulus_pallet_aura_ext::Config for Runtime {}
parameter_types! {
pub const DepositBase: Balance = 30 * CENTI_CFG;
pub const DepositFactor: Balance = 5 * CENTI_CFG;
pub const MaxSignatories: u16 = 100;
}
impl pallet_multisig::Config for Runtime {
type Currency = Balances;
type DepositBase = DepositBase;
type DepositFactor = DepositFactor;
type MaxSignatories = MaxSignatories;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_multisig::WeightInfo<Runtime>;
}
parameter_types! {
pub const ProxyDepositBase: Balance = 30 * CENTI_CFG;
pub const ProxyDepositFactor: Balance = 5 * CENTI_CFG;
pub const MaxProxies: u16 = 32;
pub const AnnouncementDepositBase: Balance = deposit(1, 8);
pub const AnnouncementDepositFactor: Balance = deposit(0, 66);
pub const MaxPending: u16 = 32;
}
#[derive(
Copy,
Clone,
Eq,
PartialEq,
Ord,
PartialOrd,
Encode,
Decode,
RuntimeDebug,
MaxEncodedLen,
TypeInfo,
)]
pub enum ProxyType {
Any,
NonTransfer,
Governance,
_Staking, NonProxy,
Borrow,
Invest,
ProxyManagement,
KeystoreManagement,
PodOperation,
PodAuth,
PermissionManagement,
Transfer,
}
impl Default for ProxyType {
fn default() -> Self {
Self::Any
}
}
impl InstanceFilter<RuntimeCall> for ProxyType {
fn filter(&self, c: &RuntimeCall) -> bool {
match self {
ProxyType::Any => true,
ProxyType::NonTransfer => {
matches!(
c,
RuntimeCall::System(..) |
RuntimeCall::ParachainSystem(..) |
RuntimeCall::Timestamp(..) |
RuntimeCall::CollatorSelection(..) |
RuntimeCall::Session(..) |
RuntimeCall::Multisig(..) |
RuntimeCall::Proxy(..) |
RuntimeCall::Utility(..) |
RuntimeCall::Scheduler(..) |
RuntimeCall::Council(..) |
RuntimeCall::Elections(..) |
RuntimeCall::Democracy(..) |
RuntimeCall::ConvictionVoting(..) |
RuntimeCall::Referenda(..) |
RuntimeCall::TechnicalCommittee(..) |
RuntimeCall::TechnicalCommitteeMembership(..) |
RuntimeCall::Whitelist(..) |
RuntimeCall::Identity(..) |
RuntimeCall::Vesting(pallet_vesting::Call::vest {..}) |
RuntimeCall::Vesting(pallet_vesting::Call::vest_other {..}) |
RuntimeCall::Treasury(..) |
RuntimeCall::Uniques(..) |
RuntimeCall::Preimage(..) |
RuntimeCall::Fees(..) |
RuntimeCall::Anchor(..) |
RuntimeCall::PoolSystem(..) |
RuntimeCall::Loans(pallet_loans::Call::create{..}) |
RuntimeCall::Loans(pallet_loans::Call::write_off{..}) |
RuntimeCall::Loans(pallet_loans::Call::admin_write_off{..}) |
RuntimeCall::Loans(pallet_loans::Call::propose_loan_mutation{..}) |
RuntimeCall::Loans(pallet_loans::Call::apply_loan_mutation{..}) |
RuntimeCall::Loans(pallet_loans::Call::close{..}) |
RuntimeCall::Loans(pallet_loans::Call::propose_write_off_policy{..}) |
RuntimeCall::Loans(pallet_loans::Call::apply_write_off_policy{..}) |
RuntimeCall::Loans(pallet_loans::Call::update_portfolio_valuation{..}) |
RuntimeCall::Loans(pallet_loans::Call::propose_transfer_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::apply_transfer_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::increase_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::decrease_debt { .. }) |
RuntimeCall::Permissions(..) |
RuntimeCall::CollatorAllowlist(..) |
RuntimeCall::Keystore(..) |
RuntimeCall::Investments(pallet_investments::Call::collect_investments_for {..}) |
RuntimeCall::Investments(pallet_investments::Call::collect_redemptions_for {..}) |
RuntimeCall::LiquidityRewards(..) |
RuntimeCall::BlockRewards(..) |
RuntimeCall::PoolRegistry(pallet_pool_registry::Call::execute_update {..})
)
}
ProxyType::Governance => matches!(
c,
RuntimeCall::Democracy(..)
| RuntimeCall::Council(..)
| RuntimeCall::Elections(..)
| RuntimeCall::Utility(..)
| RuntimeCall::ConvictionVoting(..)
| RuntimeCall::Referenda(..)
| RuntimeCall::TechnicalCommittee(..)
| RuntimeCall::TechnicalCommitteeMembership(..)
| RuntimeCall::Whitelist(..)
),
ProxyType::_Staking => false,
ProxyType::NonProxy => {
matches!(c, RuntimeCall::Proxy(pallet_proxy::Call::proxy { .. }))
|| !matches!(c, RuntimeCall::Proxy(..))
}
ProxyType::Borrow => {
matches!(
c,
RuntimeCall::Loans(pallet_loans::Call::create { .. }) |
RuntimeCall::Loans(pallet_loans::Call::borrow { .. }) |
RuntimeCall::Loans(pallet_loans::Call::repay { .. }) |
RuntimeCall::Loans(pallet_loans::Call::write_off { .. }) |
RuntimeCall::Loans(pallet_loans::Call::apply_loan_mutation { .. }) |
RuntimeCall::Loans(pallet_loans::Call::close { .. }) |
RuntimeCall::Loans(pallet_loans::Call::apply_write_off_policy { .. }) |
RuntimeCall::Loans(pallet_loans::Call::update_portfolio_valuation { .. }) |
RuntimeCall::Loans(pallet_loans::Call::propose_transfer_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::apply_transfer_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::increase_debt { .. }) |
RuntimeCall::Loans(pallet_loans::Call::decrease_debt { .. }) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::close_epoch { .. }) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::submit_solution { .. }) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::execute_epoch { .. }) |
RuntimeCall::Utility(pallet_utility::Call::batch_all { .. }) |
RuntimeCall::Utility(pallet_utility::Call::batch { .. }) |
RuntimeCall::TokenMux(pallet_token_mux::Call::burn {..}) |
RuntimeCall::TokenMux(pallet_token_mux::Call::deposit {..}) |
RuntimeCall::TokenMux(pallet_token_mux::Call::match_swap {..}) |
RuntimeCall::PoolFees(pallet_pool_fees::Call::charge_fee { .. }) |
RuntimeCall::PoolFees(pallet_pool_fees::Call::uncharge_fee { .. }) |
RuntimeCall::Remarks(pallet_remarks::Call::remark { .. })
) | ProxyType::PodOperation.filter(c)
}
ProxyType::Invest => matches!(
c,
RuntimeCall::Investments(pallet_investments::Call::update_invest_order{..}) |
RuntimeCall::Investments(pallet_investments::Call::update_redeem_order{..}) |
RuntimeCall::Investments(pallet_investments::Call::collect_investments{..}) |
RuntimeCall::Investments(pallet_investments::Call::collect_redemptions{..}) |
RuntimeCall::Loans(pallet_loans::Call::update_portfolio_valuation{..}) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::close_epoch{..}) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::submit_solution{..}) |
RuntimeCall::PoolSystem(pallet_pool_system::Call::execute_epoch{..}) |
RuntimeCall::Utility(pallet_utility::Call::batch_all{..}) |
RuntimeCall::Utility(pallet_utility::Call::batch{..})
),
ProxyType::ProxyManagement => matches!(c, RuntimeCall::Proxy(..)),
ProxyType::KeystoreManagement => matches!(
c,
RuntimeCall::Keystore(pallet_keystore::Call::add_keys { .. })
| RuntimeCall::Keystore(pallet_keystore::Call::revoke_keys { .. })
),
ProxyType::PodOperation => matches!(
c,
RuntimeCall::Uniques(..)
| RuntimeCall::Anchor(..)
| RuntimeCall::AnchorsV2(..)
| RuntimeCall::Utility(pallet_utility::Call::batch_all { .. })
),
ProxyType::PodAuth => false,
ProxyType::PermissionManagement => matches!(
c,
RuntimeCall::Permissions(pallet_permissions::Call::add { .. })
| RuntimeCall::Permissions(pallet_permissions::Call::remove { .. })
),
ProxyType::Transfer => {
matches!(
c,
RuntimeCall::XTokens(..)
| RuntimeCall::Balances(..)
| RuntimeCall::Tokens(..)
| RuntimeCall::LiquidityPools(
pallet_liquidity_pools::Call::transfer { .. }
| pallet_liquidity_pools::Call::transfer_tranche_tokens { .. }
)
)
}
}
}
fn is_superset(&self, o: &Self) -> bool {
match (self, o) {
(x, y) if x == y => true,
(ProxyType::Any, _) => true,
(_, ProxyType::Any) => false,
(_, ProxyType::NonProxy) => false,
(ProxyType::NonTransfer, _) => true,
_ => false,
}
}
}
impl pallet_proxy::Config for Runtime {
type AnnouncementDepositBase = AnnouncementDepositBase;
type AnnouncementDepositFactor = AnnouncementDepositFactor;
type CallHasher = BlakeTwo256;
type Currency = Tokens;
type MaxPending = MaxPending;
type MaxProxies = MaxProxies;
type ProxyDepositBase = ProxyDepositBase;
type ProxyDepositFactor = ProxyDepositFactor;
type ProxyType = ProxyType;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_proxy::WeightInfo<Runtime>;
}
impl pallet_utility::Config for Runtime {
type PalletsOrigin = OriginCaller;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_utility::WeightInfo<Runtime>;
}
parameter_types! {
pub MaximumSchedulerWeight: Weight = Perbill::from_percent(80) * MaximumBlockWeight::get();
pub const MaxScheduledPerBlock: u32 = 50;
pub const NoPreimagePostponement: Option<u32> = Some(10);
}
impl pallet_scheduler::Config for Runtime {
type MaxScheduledPerBlock = MaxScheduledPerBlock;
type MaximumWeight = MaximumSchedulerWeight;
type OriginPrivilegeCmp = EqualPrivilegeOnly;
type PalletsOrigin = OriginCaller;
type Preimages = Preimage;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type RuntimeOrigin = RuntimeOrigin;
type ScheduleOrigin = EnsureRoot<AccountId>;
type WeightInfo = weights::pallet_scheduler::WeightInfo<Runtime>;
}
parameter_types! {
pub const PreimageMaxSize: u32 = 4096 * 1024;
pub PreimageBaseDeposit: Balance = deposit(2, 64);
pub PreimageByteDeposit: Balance = deposit(0, 1);
pub const PreimageHoldReason: RuntimeHoldReason = RuntimeHoldReason::Preimage(pallet_preimage::HoldReason::Preimage);
}
impl pallet_preimage::Config for Runtime {
type Consideration = HoldConsideration<
AccountId,
Balances,
PreimageHoldReason,
LinearStoragePrice<PreimageBaseDeposit, PreimageByteDeposit, Balance>,
>;
type Currency = Balances;
type ManagerOrigin = EnsureRoot<AccountId>;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = ();
}
parameter_types! {
pub const CouncilMotionDuration: BlockNumber = 5 * DAYS;
pub const CouncilMaxProposals: u32 = 100;
pub const CouncilMaxMembers: u32 = 100;
pub MaxProposalWeight: Weight = Perbill::from_percent(50) * RuntimeBlockWeights::get().max_block;
}
impl pallet_collective::Config<CouncilCollective> for Runtime {
type DefaultVote = pallet_collective::PrimeDefaultVote;
type MaxMembers = CouncilMaxMembers;
type MaxProposalWeight = MaxProposalWeight;
type MaxProposals = CouncilMaxProposals;
type MotionDuration = CouncilMotionDuration;
type Proposal = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type RuntimeOrigin = RuntimeOrigin;
type SetMembersOrigin = EnsureRoot<AccountId>;
type WeightInfo = weights::pallet_collective_council::WeightInfo<Runtime>;
}
parameter_types! {
pub const CandidacyBond: Balance = 1000 * CFG;
pub const VotingBond: Balance = 50 * CENTI_CFG;
pub const VotingBondBase: Balance = 50 * CENTI_CFG;
pub const TermDuration: BlockNumber = 7 * DAYS;
pub const DesiredMembers: u32 = 7;
pub const DesiredRunnersUp: u32 = 3;
pub const ElectionsPhragmenModuleId: LockIdentifier = *b"phrelect";
pub const MaxVotesPerVoter: u32 = 5;
}
const_assert!(DesiredMembers::get() <= CouncilMaxMembers::get());
impl pallet_elections_phragmen::Config for Runtime {
type CandidacyBond = CandidacyBond;
type ChangeMembers = Council;
type Currency = Tokens;
type CurrencyToVote = U128CurrencyToVote;
type DesiredMembers = DesiredMembers;
type DesiredRunnersUp = DesiredRunnersUp;
type InitializeMembers = Council;
type KickedMember = ();
type LoserCandidate = ();
type MaxCandidates = MaxCandidates;
type MaxVoters = MaxVoters;
type MaxVotesPerVoter = MaxVotesPerVoter;
type PalletId = ElectionsPhragmenModuleId;
type RuntimeEvent = RuntimeEvent;
type TermDuration = TermDuration;
type VotingBondBase = VotingBondBase;
type VotingBondFactor = VotingBond;
type WeightInfo = weights::pallet_elections_phragmen::WeightInfo<Runtime>;
}
#[cfg(feature = "instant-voting")]
parameter_types! {
pub const InstantAllowed: bool = true;
}
#[cfg(not(feature = "instant-voting"))]
parameter_types! {
pub const InstantAllowed: bool = false;
}
parameter_types! {
pub const LaunchPeriod: BlockNumber = 7 * DAYS;
pub const VotingPeriod: BlockNumber = 7 * DAYS;
pub const FastTrackVotingPeriod: BlockNumber = 3 * HOURS;
pub const MinimumDeposit: Balance = 10 * CFG;
pub const EnactmentPeriod: BlockNumber = 8 * DAYS;
pub const CooloffPeriod: BlockNumber = 7 * DAYS;
pub const MaxProposals: u32 = 100;
pub const MaxVotes: u32 = 100;
}
impl pallet_democracy::Config for Runtime {
type BlacklistOrigin = EnsureRoot<AccountId>;
type CancelProposalOrigin = EnsureRoot<AccountId>;
type CancellationOrigin = EnsureRootOr<TwoThirdOfCouncil>;
type CooloffPeriod = CooloffPeriod;
type Currency = Balances;
type EnactmentPeriod = EnactmentPeriod;
type ExternalDefaultOrigin = AllOfCouncil;
type ExternalMajorityOrigin = TwoThirdOfCouncil;
type ExternalOrigin = HalfOfCouncil;
type FastTrackOrigin = EnsureRootOr<TwoThirdOfCouncil>;
type FastTrackVotingPeriod = FastTrackVotingPeriod;
type InstantAllowed = InstantAllowed;
type InstantOrigin = EnsureRootOr<AllOfCouncil>;
type LaunchPeriod = LaunchPeriod;
type MaxBlacklisted = ConstU32<100>;
type MaxDeposits = ConstU32<100>;
type MaxProposals = MaxProposals;
type MaxVotes = MaxVotes;
type MinimumDeposit = MinimumDeposit;
type PalletsOrigin = OriginCaller;
type Preimages = Preimage;
type RuntimeEvent = RuntimeEvent;
type Scheduler = Scheduler;
type Slash = ();
type SubmitOrigin = EnsureSigned<AccountId>;
type VetoOrigin = EnsureMember<AccountId, CouncilCollective>;
type VoteLockingPeriod = EnactmentPeriod;
type VotingPeriod = VotingPeriod;
type WeightInfo = weights::pallet_democracy::WeightInfo<Runtime>;
}
parameter_types! {
pub const MaxSubAccounts: u32 = 100;
pub const MaxAdditionalFields: u32 = 100;
pub const BasicDeposit: Balance = 100 * CFG;
pub const ByteDeposit: Balance = deposit(0, 1);
pub const SubAccountDeposit: Balance = 20 * CFG;
pub const MaxRegistrars: u32 = 20;
}
impl pallet_identity::Config for Runtime {
type BasicDeposit = BasicDeposit;
type ByteDeposit = ByteDeposit;
type Currency = Tokens;
type ForceOrigin = EnsureRootOr<HalfOfCouncil>;
type IdentityInformation = pallet_identity::legacy::IdentityInfo<MaxAdditionalFields>;
type MaxRegistrars = MaxRegistrars;
type MaxSubAccounts = MaxSubAccounts;
type MaxSuffixLength = ConstU32<7>;
type MaxUsernameLength = ConstU32<32>;
type OffchainSignature = Signature;
type PendingUsernameExpiration = ConstU32<{ 7 * DAYS }>;
type RegistrarOrigin = EnsureRootOr<HalfOfCouncil>;
type RuntimeEvent = RuntimeEvent;
type SigningPublicKey = <Signature as Verify>::Signer;
type Slashed = ();
type SubAccountDeposit = SubAccountDeposit;
type UsernameAuthorityOrigin = EnsureRoot<Self::AccountId>;
type WeightInfo = weights::pallet_identity::WeightInfo<Runtime>;
}
parameter_types! {
pub const MinVestedTransfer: Balance = MIN_VESTING * CFG;
pub UnvestedFundsAllowedWithdrawReasons: WithdrawReasons =
WithdrawReasons::except(WithdrawReasons::TRANSFER | WithdrawReasons::RESERVE);
}
impl pallet_vesting::Config for Runtime {
type BlockNumberProvider = System;
type BlockNumberToBalance = ConvertInto;
type Currency = Tokens;
type MinVestedTransfer = MinVestedTransfer;
type RuntimeEvent = RuntimeEvent;
type UnvestedFundsAllowedWithdrawReasons = UnvestedFundsAllowedWithdrawReasons;
type WeightInfo = weights::pallet_vesting::WeightInfo<Runtime>;
const MAX_VESTING_SCHEDULES: u32 = 28;
}
parameter_types! {
pub const DepositPerByte: Balance = CENTI_CFG;
pub const AttributeDepositBase: Balance = 10 * CENTI_CFG;
pub const MetadataDepositBase: Balance = 10 * CENTI_CFG;
pub const CollectionDeposit: Balance = CFG;
pub const ItemDeposit: Balance = 10 * CENTI_CFG;
pub const Limit: u32 = 256;
}
impl pallet_uniques::Config for Runtime {
type AttributeDepositBase = AttributeDepositBase;
type CollectionDeposit = CollectionDeposit;
type CollectionId = CollectionId;
type CreateOrigin = AsEnsureOriginWithArg<EnsureSigned<AccountId>>;
type Currency = Tokens;
type DepositPerByte = DepositPerByte;
type ForceOrigin = EnsureRootOr<HalfOfCouncil>;
#[cfg(feature = "runtime-benchmarks")]
type Helper = ();
type ItemDeposit = ItemDeposit;
type ItemId = ItemId;
type KeyLimit = Limit;
type Locker = ();
type MetadataDepositBase = MetadataDepositBase;
type RuntimeEvent = RuntimeEvent;
type StringLimit = Limit;
type ValueLimit = Limit;
type WeightInfo = weights::pallet_uniques::WeightInfo<Runtime>;
}
parameter_types! {
pub const ProposalBond: Permill = Permill::from_percent(5);
pub const ProposalBondMinimum: Balance = 100 * CFG;
pub const ProposalBondMaximum: Balance = 500 * CFG;
pub const SpendPeriod: BlockNumber = 30 * DAYS;
pub const PayoutPeriod: BlockNumber = 30 * DAYS;
pub const Burn: Permill = Permill::from_percent(1);
pub const TreasuryPalletId: PalletId = cfg_types::ids::TREASURY_PALLET_ID;
pub const MaxApprovals: u32 = 100;
}
impl pallet_treasury::Config for Runtime {
type ApproveOrigin = TreasuryApproveOrigin;
type AssetKind = ();
type BalanceConverter = UnityAssetBalanceConversion;
#[cfg(feature = "runtime-benchmarks")]
type BenchmarkHelper = ();
type Beneficiary = Self::AccountId;
type BeneficiaryLookup = IdentityLookup<Self::Beneficiary>;
type Burn = Burn;
type BurnDestination = ();
type Currency = Tokens;
type MaxApprovals = MaxApprovals;
type OnSlash = Treasury;
type PalletId = TreasuryPalletId;
type Paymaster = PayFromAccount<Balances, TreasuryAccount>;
type PayoutPeriod = PayoutPeriod;
type ProposalBond = ProposalBond;
type ProposalBondMaximum = ProposalBondMaximum;
type ProposalBondMinimum = ProposalBondMinimum;
type RejectOrigin = TreasuryApproveOrigin;
type RuntimeEvent = RuntimeEvent;
type SpendFunds = ();
type SpendOrigin = TreasurySpender;
type SpendPeriod = SpendPeriod;
type WeightInfo = pallet_treasury::weights::SubstrateWeight<Runtime>;
}
parameter_types! {
pub const DefaultFeeValue: Balance = DEFAULT_FEE_VALUE;
}
impl pallet_fees::Config for Runtime {
type Currency = Tokens;
type DefaultFeeValue = DefaultFeeValue;
type FeeChangeOrigin = EnsureRootOr<HalfOfCouncil>;
type FeeKey = FeeKey;
type RuntimeEvent = RuntimeEvent;
type Treasury = pallet_treasury::Pallet<Self>;
type WeightInfo = weights::pallet_fees::WeightInfo<Self>;
}
parameter_types! {
pub const CommitAnchorFeeKey: FeeKey = FeeKey::AnchorsCommit;
pub const PreCommitDepositFeeKey: FeeKey = FeeKey::AnchorsPreCommit;
}
impl pallet_anchors::Config for Runtime {
type CommitAnchorFeeKey = CommitAnchorFeeKey;
type Currency = Balances;
type Fees = Fees;
type PreCommitDepositFeeKey = PreCommitDepositFeeKey;
type WeightInfo = weights::pallet_anchors::WeightInfo<Runtime>;
}
impl pallet_collator_allowlist::Config for Runtime {
type RuntimeEvent = RuntimeEvent;
type ValidatorId = AccountId;
type ValidatorRegistration = Session;
type WeightInfo = weights::pallet_collator_allowlist::WeightInfo<Self>;
}
parameter_types! {
pub const PoolPalletId: frame_support::PalletId = cfg_types::ids::POOLS_PALLET_ID;
pub PoolPalletIndex: u8 = <PoolSystem as PalletInfoAccess>::index() as u8;
pub const MinUpdateDelay: u64 = if cfg!(feature = "runtime-benchmarks") {
0
} else {
1
};
pub const ChallengeTime: BlockNumber = if cfg!(feature = "runtime-benchmarks") {
0
} else {
2 * MINUTES
};
pub const DefaultMinEpochTime: u64 = 0; pub const DefaultMaxNAVAge: u64 = 1 * SECONDS_PER_MINUTE; pub const MinEpochTimeLowerBound: u64 = 0; pub const MinEpochTimeUpperBound: u64 = 30 * SECONDS_PER_DAY; pub const MaxNAVAgeUpperBound: u64 = SECONDS_PER_HOUR; #[derive(scale_info::TypeInfo, Eq, PartialEq, Debug, Clone, Copy )]
pub const MaxSizeMetadata: u32 = 46; pub const PoolDeposit: Balance = 100 * CFG;
}
impl pallet_pool_system::Config for Runtime {
type AdminOrigin = runtime_common::pool::LiquidityAndPoolAdminOrRoot<Runtime>;
type AssetRegistry = OrmlAssetRegistry;
type AssetsUnderManagementNAV = Loans;
type Balance = Balance;
type BalanceRatio = Quantity;
type ChallengeTime = ChallengeTime;
type Currency = Balances;
type CurrencyId = CurrencyId;
type DefaultMaxNAVAge = DefaultMaxNAVAge;
type DefaultMinEpochTime = DefaultMinEpochTime;
type EpochId = PoolEpochId;
type Investments = Investments;
type MaxNAVAgeUpperBound = MaxNAVAgeUpperBound;
type MaxTranches = MaxTranches;
type MinEpochTimeLowerBound = MinEpochTimeLowerBound;
type MinEpochTimeUpperBound = MinEpochTimeUpperBound;
type MinUpdateDelay = MinUpdateDelay;
type OnEpochTransition = PoolFees;
type PalletId = PoolPalletId;
type PalletIndex = PoolPalletIndex;
type Permission = Permissions;
type PoolCreateOrigin = EnsureSigned<AccountId>;
type PoolCurrency = PoolCurrency;
type PoolDeposit = PoolDeposit;
type PoolFees = PoolFees;
type PoolFeesNAV = PoolFees;
type PoolId = PoolId;
type Rate = Rate;
type RuntimeChange = runtime_common::changes::RuntimeChange<Runtime, FastDelay>;
type RuntimeEvent = RuntimeEvent;
type StringLimit = AssetStringLimit;
type Time = Timestamp;
type Tokens = Tokens;
type TrancheCurrency = InvestmentId;
type TrancheId = TrancheId;
type TrancheWeight = TrancheWeight;
type UpdateGuard = UpdateGuard;
type WeightInfo = weights::pallet_pool_system::WeightInfo<Runtime>;
}
impl pallet_pool_registry::Config for Runtime {
type AssetRegistry = OrmlAssetRegistry;
type Balance = Balance;
type CurrencyId = CurrencyId;
type InterestRate = Rate;
type MaxSizeMetadata = MaxSizeMetadata;
type MaxTranches = MaxTranches;
type ModifyPool = pallet_pool_system::Pallet<Self>;
type ModifyWriteOffPolicy = pallet_loans::Pallet<Self>;
type Permission = Permissions;
type PoolCreateOrigin = EnsureSigned<AccountId>;
type PoolFeesInspect = PoolFees;
type PoolId = PoolId;
type RuntimeEvent = RuntimeEvent;
type TrancheId = TrancheId;
type WeightInfo = weights::pallet_pool_registry::WeightInfo<Runtime>;
}
parameter_types! {
pub const MaxPoolFeesPerBucket: u32 = MAX_POOL_FEES_PER_BUCKET;
pub const PoolFeesPalletId: PalletId = cfg_types::ids::POOL_FEES_PALLET_ID;
pub const MaxFeesPerPool: u32 = MAX_FEES_PER_POOL;
}
impl pallet_pool_fees::Config for Runtime {
type Balance = Balance;
type ChangeGuard = PoolSystem;
type CurrencyId = CurrencyId;
type FeeId = PoolFeeId;
type IsPoolAdmin = PoolAdminCheck<Permissions>;
type MaxFeesPerPool = MaxFeesPerPool;
type MaxPoolFeesPerBucket = MaxPoolFeesPerBucket;
type PalletId = PoolFeesPalletId;
type PoolId = PoolId;
type PoolReserve = PoolSystem;
type Rate = Rate;
type RuntimeChange = runtime_common::changes::RuntimeChange<Runtime, FastDelay>;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type Tokens = Tokens;
type WeightInfo = weights::pallet_pool_fees::WeightInfo<Self>;
}
pub struct PoolCurrency;
impl Contains<CurrencyId> for PoolCurrency {
fn contains(id: &CurrencyId) -> bool {
match id {
CurrencyId::Tranche(_, _) | CurrencyId::Native | CurrencyId::Staking(_) => false,
_ => OrmlAssetRegistry::metadata(&id)
.map(|m| m.additional.pool_currency)
.unwrap_or(false),
}
}
}
pub struct UpdateGuard;
impl PoolUpdateGuard for UpdateGuard {
type Moment = Seconds;
type PoolDetails = PoolDetails<
CurrencyId,
InvestmentId,
u32,
Balance,
Rate,
TrancheWeight,
TrancheId,
PoolId,
MaxTranches,
>;
type ScheduledUpdateDetails = ScheduledUpdateDetails<Rate, AssetStringLimit, MaxTranches>;
fn released(
pool: &Self::PoolDetails,
update: &Self::ScheduledUpdateDetails,
_now: Self::Moment,
) -> bool {
if !cfg!(feature = "runtime-benchmarks") && update.submitted_at >= pool.epoch.last_closed {
return false;
}
let pool_id = pool.tranches.of_pool();
if PoolSystem::epoch_targets(pool_id).is_some() {
return false;
}
let acc_outstanding_redemptions = pool
.tranches
.ids_non_residual_top()
.iter()
.map(|tranche_id| {
let investment_id = (pool_id, *tranche_id);
Investments::redeem_orders(investment_id).amount
})
.fold(Balance::zero(), |acc, redemption| {
acc.saturating_add(redemption)
});
if acc_outstanding_redemptions != 0u128 {
return false;
}
true
}
}
parameter_types! {
pub const PotId: PalletId = cfg_types::ids::STAKE_POT_PALLET_ID;
#[derive(scale_info::TypeInfo, Debug, PartialEq, Eq, Clone)]
pub const MaxCandidates: u32 = 20;
pub const MinEligibleCollators: u32 = 5;
pub const MaxVoters: u32 = 100;
pub const SessionLength: BlockNumber = 6 * HOURS;
pub const MaxInvulnerables: u32 = 100;
}
type CollatorSelectionUpdateOrigin = EitherOfDiverse<
EnsureRoot<AccountId>,
pallet_collective::EnsureProportionAtLeast<AccountId, CouncilCollective, 3, 4>,
>;
impl pallet_collator_selection::Config for Runtime {
type Currency = Balances;
type KickThreshold = Period;
type MaxCandidates = MaxCandidates;
type MaxInvulnerables = MaxInvulnerables;
type MinEligibleCollators = MinEligibleCollators;
type PotId = PotId;
type RuntimeEvent = RuntimeEvent;
type UpdateOrigin = CollatorSelectionUpdateOrigin;
type ValidatorId = <Self as frame_system::Config>::AccountId;
type ValidatorIdOf = pallet_collator_selection::IdentityCollator;
type ValidatorRegistration = Session;
type WeightInfo = weights::pallet_collator_selection::WeightInfo<Self>;
}
parameter_types! {
pub MaxHrmpRelayFee: Asset = (Location::parent(), 1_000_000_000_000u128).into();
}
impl pallet_xcm_transactor::Config for Runtime {
type AccountIdToLocation = AccountIdToLocation;
type AssetTransactor = FungiblesTransactor;
type Balance = Balance;
type BaseXcmWeight = BaseXcmWeight;
type CurrencyId = CurrencyId;
type CurrencyIdToLocation = CurrencyIdConvert;
type DerivativeAddressRegistrationOrigin = EnsureRoot<AccountId>;
type HrmpManipulatorOrigin = EnsureRootOr<HalfOfCouncil>;
type HrmpOpenOrigin = EnsureRoot<AccountId>;
type MaxHrmpFee = staging_xcm_builder::Case<MaxHrmpRelayFee>;
type ReserveProvider = xcm_primitives::AbsoluteAndRelativeReserve<SelfLocation>;
type RuntimeEvent = RuntimeEvent;
type SelfLocation = SelfLocation;
type SovereignAccountDispatcherOrigin = EnsureRoot<AccountId>;
type Transactor = xcm_transactor::NullTransactor;
type UniversalLocation = UniversalLocation;
type Weigher = XcmWeigher;
type WeightInfo = ();
type XcmSender = XcmRouter;
}
parameter_types! {
pub const MaxActiveLoansPerPool: u32 = 1000;
pub const MaxRegisteredPricesPerPool: u32 = 100;
pub const MaxRateCount: u32 = 1000; pub FirstValueFee: Fee = Fee::Balance(deposit(1, pallet_oracle_feed::util::size_of_feed::<Runtime>()));
#[derive(Clone, PartialEq, Eq, Debug, TypeInfo, Encode, Decode, MaxEncodedLen)]
pub const MaxWriteOffPolicySize: u32 = 10;
#[derive(Clone, PartialEq, Eq, Debug, TypeInfo, Encode, Decode, MaxEncodedLen)]
pub const MaxFeedersPerKey: u32 = 5;
}
impl pallet_oracle_feed::Config for Runtime {
type FeederOrigin = EitherOfDiverse<EnsureRoot<AccountId>, EnsureSigned<AccountId>>;
type FirstValuePayFee = FeeToTreasury<Fees, FirstValueFee>;
type OracleKey = OracleKey;
type OracleValue = Ratio;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type WeightInfo = weights::pallet_oracle_feed::WeightInfo<Self>;
}
impl pallet_oracle_collection::Config for Runtime {
type AggregationProvider = pallet_oracle_collection::util::MedianAggregation;
type ChangeGuard = PoolSystem;
type CollectionId = PoolId;
type FeederId = Feeder<RuntimeOrigin>;
type IsAdmin = PoolAdminCheck<Permissions>;
type MaxCollectionSize = MaxRegisteredPricesPerPool;
type MaxFeedersPerKey = MaxFeedersPerKey;
type OracleKey = OracleKey;
type OracleProvider =
OracleConverterBridge<RuntimeOrigin, OraclePriceFeed, PoolSystem, OrmlAssetRegistry>;
type OracleValue = Balance;
type RuntimeChange = runtime_common::changes::RuntimeChange<Runtime, FastDelay>;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type Timestamp = Millis;
type WeightInfo = weights::pallet_oracle_collection::WeightInfo<Self>;
}
impl pallet_interest_accrual::Config for Runtime {
type Balance = Balance;
type MaxRateCount = MaxRateCount;
type Rate = Rate;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type Weights = weights::pallet_interest_accrual::WeightInfo<Self>;
}
impl pallet_loans::Config for Runtime {
type Balance = Balance;
type ChangeGuard = PoolSystem;
type CollectionId = CollectionId;
type CurrencyId = CurrencyId;
type InterestAccrual = InterestAccrual;
type ItemId = ItemId;
type LoanId = LoanId;
type MaxActiveLoansPerPool = MaxActiveLoansPerPool;
type MaxWriteOffPolicySize = MaxWriteOffPolicySize;
type Moment = Millis;
type NonFungible = Uniques;
type PerThing = Perquintill;
type Permissions = Permissions;
type Pool = PoolSystem;
type PoolId = PoolId;
type PriceId = OracleKey;
type PriceRegistry = OraclePriceCollection;
type Quantity = Quantity;
type Rate = Rate;
type RuntimeChange = runtime_common::changes::RuntimeChange<Runtime, FastDelay>;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type WeightInfo = weights::pallet_loans::WeightInfo<Self>;
}
parameter_types! {
#[derive(Encode, Decode, Debug, Eq, PartialEq, PartialOrd, scale_info::TypeInfo, Clone)]
#[cfg_attr(feature = "std", derive(frame_support::Serialize, frame_support::Deserialize))]
pub const MaxTranches: u32 = 5;
#[derive(Debug, Eq, PartialEq, scale_info::TypeInfo, Clone)]
pub const MinDelay: Seconds = 7 * SECONDS_PER_DAY;
#[derive(Debug, Eq, PartialEq, scale_info::TypeInfo, Clone)]
pub const MaxRolesPerPool: u32 = 1_000;
}
impl pallet_permissions::Config for Runtime {
type AdminOrigin = EnsureRootOr<EitherOf<HalfOfCouncil, PoolAdmin>>;
type Editors = Editors;
type MaxRolesPerScope = MaxRolesPerPool;
type Role = Role<TrancheId>;
type RuntimeEvent = RuntimeEvent;
type Scope = PermissionScope<PoolId, CurrencyId>;
type Storage = PermissionRoles<TimeProvider<Timestamp>, MinDelay, TrancheId, MaxTranches>;
type WeightInfo = weights::pallet_permissions::WeightInfo<Runtime>;
}
pub struct Editors;
impl
Contains<(
AccountId,
Option<Role<TrancheId>>,
PermissionScope<PoolId, CurrencyId>,
Role<TrancheId>,
)> for Editors
{
fn contains(
t: &(
AccountId,
Option<Role<TrancheId>>,
PermissionScope<PoolId, CurrencyId>,
Role<TrancheId>,
),
) -> bool {
let (_editor, maybe_role, _scope, role) = t;
if let Some(with_role) = maybe_role {
match *with_role {
Role::PoolRole(PoolRole::PoolAdmin) => match *role {
Role::PoolRole(PoolRole::TrancheInvestor(_, _)) => false,
Role::PoolRole(..) => true,
_ => false,
},
Role::PoolRole(PoolRole::InvestorAdmin) => matches!(
*role,
Role::PoolRole(PoolRole::TrancheInvestor(_, _))
| Role::PoolRole(PoolRole::PODReadAccess)
),
Role::PermissionedCurrencyRole(PermissionedCurrencyRole::Manager) => matches!(
*role,
Role::PermissionedCurrencyRole(PermissionedCurrencyRole::Holder(_))
),
_ => false,
}
} else {
false
}
}
}
pub struct RestrictedTokens<P>(PhantomData<P>);
impl<P> PreConditions<TransferDetails<AccountId, CurrencyId, Balance>> for RestrictedTokens<P>
where
P: PermissionsT<AccountId, Scope = PermissionScope<PoolId, CurrencyId>, Role = Role>,
{
type Result = bool;
fn check(details: TransferDetails<AccountId, CurrencyId, Balance>) -> bool {
let TransferDetails {
send,
recv,
id,
amount: _amount,
} = details;
match id {
CurrencyId::Tranche(pool_id, tranche_id) => {
P::has(
PermissionScope::Pool(pool_id),
send,
Role::PoolRole(PoolRole::TrancheInvestor(tranche_id, UNION)),
) && P::has(
PermissionScope::Pool(pool_id),
recv,
Role::PoolRole(PoolRole::TrancheInvestor(tranche_id, UNION)),
)
}
_ => true,
}
}
}
parameter_types! {
pub const NativeToken: CurrencyId = CurrencyId::Native;
}
impl pallet_restricted_tokens::Config for Runtime {
type Balance = Balance;
type CurrencyId = CurrencyId;
type Fungibles = OrmlTokens;
type NativeFungible = Balances;
type NativeToken = NativeToken;
type PreCurrency = cfg_traits::Always;
type PreExtrTransfer = (
RestrictedTokens<Permissions>,
PreNativeTransfer<TransferAllowList>,
);
type PreFungibleInspect = FungibleInspectPassthrough;
type PreFungibleInspectHold = cfg_traits::Always;
type PreFungibleMutate = cfg_traits::Always;
type PreFungibleMutateHold = cfg_traits::Always;
type PreFungibleTransfer = cfg_traits::Always;
type PreFungiblesInspect = FungiblesInspectPassthrough;
type PreFungiblesInspectHold = cfg_traits::Always;
type PreFungiblesMutate = cfg_traits::Always;
type PreFungiblesMutateHold = cfg_traits::Always;
type PreFungiblesTransfer = cfg_traits::Always;
type PreFungiblesUnbalanced = cfg_traits::Always;
type PreReservableCurrency = cfg_traits::Always;
type RuntimeEvent = RuntimeEvent;
type RuntimeHoldReason = RuntimeHoldReason;
type WeightInfo = weights::pallet_restricted_tokens::WeightInfo<Self>;
}
parameter_types! {
pub TreasuryAccount: AccountId = TreasuryPalletId::get().into_account_truncating();
}
pub struct CurrencyHooks<R>(PhantomData<R>);
impl<C: orml_tokens::Config> MutationHooks<AccountId, CurrencyId, Balance> for CurrencyHooks<C> {
type OnDust = orml_tokens::TransferDust<Runtime, TreasuryAccount>;
type OnKilledTokenAccount = ();
type OnNewTokenAccount = ();
type OnSlash = ();
type PostDeposit = ();
type PostTransfer = ();
type PreDeposit = ();
type PreTransfer = ();
}
impl orml_tokens::Config for Runtime {
type Amount = IBalance;
type Balance = Balance;
type CurrencyHooks = CurrencyHooks<Runtime>;
type CurrencyId = CurrencyId;
type DustRemovalWhitelist = frame_support::traits::Nothing;
type ExistentialDeposits = CurrencyED<Runtime>;
type MaxLocks = MaxLocks;
type MaxReserves = MaxReserves;
type ReserveIdentifier = [u8; 8];
type RuntimeEvent = RuntimeEvent;
type WeightInfo = ();
}
impl orml_asset_registry::module::Config for Runtime {
type AssetId = CurrencyId;
type AssetProcessor = asset_registry::CustomAssetProcessor;
type AuthorityOrigin =
asset_registry::AuthorityOrigin<RuntimeOrigin, EnsureRootOr<HalfOfCouncil>>;
type Balance = Balance;
type CustomMetadata = CustomMetadata;
type RuntimeEvent = RuntimeEvent;
type StringLimit = AssetStringLimit;
type WeightInfo = ();
}
parameter_types! {
pub NativeTokenId: chainbridge::ResourceId = chainbridge::derive_resource_id(1, &sp_io::hashing::blake2_128(b"xRAD"));
pub const NativeTokenTransferFeeKey: FeeKey = FeeKey::BridgeNativeTransfer;
}
impl pallet_bridge::Config for Runtime {
type BridgeOrigin = chainbridge::EnsureBridge<Runtime>;
type BridgePalletId = ChainBridgePalletId;
type Currency = Balances;
type Fees = Fees;
type NativeTokenId = NativeTokenId;
type NativeTokenTransferFeeKey = NativeTokenTransferFeeKey;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = ();
}
parameter_types! {
pub const ChainId: chainbridge::ChainId = 1;
pub const ProposalLifetime: u32 = 500;
pub const ChainBridgePalletId: PalletId = cfg_types::ids::CHAIN_BRIDGE_PALLET_ID;
pub const RelayerVoteThreshold: u32 = DEFAULT_RELAYER_VOTE_THRESHOLD;
}
impl chainbridge::Config for Runtime {
type AdminOrigin =
pallet_collective::EnsureProportionAtLeast<AccountId, CouncilCollective, 3, 4>;
type ChainId = ChainId;
type PalletId = ChainBridgePalletId;
type Proposal = RuntimeCall;
type ProposalLifetime = ProposalLifetime;
type RelayerVoteThreshold = RelayerVoteThreshold;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = ();
}
impl pallet_sudo::Config for Runtime {
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = ();
}
parameter_types! {
pub const MaxKeys: u32 = 10;
pub const DefaultKeyDeposit: Balance = 100 * CFG;
}
impl pallet_keystore::pallet::Config for Runtime {
type AdminOrigin = EnsureRootOr<AllOfCouncil>;
type Balance = Balance;
type Currency = Balances;
type DefaultKeyDeposit = DefaultKeyDeposit;
type MaxKeys = MaxKeys;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_keystore::WeightInfo<Runtime>;
}
parameter_types! {
pub const DefaultAnchorDeposit: Balance = 100 * CFG;
}
impl pallet_anchors_v2::pallet::Config for Runtime {
type AdminOrigin = EnsureRootOr<AllOfCouncil>;
type Balance = Balance;
type Currency = Balances;
type DefaultAnchorDeposit = DefaultAnchorDeposit;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_anchors_v2::WeightInfo<Runtime>;
}
parameter_types! {
pub const MaxOutstandingCollects: u32 = 10;
}
impl pallet_investments::Config for Runtime {
type Accountant = PoolSystem;
type Amount = Balance;
type BalanceRatio = Quantity;
type CollectedInvestmentHook = pallet_foreign_investments::CollectedInvestmentHook<Runtime>;
type CollectedRedemptionHook = pallet_foreign_investments::CollectedRedemptionHook<Runtime>;
type InvestmentId = InvestmentId;
type MaxOutstandingCollects = MaxOutstandingCollects;
type PreConditions = IsUnfrozenTrancheInvestor<Permissions, Timestamp>;
type RuntimeEvent = RuntimeEvent;
type Tokens = Tokens;
type WeightInfo = ();
}
parameter_types! {
pub const RewardsPalletId: PalletId = cfg_types::ids::BLOCK_REWARDS_PALLET_ID;
pub const RewardCurrency: CurrencyId = CurrencyId::Native;
#[derive(scale_info::TypeInfo)]
pub const MaxCurrencyMovements: u32 = 50;
#[derive(scale_info::TypeInfo)]
pub const MaxGroups: u32 = 20;
#[derive(scale_info::TypeInfo, Debug, PartialEq, Eq, Clone)]
pub const MaxChangesPerEpoch: u32 = 50;
pub const InitialEpochDuration: Millis = SECONDS_PER_MINUTE * 1000; }
impl pallet_rewards::mechanism::gap::Config for Runtime {
type Balance = Balance;
type DistributionId = u32;
type IBalance = IBalance;
type MaxCurrencyMovements = MaxCurrencyMovements;
type Rate = FixedI128;
}
impl pallet_rewards::Config<pallet_rewards::Instance2> for Runtime {
type Currency = Tokens;
type CurrencyId = CurrencyId;
type GroupId = u32;
type PalletId = RewardsPalletId;
type RewardCurrency = RewardCurrency;
type RewardIssuance =
pallet_rewards::issuance::MintReward<AccountId, Balance, CurrencyId, Tokens>;
type RewardMechanism = GapRewardMechanism;
type RuntimeEvent = RuntimeEvent;
}
impl pallet_liquidity_rewards::Config for Runtime {
type AdminOrigin = EnsureRootOr<HalfOfCouncil>;
type Balance = Balance;
type CurrencyId = CurrencyId;
type GroupId = u32;
type InitialEpochDuration = InitialEpochDuration;
type MaxChangesPerEpoch = MaxChangesPerEpoch;
type MaxGroups = MaxGroups;
type Rewards = LiquidityRewardsBase;
type RuntimeEvent = RuntimeEvent;
type Timer = Timestamp;
type Weight = u64;
type WeightInfo = ();
}
impl pallet_rewards::Config<instances::BlockRewards> for Runtime {
type Currency = Tokens;
type CurrencyId = CurrencyId;
type GroupId = u32;
type PalletId = RewardsPalletId;
type RewardCurrency = RewardCurrency;
type RewardIssuance =
pallet_rewards::issuance::MintReward<AccountId, Balance, CurrencyId, Tokens>;
type RewardMechanism = pallet_rewards::mechanism::base::Mechanism<
Balance,
IBalance,
FixedI128,
SingleCurrencyMovement,
>;
type RuntimeEvent = RuntimeEvent;
}
parameter_types! {
pub const BlockRewardCurrency: CurrencyId = CurrencyId::Staking(BlockRewardsCurrency);
pub const StakeAmount: Balance = cfg_types::consts::rewards::DEFAULT_COLLATOR_STAKE;
pub const CollatorGroupId: u32 = cfg_types::ids::COLLATOR_GROUP_ID;
}
impl pallet_block_rewards::Config for Runtime {
type AdminOrigin = EnsureRootOr<HalfOfCouncil>;
type AuthorityId = AuraId;
type Balance = Balance;
type CurrencyId = CurrencyId;
type MaxCollators = MaxAuthorities;
type Rate = Rate;
type Rewards = BlockRewardsBase;
type RuntimeEvent = RuntimeEvent;
type StakeAmount = StakeAmount;
type StakeCurrencyId = BlockRewardCurrency;
type StakeGroupId = CollatorGroupId;
type Time = Timestamp;
type Tokens = Tokens;
type TreasuryPalletId = TreasuryPalletId;
type Weight = u64;
type WeightInfo = weights::pallet_block_rewards::WeightInfo<Runtime>;
}
impl pallet_transfer_allowlist::Config for Runtime {
type CurrencyId = FilterCurrency;
type Deposit = AllowanceDeposit<Fees>;
type Location = RestrictedTransferLocation;
type ReserveCurrency = Balances;
type RuntimeEvent = RuntimeEvent;
type RuntimeHoldReason = RuntimeHoldReason;
type WeightInfo = weights::pallet_transfer_allowlist::WeightInfo<Runtime>;
}
parameter_types! {
pub MinFulfillmentAmountNative: Balance = 10 * CFG;
pub NativeDecimals: u32 = cfg_primitives::currency_decimals::NATIVE;
}
impl pallet_order_book::Config for Runtime {
type AdminOrigin = EnsureRoot<AccountId>;
type AssetRegistry = OrmlAssetRegistry;
type BalanceIn = Balance;
type BalanceOut = Balance;
type Currency = Tokens;
type CurrencyId = CurrencyId;
type FeederId = Feeder<RuntimeOrigin>;
type FulfilledOrderHook = ForeignInvestments;
type MinFulfillmentAmountNative = MinFulfillmentAmountNative;
type NativeDecimals = NativeDecimals;
type OrderIdNonce = u64;
type Ratio = Ratio;
type RatioProvider = DigestedOracleRatioProvider<
RuntimeOrigin,
OracleRatioProvider<RuntimeOrigin, OraclePriceFeed>,
OrmlAssetRegistry,
>;
type RuntimeEvent = RuntimeEvent;
type Weights = weights::pallet_order_book::WeightInfo<Runtime>;
}
impl pallet_foreign_investments::Config for Runtime {
type CurrencyId = CurrencyId;
type ForeignBalance = Balance;
type Hooks = LiquidityPools;
type Investment = Investments;
type InvestmentId = InvestmentId;
type OrderBook = OrderBook;
type OrderId = OrderId;
type PoolBalance = Balance;
type PoolInspect = PoolSystem;
type RuntimeEvent = RuntimeEvent;
type SwapBalance = Balance;
type SwapRatio = Ratio;
type TrancheBalance = Balance;
}
parameter_types! {
pub LiquidityPoolsPalletIndex: PalletIndex = <LiquidityPools as PalletInfoAccess>::index() as u8;
}
impl pallet_liquidity_pools::Config for Runtime {
type AssetRegistry = OrmlAssetRegistry;
type Balance = Balance;
type BalanceRatio = Ratio;
type CurrencyId = CurrencyId;
type ForeignInvestment = ForeignInvestments;
type GeneralCurrencyPrefix = GeneralCurrencyPrefix;
type MarketRatio = OrderBook;
type OutboundMessageHandler = LiquidityPoolsGateway;
type Permission = Permissions;
type PoolId = PoolId;
type PoolInspect = PoolSystem;
type PreTransferFilter = PreLpTransfer<TransferAllowList>;
type RuntimeEvent = RuntimeEvent;
type Time = Timestamp;
type Tokens = Tokens;
type TrancheId = TrancheId;
type TrancheTokenPrice = PoolSystem;
type TreasuryAccount = TreasuryAccount;
type WeightInfo = ();
}
impl pallet_liquidity_pools_forwarder::Config for Runtime {
type AdminOrigin = EnsureRootOr<HalfOfCouncil>;
type Message = pallet_liquidity_pools::Message;
type MessageReceiver = LiquidityPoolsGateway;
type MessageSender = MessageSerializer<RouterDispatcher<Runtime>, LiquidityPoolsForwarder>;
type RouterId = RouterId;
type RuntimeEvent = RuntimeEvent;
}
parameter_types! {
pub Sender: DomainAddress = gateway::get_gateway_domain_address::<Runtime>();
pub const MaxIncomingMessageSize: u32 = 1024;
pub const MaxRouterCount: u32 = 8;
}
impl pallet_liquidity_pools_gateway::Config for Runtime {
type AdminOrigin = EnsureRootOr<HalfOfCouncil>;
type InboundMessageHandler = LiquidityPools;
type MaxIncomingMessageSize = MaxIncomingMessageSize;
type MaxRouterCount = MaxRouterCount;
type Message = pallet_liquidity_pools::Message;
type MessageQueue = LiquidityPoolsGatewayQueue;
type MessageSender = LiquidityPoolsForwarder;
type RouterId = RouterId;
type RouterProvider = LPGatewayRouterProvider;
type RuntimeEvent = RuntimeEvent;
type Sender = Sender;
type SessionId = LPGatewaySessionId;
type WeightInfo = ();
}
impl pallet_liquidity_pools_gateway_queue::Config for Runtime {
type Message = GatewayMessage<pallet_liquidity_pools::Message, RouterId>;
type MessageNonce = LPGatewayQueueMessageNonce;
type MessageProcessor = LiquidityPoolsGateway;
type RuntimeEvent = RuntimeEvent;
}
parameter_types! {
pub const TokenMuxPalletId: PalletId = cfg_types::ids::TOKEN_MUX_PALLET_ID;
}
impl pallet_token_mux::Config for Runtime {
type AssetRegistry = OrmlAssetRegistry;
type BalanceIn = Balance;
type BalanceOut = Balance;
type BalanceRatio = Ratio;
type CurrencyId = CurrencyId;
type LocalAssetId = LocalAssetId;
type OrderBook = OrderBook;
type OrderId = OrderId;
type PalletId = TokenMuxPalletId;
type RuntimeEvent = RuntimeEvent;
type Tokens = Tokens;
type WeightInfo = weights::pallet_token_mux::WeightInfo<Runtime>;
}
parameter_types! {
pub const MaxRemarksPerCall: u32 = 10;
}
impl pallet_remarks::Config for Runtime {
type MaxRemarksPerCall = MaxRemarksPerCall;
type Remark = Remark;
type RemarkDispatchHandler = pallet_remarks::NoopRemarkDispatchHandler<Runtime>;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_remarks::WeightInfo<Runtime>;
}
parameter_types! {
pub UnitWeightCost: Weight = Weight::from_parts(200_000_000u64, 0);
pub MaxInstructions: u32 = 100;
}
pub type XcmWeigher =
staging_xcm_builder::FixedWeightBounds<UnitWeightCost, RuntimeCall, MaxInstructions>;
pub type Precompiles = evm::precompile::Precompiles<crate::Runtime, TokenSymbol>;
parameter_types! {
pub BlockGasLimit: U256 = U256::from(NORMAL_DISPATCH_RATIO * MAXIMUM_BLOCK_WEIGHT.ref_time() / WEIGHT_PER_GAS);
pub PrecompilesValue: Precompiles = Precompiles::new();
pub WeightPerGas: Weight = Weight::from_parts(WEIGHT_PER_GAS, 0);
pub const TokenSymbol: &'static str = "DCFG";
}
impl pallet_evm::Config for Runtime {
type AddressMapping = RuntimeAccountConverter<Runtime>;
type BlockGasLimit = BlockGasLimit;
type BlockHashMapping = pallet_ethereum::EthereumBlockHashMapping<Self>;
type CallOrigin = EnsureAddressRoot<AccountId>;
type ChainId = EVMChainId;
type Currency = Balances;
type FeeCalculator = BaseFee;
type FindAuthor = FindAuthorTruncated<Self>;
type GasLimitPovSizeRatio = ConstU64<GAS_LIMIT_POV_SIZE_RATIO>;
type GasLimitStorageGrowthRatio = ConstU64<GAS_LIMIT_STORAGE_GROWTH_RATIO>;
type GasWeightMapping = pallet_evm::FixedGasWeightMapping<Self>;
type OnChargeTransaction = ();
type OnCreate = ();
type PrecompilesType = Precompiles;
type PrecompilesValue = PrecompilesValue;
type Runner = pallet_evm::runner::stack::Runner<Self>;
type RuntimeEvent = RuntimeEvent;
type SuicideQuickClearLimit = ConstU32<0>;
type Timestamp = Timestamp;
type WeightInfo = ();
type WeightPerGas = WeightPerGas;
type WithdrawOrigin = EnsureAddressNever<AccountId>;
}
impl pallet_evm_chain_id::Config for Runtime {}
parameter_types! {
pub DefaultBaseFeePerGas: U256 = U256::from(1_000_000_000);
pub DefaultElasticity: Permill = Permill::from_parts(125_000);
}
impl pallet_base_fee::Config for Runtime {
type DefaultBaseFeePerGas = DefaultBaseFeePerGas;
type DefaultElasticity = DefaultElasticity;
type RuntimeEvent = RuntimeEvent;
type Threshold = BaseFeeThreshold;
}
parameter_types! {
pub const PostBlockAndTxnHashes: PostLogContent = PostLogContent::BlockAndTxnHashes;
pub const ExtraDataLength: u32 = 30;
}
impl pallet_ethereum::Config for Runtime {
type ExtraDataLength = ExtraDataLength;
type PostLogContent = PostBlockAndTxnHashes;
type RuntimeEvent = RuntimeEvent;
type StateRoot = pallet_ethereum::IntermediateStateRoot<Self>;
}
impl pallet_ethereum_transaction::Config for Runtime {}
impl pallet_axelar_router::Config for Runtime {
type AdminOrigin = EnsureRoot<AccountId>;
type EvmAccountCodeChecker = EvmAccountCodeChecker<Runtime>;
type Middleware = RouterId;
type Receiver = MessageSerializer<RouterDispatcher<Runtime>, LiquidityPoolsForwarder>;
type RuntimeEvent = RuntimeEvent;
type Transactor = EthereumTransaction;
}
impl pallet_conviction_voting::Config for Runtime {
type Currency = Balances;
type MaxTurnout =
frame_support::traits::tokens::currency::ActiveIssuanceOf<Balances, Self::AccountId>;
type MaxVotes = ConstU32<512>;
type Polls = Referenda;
type RuntimeEvent = RuntimeEvent;
type VoteLockingPeriod = EnactmentPeriod;
type WeightInfo = weights::pallet_conviction_voting::WeightInfo<Self>;
}
parameter_types! {
pub const AlarmInterval: BlockNumber = 1;
pub const SubmissionDeposit: Balance = 10 * CFG;
pub const UndecidingTimeout: BlockNumber = 14 * MINUTES;
}
parameter_types! {
pub const MaxBalance: Balance = Balance::max_value();
}
pub type TreasurySpender = EnsureWithSuccess<EnsureRootOr<Treasurer>, AccountId, MaxBalance>;
impl pallet_custom_origins::Config for Runtime {}
impl pallet_whitelist::Config for Runtime {
type DispatchWhitelistedOrigin = DispatchWhitelistedOrigin;
type Preimages = Preimage;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WeightInfo = weights::pallet_whitelist::WeightInfo<Self>;
type WhitelistOrigin = WhitelistOrigin;
}
impl pallet_referenda::Config for Runtime {
type AlarmInterval = AlarmInterval;
type CancelOrigin = RefCancelOrigin;
type Currency = Balances;
type KillOrigin = RefKillerOrigin;
type MaxQueued = ConstU32<100>;
type Preimages = Preimage;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type Scheduler = Scheduler;
type Slash = Treasury;
type SubmissionDeposit = SubmissionDeposit;
type SubmitOrigin = frame_system::EnsureSigned<AccountId>;
type Tally = pallet_conviction_voting::TallyOf<Runtime>;
type Tracks = TracksInfo;
type UndecidingTimeout = UndecidingTimeout;
type Votes = pallet_conviction_voting::VotesOf<Runtime>;
type WeightInfo = weights::pallet_referenda::WeightInfo<Self>;
}
parameter_types! {
pub const TechnicalMotionDuration: BlockNumber = 3 * DAYS;
pub const TechnicalMaxProposals: u32 = 20;
pub const TechnicalMaxMembers: u32 = 20;
}
impl pallet_collective::Config<TechnicalCollective> for Runtime {
type DefaultVote = pallet_collective::PrimeDefaultVote;
type MaxMembers = TechnicalMaxMembers;
type MaxProposalWeight = MaxProposalWeight;
type MaxProposals = TechnicalMaxProposals;
type MotionDuration = TechnicalMotionDuration;
type Proposal = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type RuntimeOrigin = RuntimeOrigin;
type SetMembersOrigin = EnsureRoot<AccountId>;
type WeightInfo = weights::pallet_collective_technical_fellowship::WeightInfo<Runtime>;
}
impl pallet_membership::Config<TechnicalMembership> for Runtime {
type AddOrigin = EnsureRoot<AccountId>;
type MaxMembers = TechnicalMaxMembers;
type MembershipChanged = TechnicalCommittee;
type MembershipInitialized = TechnicalCommittee;
type PrimeOrigin = EnsureRoot<AccountId>;
type RemoveOrigin = EnsureRoot<AccountId>;
type ResetOrigin = EnsureRoot<AccountId>;
type RuntimeEvent = RuntimeEvent;
type SwapOrigin = EnsureRoot<AccountId>;
type WeightInfo = weights::pallet_membership::WeightInfo<Runtime>;
}
pub type Block = generic::Block<Header, UncheckedExtrinsic>;
pub type SignedBlock = generic::SignedBlock<Block>;
pub type BlockId = generic::BlockId<Block>;
pub type SignedExtra = (
frame_system::CheckNonZeroSender<Runtime>,
frame_system::CheckSpecVersion<Runtime>,
frame_system::CheckTxVersion<Runtime>,
frame_system::CheckGenesis<Runtime>,
frame_system::CheckEra<Runtime>,
frame_system::CheckNonce<Runtime>,
frame_system::CheckWeight<Runtime>,
pallet_transaction_payment::ChargeTransactionPayment<Runtime>,
frame_metadata_hash_extension::CheckMetadataHash<Runtime>,
runtime_common::transfer_filter::PreBalanceTransferExtension<Runtime>,
);
pub type UncheckedExtrinsic =
fp_self_contained::UncheckedExtrinsic<Address, RuntimeCall, Signature, SignedExtra>;
pub type CheckedExtrinsic =
fp_self_contained::CheckedExtrinsic<AccountId, RuntimeCall, SignedExtra, H160>;
pub type Executive = frame_executive::Executive<
Runtime,
Block,
frame_system::ChainContext<Runtime>,
Runtime,
AllPalletsWithSystem,
crate::migrations::UpgradeDevelopment1403,
>;
construct_runtime!(
pub enum Runtime {
System: frame_system::{Pallet, Call, Config<T>, Storage, Event<T>} = 0,
ParachainSystem: cumulus_pallet_parachain_system::{Pallet, Call, Config<T>, Storage, Inherent, Event<T>} = 1,
Timestamp: pallet_timestamp::{Pallet, Call, Storage, Inherent} = 3,
ParachainInfo: staging_parachain_info::{Pallet, Storage, Config<T>} = 4,
Balances: pallet_balances::{Pallet, Call, Storage, Config<T>, Event<T>} = 20,
TransactionPayment: pallet_transaction_payment::{Event<T>, Pallet, Storage} = 21,
CollatorSelection: pallet_collator_selection::{Pallet, Call, Storage, Event<T>, Config<T>} = 71,
Authorship: pallet_authorship::{Pallet, Storage} = 30,
Session: pallet_session::{Pallet, Call, Storage, Event, Config<T>} = 31,
Aura: pallet_aura::{Pallet, Storage, Config<T>} = 32,
AuraExt: cumulus_pallet_aura_ext::{Pallet, Storage, Config<T>} = 33,
Multisig: pallet_multisig::{Pallet, Call, Storage, Event<T>} = 60,
Proxy: pallet_proxy::{Pallet, Call, Storage, Event<T>} = 61,
Utility: pallet_utility::{Pallet, Call, Event} = 62,
Scheduler: pallet_scheduler::{Pallet, Call, Storage, Event<T>} = 63,
Council: pallet_collective::<Instance1>::{Pallet, Call, Storage, Origin<T>, Event<T>, Config<T>} = 64,
Elections: pallet_elections_phragmen::{Pallet, Call, Storage, Event<T>, Config<T>} = 65,
Democracy: pallet_democracy::{Pallet, Call, Storage, Config<T>, Event<T>} = 66,
Identity: pallet_identity::{Pallet, Call, Storage, Event<T>} = 67,
Vesting: pallet_vesting::{Pallet, Call, Storage, Event<T>, Config<T>} = 68,
Treasury: pallet_treasury::{Pallet, Call, Storage, Config<T>, Event<T>} = 69,
Uniques: pallet_uniques::{Pallet, Call, Storage, Event<T>} = 70,
Preimage: pallet_preimage::{Pallet, Call, Storage, Event<T>, HoldReason} = 72,
ConvictionVoting: pallet_conviction_voting::{Pallet, Call, Storage, Event<T>} = 80,
Referenda: pallet_referenda::{Pallet, Call, Storage, Event<T>} = 81,
Origins: pallet_custom_origins::{Origin} = 82,
Whitelist: pallet_whitelist::{Pallet, Call, Storage, Event<T>} = 83,
TechnicalCommittee: pallet_collective::<Instance2>::{Pallet, Call, Storage, Origin<T>, Event<T>, Config<T>} = 84,
TechnicalCommitteeMembership: pallet_membership::<Instance1>::{Pallet, Call, Storage, Event<T>, Config<T>} = 85,
Fees: pallet_fees::{Pallet, Call, Storage, Config<T>, Event<T>} = 90,
Anchor: pallet_anchors::{Pallet, Call, Storage} = 91,
PoolSystem: pallet_pool_system::{Pallet, Call, Storage, Event<T>} = 95,
Loans: pallet_loans::{Pallet, Call, Storage, Event<T>} = 96,
Permissions: pallet_permissions::{Pallet, Call, Storage, Event<T>} = 97,
CollatorAllowlist: pallet_collator_allowlist::{Pallet, Call, Storage, Config<T>, Event<T>} = 98,
Tokens: pallet_restricted_tokens::{Pallet, Call, Event<T>, HoldReason} = 99,
Bridge: pallet_bridge::{Pallet, Call, Storage, Config<T>, Event<T>} = 101,
InterestAccrual: pallet_interest_accrual::{Pallet, Storage, Event<T>} = 102,
Keystore: pallet_keystore::{Pallet, Call, Storage, Event<T>} = 104,
Investments: pallet_investments::{Pallet, Call, Storage, Event<T>} = 105,
LiquidityRewardsBase: pallet_rewards::<Instance2>::{Pallet, Storage, Event<T>, Config<T>} = 106,
LiquidityRewards: pallet_liquidity_rewards::{Pallet, Call, Storage, Event<T>} = 107,
LiquidityPools: pallet_liquidity_pools::{Pallet, Call, Storage, Event<T>} = 108,
PoolRegistry: pallet_pool_registry::{Pallet, Call, Storage, Event<T>} = 109,
BlockRewardsBase: pallet_rewards::<Instance1>::{Pallet, Storage, Event<T>, Config<T>} = 110,
BlockRewards: pallet_block_rewards::{Pallet, Call, Storage, Event<T>, Config<T>} = 111,
TransferAllowList: pallet_transfer_allowlist::{Pallet, Call, Storage, Event<T>, HoldReason} = 112,
GapRewardMechanism: pallet_rewards::mechanism::gap = 114,
LiquidityPoolsGateway: pallet_liquidity_pools_gateway::{Pallet, Call, Storage, Event<T> } = 115,
OrderBook: pallet_order_book::{Pallet, Call, Storage, Event<T>} = 116,
ForeignInvestments: pallet_foreign_investments::{Pallet, Storage, Event<T>} = 117,
OraclePriceFeed: pallet_oracle_feed::{Pallet, Call, Storage, Event<T>} = 118,
OraclePriceCollection: pallet_oracle_collection::{Pallet, Call, Storage, Event<T>} = 119,
AnchorsV2: pallet_anchors_v2::{Pallet, Call, Storage, Event<T>} = 130,
LiquidityPoolsGatewayQueue: pallet_liquidity_pools_gateway_queue::{Pallet, Call, Storage, Event<T>} = 131,
LiquidityPoolsForwarder: pallet_liquidity_pools_forwarder::{Pallet, Call, Storage, Event<T>} = 132,
XcmpQueue: cumulus_pallet_xcmp_queue::{Pallet, Call, Storage, Event<T>} = 120,
PolkadotXcm: pallet_xcm::{Pallet, Call, Storage, Config<T>, Event<T>, Origin} = 121,
CumulusXcm: cumulus_pallet_xcm::{Pallet, Event<T>, Origin} = 122,
XTokens: pallet_restricted_xtokens::{Pallet, Call} = 124,
XcmTransactor: pallet_xcm_transactor::{Pallet, Call, Storage, Event<T>} = 125,
OrmlXTokens: orml_xtokens::{Pallet, Event<T>} = 126,
MessageQueue: pallet_message_queue::{Pallet, Call, Storage, Event<T>} = 127,
OrmlTokens: orml_tokens::{Pallet, Storage, Event<T>, Config<T>} = 150,
ChainBridge: chainbridge::{Pallet, Call, Storage, Event<T>} = 151,
OrmlAssetRegistry: orml_asset_registry::module::{Pallet, Storage, Call, Event<T>, Config<T>} = 152,
OrmlXcm: orml_xcm::{Pallet, Storage, Call, Event<T>} = 153,
EVM: pallet_evm::{Pallet, Config<T>, Call, Storage, Event<T>} = 160,
EVMChainId: pallet_evm_chain_id::{Pallet, Config<T>, Storage} = 161,
BaseFee: pallet_base_fee::{Pallet, Call, Config<T>, Storage, Event} = 162,
Ethereum: pallet_ethereum::{Pallet, Config<T>, Call, Storage, Event, Origin} = 163,
EthereumTransaction: pallet_ethereum_transaction::{Pallet, Storage} = 164,
AxelarRouter: pallet_axelar_router::{Pallet, Call, Storage, Event<T>} = 165,
Sudo: pallet_sudo::{Pallet, Call, Config<T>, Storage, Event<T>} = 200,
PoolFees: pallet_pool_fees::{Pallet, Call, Storage, Event<T>} = 250,
Remarks: pallet_remarks::{Pallet, Call, Event<T>} = 251,
TokenMux: pallet_token_mux::{Pallet, Call, Storage, Event<T>} = 253,
}
);
impl fp_self_contained::SelfContainedCall for RuntimeCall {
type SignedInfo = H160;
fn is_self_contained(&self) -> bool {
match self {
RuntimeCall::Ethereum(call) => call.is_self_contained(),
_ => false,
}
}
fn check_self_contained(&self) -> Option<Result<Self::SignedInfo, TransactionValidityError>> {
match self {
RuntimeCall::Ethereum(call) => call.check_self_contained(),
_ => None,
}
}
fn validate_self_contained(
&self,
info: &Self::SignedInfo,
dispatch_info: &DispatchInfoOf<RuntimeCall>,
len: usize,
) -> Option<TransactionValidity> {
match self {
RuntimeCall::Ethereum(call) => call.validate_self_contained(info, dispatch_info, len),
_ => None,
}
}
fn pre_dispatch_self_contained(
&self,
info: &Self::SignedInfo,
dispatch_info: &DispatchInfoOf<RuntimeCall>,
len: usize,
) -> Option<Result<(), TransactionValidityError>> {
match self {
RuntimeCall::Ethereum(call) => {
call.pre_dispatch_self_contained(info, dispatch_info, len)
}
_ => None,
}
}
fn apply_self_contained(
self,
info: Self::SignedInfo,
) -> Option<sp_runtime::DispatchResultWithInfo<PostDispatchInfoOf<Self>>> {
match self {
call @ RuntimeCall::Ethereum(pallet_ethereum::Call::transact { .. }) => {
Some(call.dispatch(RuntimeOrigin::from(
pallet_ethereum::RawOrigin::EthereumTransaction(info),
)))
}
_ => None,
}
}
}
pub struct TransactionConverter;
impl fp_rpc::ConvertTransaction<UncheckedExtrinsic> for TransactionConverter {
fn convert_transaction(&self, transaction: pallet_ethereum::Transaction) -> UncheckedExtrinsic {
UncheckedExtrinsic::new_unsigned(
pallet_ethereum::Call::<Runtime>::transact { transaction }.into(),
)
}
}
impl fp_rpc::ConvertTransaction<sp_runtime::OpaqueExtrinsic> for TransactionConverter {
fn convert_transaction(
&self,
transaction: pallet_ethereum::Transaction,
) -> sp_runtime::OpaqueExtrinsic {
let extrinsic = UncheckedExtrinsic::new_unsigned(
pallet_ethereum::Call::<Runtime>::transact { transaction }.into(),
);
let encoded = extrinsic.encode();
sp_runtime::OpaqueExtrinsic::decode(&mut &encoded[..])
.expect("Encoded extrinsic is always valid")
}
}
impl_runtime_apis! {
impl sp_api::Core<Block> for Runtime {
fn version() -> RuntimeVersion {
VERSION
}
fn execute_block(block: Block) {
Executive::execute_block(block)
}
fn initialize_block(header: &<Block as BlockT>::Header) {
Executive::initialize_block(header)
}
}
impl sp_api::Metadata<Block> for Runtime {
fn metadata() -> OpaqueMetadata {
OpaqueMetadata::new(Runtime::metadata().into())
}
fn metadata_at_version(version: u32) -> Option<sp_core::OpaqueMetadata> { Runtime::metadata_at_version(version) }
fn metadata_versions() -> sp_std::vec::Vec<u32> { Runtime::metadata_versions() }
}
impl sp_block_builder::BlockBuilder<Block> for Runtime {
fn apply_extrinsic(extrinsic: <Block as BlockT>::Extrinsic) -> ApplyExtrinsicResult {
Executive::apply_extrinsic(extrinsic)
}
fn finalize_block() -> <Block as BlockT>::Header {
Executive::finalize_block()
}
fn inherent_extrinsics(data: InherentData) -> Vec<<Block as BlockT>::Extrinsic> {
data.create_extrinsics()
}
fn check_inherents(block: Block, data: InherentData) -> CheckInherentsResult {
data.check_extrinsics(&block)
}
}
impl sp_transaction_pool::runtime_api::TaggedTransactionQueue<Block> for Runtime {
fn validate_transaction(
source: TransactionSource,
tx: <Block as BlockT>::Extrinsic,
block_hash: <Block as BlockT>::Hash,
) -> TransactionValidity {
Executive::validate_transaction(source, tx, block_hash)
}
}
impl sp_offchain::OffchainWorkerApi<Block> for Runtime {
fn offchain_worker(header: &<Block as BlockT>::Header) {
Executive::offchain_worker(header)
}
}
impl sp_session::SessionKeys<Block> for Runtime {
fn decode_session_keys(
encoded: Vec<u8>,
) -> Option<Vec<(Vec<u8>, sp_core::crypto::KeyTypeId)>> {
SessionKeys::decode_into_raw_public_keys(&encoded)
}
fn generate_session_keys(seed: Option<Vec<u8>>) -> Vec<u8> {
SessionKeys::generate(seed)
}
}
impl sp_consensus_aura::AuraApi<Block, AuraId> for Runtime {
fn slot_duration() -> sp_consensus_aura::SlotDuration {
sp_consensus_aura::SlotDuration::from_millis(Aura::slot_duration())
}
fn authorities() -> Vec<AuraId> {
Aura::authorities().into_inner()
}
}
impl frame_system_rpc_runtime_api::AccountNonceApi<Block, AccountId, Nonce> for Runtime {
fn account_nonce(account: AccountId) -> Nonce {
System::account_nonce(account)
}
}
impl pallet_transaction_payment_rpc_runtime_api::TransactionPaymentApi<
Block,
Balance,
> for Runtime {
fn query_info(uxt: <Block as BlockT>::Extrinsic, len: u32) -> RuntimeDispatchInfo<Balance> {
TransactionPayment::query_info(uxt, len)
}
fn query_fee_details(uxt: <Block as BlockT>::Extrinsic, len: u32) -> FeeDetails<Balance> {
TransactionPayment::query_fee_details(uxt, len)
}
fn query_weight_to_fee(weight: Weight) -> Balance {
TransactionPayment::weight_to_fee(weight)
}
fn query_length_to_fee(length: u32) -> Balance {
TransactionPayment::length_to_fee(length)
}
}
impl cumulus_primitives_core::CollectCollationInfo<Block> for Runtime {
fn collect_collation_info(header: &<Block as BlockT>::Header) -> cumulus_primitives_core::CollationInfo {
ParachainSystem::collect_collation_info(header)
}
}
impl runtime_common::apis::AnchorApi<Block, Hash, BlockNumber> for Runtime {
fn get_anchor_by_id(id: Hash) -> Option<AnchorData<Hash, BlockNumber>> {
Anchor::get_anchor_by_id(id)
}
}
impl runtime_common::apis::PoolsApi<Block, PoolId, TrancheId, Balance, CurrencyId, Quantity, MaxTranches> for Runtime {
fn currency(pool_id: PoolId) -> Option<CurrencyId>{
pallet_pool_system::Pool::<Runtime>::get(pool_id).map(|details| details.currency)
}
fn inspect_epoch_solution(pool_id: PoolId, solution: Vec<TrancheSolution>) -> Option<EpochSolution<Balance, MaxTranches>>{
let pool = pallet_pool_system::Pool::<Runtime>::get(pool_id)?;
let epoch_execution_info = pallet_pool_system::EpochExecution::<Runtime>::get(pool_id)?;
pallet_pool_system::Pallet::<Runtime>::score_solution(
&pool,
&epoch_execution_info,
&solution
).ok()
}
fn tranche_token_price(pool_id: PoolId, tranche: TrancheLoc<TrancheId>) -> Option<Quantity>{
let index: usize = PoolSystem::pool(pool_id)?.tranches.tranche_index(&tranche)?.try_into().ok()?;
Self::tranche_token_prices(pool_id)?.get(index).cloned()
}
fn tranche_token_prices(pool_id: PoolId) -> Option<Vec<Quantity>>{
let now = <Timestamp as UnixTime>::now().as_secs();
let mut pool = PoolSystem::pool(pool_id)?;
pool
.tranches
.calculate_prices::<_, Tokens, AccountId>(runtime_common::update_nav::<Runtime>(pool_id).ok()?.total, now)
.ok()
}
fn tranche_ids(pool_id: PoolId) -> Option<Vec<TrancheId>>{
let pool = pallet_pool_system::Pool::<Runtime>::get(pool_id)?;
Some(pool.tranches.ids_residual_top())
}
fn tranche_id(pool_id: PoolId, tranche_index: TrancheIndex) -> Option<TrancheId>{
let pool = pallet_pool_system::Pool::<Runtime>::get(pool_id)?;
let index: usize = tranche_index.try_into().ok()?;
pool.tranches.ids_residual_top().get(index).cloned()
}
fn tranche_currency(pool_id: PoolId, tranche_loc: TrancheLoc<TrancheId>) -> Option<CurrencyId>{
let pool = pallet_pool_system::Pool::<Runtime>::get(pool_id)?;
pool.tranches.tranche_currency(tranche_loc).map(Into::into)
}
fn nav(pool_id: PoolId) -> Option<PoolNav<Balance>> {
runtime_common::update_nav::<Runtime>(pool_id).ok()
}
}
impl runtime_common::apis::RewardsApi<Block, AccountId, Balance, CurrencyId> for Runtime {
fn list_currencies(domain: runtime_common::apis::RewardDomain, account_id: AccountId) -> Vec<CurrencyId> {
match domain {
runtime_common::apis::RewardDomain::Block => pallet_rewards::Pallet::<Runtime, instances::BlockRewards>::list_currencies(&account_id),
runtime_common::apis::RewardDomain::Liquidity => pallet_rewards::Pallet::<Runtime, pallet_rewards::Instance2>::list_currencies(&account_id),
}
}
fn compute_reward(domain: runtime_common::apis::RewardDomain, currency_id: CurrencyId, account_id: AccountId) -> Option<Balance> {
match domain {
runtime_common::apis::RewardDomain::Block => <pallet_rewards::Pallet::<Runtime, instances::BlockRewards> as cfg_traits::rewards::AccountRewards<AccountId>>::compute_reward(currency_id, &account_id).ok(),
runtime_common::apis::RewardDomain::Liquidity => <pallet_rewards::Pallet::<Runtime, pallet_rewards::Instance2> as cfg_traits::rewards::AccountRewards<AccountId>>::compute_reward(currency_id, &account_id).ok(),
}
}
}
impl runtime_common::apis::LoansApi<
Block,
PoolId,
LoanId,
ActiveLoanInfo<Runtime>,
Balance,
PriceCollectionInput<Runtime>
> for Runtime {
fn portfolio(
pool_id: PoolId
) -> Vec<(LoanId, ActiveLoanInfo<Runtime>)> {
Loans::get_active_loans_info(pool_id).unwrap_or_default()
}
fn portfolio_loan(
pool_id: PoolId,
loan_id: LoanId
) -> Option<ActiveLoanInfo<Runtime>> {
Loans::get_active_loan_info(pool_id, loan_id).ok().flatten()
}
fn portfolio_valuation(
pool_id: PoolId,
input_prices: PriceCollectionInput<Runtime>
) -> Result<Balance, DispatchError> {
Ok(runtime_common::update_nav_with_input(pool_id, input_prices)?.nav_aum)
}
fn expected_cashflows(pool_id: PoolId, loan_id: LoanId) -> Result<Vec<CashflowPayment<Balance>>, DispatchError> {
Loans::expected_cashflows(pool_id, loan_id)
}
}
impl runtime_common::apis::InvestmentsApi<Block, AccountId, InvestmentId, InvestmentPortfolio<Balance, CurrencyId>> for Runtime {
fn investment_portfolio(account_id: AccountId) -> Vec<(InvestmentId, InvestmentPortfolio<Balance, CurrencyId>)> {
runtime_common::investment_portfolios::get_account_portfolio::<Runtime>(account_id).unwrap_or_default()
}
}
impl runtime_common::apis::AccountConversionApi<Block, AccountId> for Runtime {
fn conversion_of(location: Location) -> Option<AccountId> {
AccountConverter::location_to_account::<LocationToAccountId>(location)
}
}
impl runtime_common::apis::OrderBookApi<Block, CurrencyId, Balance> for Runtime {
fn min_fulfillment_amount(currency_id: CurrencyId) -> Option<Balance> {
OrderBook::min_fulfillment_amount(currency_id).ok()
}
}
impl runtime_common::apis::PoolFeesApi<Block, PoolId, PoolFeeId, AccountId, Balance, Rate> for Runtime {
fn list_fees(pool_id: PoolId) -> Option<cfg_types::pools::PoolFeesList<PoolFeeId, AccountId, Balance, Rate>> {
runtime_common::update_nav::<Runtime>(pool_id).ok()?;
Some(PoolFees::get_pool_fees(pool_id))
}
}
impl fp_rpc::EthereumRuntimeRPCApi<Block> for Runtime {
fn chain_id() -> u64 {
<Runtime as pallet_evm::Config>::ChainId::get()
}
fn account_basic(address: H160) -> EVMAccount {
let (account, _) = EVM::account_basic(&address);
account
}
fn gas_price() -> U256 {
let (gas_price, _) = <Runtime as pallet_evm::Config>::FeeCalculator::min_gas_price();
gas_price
}
fn account_code_at(address: H160) -> Vec<u8> {
pallet_evm::AccountCodes::<Runtime>::get(address)
}
fn author() -> H160 {
<pallet_evm::Pallet<Runtime>>::find_author()
}
fn storage_at(address: H160, index: U256) -> H256 {
let mut tmp = [0u8; 32];
index.to_big_endian(&mut tmp);
pallet_evm::AccountStorages::<Runtime>::get(address, H256::from_slice(&tmp[..]))
}
fn call(
from: H160,
to: H160,
data: Vec<u8>,
value: U256,
gas_limit: U256,
max_fee_per_gas: Option<U256>,
max_priority_fee_per_gas: Option<U256>,
nonce: Option<U256>,
estimate: bool,
access_list: Option<Vec<(H160, Vec<H256>)>>,
) -> Result<pallet_evm::CallInfo, sp_runtime::DispatchError> {
let mut config = <Runtime as pallet_evm::Config>::config().clone();
config.estimate = estimate;
let is_transactional = false;
let validate = true;
let mut estimated_transaction_len = data.len() +
258;
if access_list.is_some() {
estimated_transaction_len += access_list.encoded_size();
}
let gas_limit = gas_limit.min(u64::MAX.into()).low_u64();
let without_base_extrinsic_weight = true;
let (weight_limit, proof_size_base_cost) =
match <Runtime as pallet_evm::Config>::GasWeightMapping::gas_to_weight(
gas_limit,
without_base_extrinsic_weight
) {
weight_limit if weight_limit.proof_size() > 0 => {
(Some(weight_limit), Some(estimated_transaction_len as u64))
}
_ => (None, None),
};
<Runtime as pallet_evm::Config>::Runner::call(
from,
to,
data,
value,
gas_limit.unique_saturated_into(),
max_fee_per_gas,
max_priority_fee_per_gas,
nonce,
access_list.unwrap_or_default(),
is_transactional,
validate,
weight_limit,
proof_size_base_cost,
&config,
).map_err(|err| err.error.into())
}
fn create(
from: H160,
data: Vec<u8>,
value: U256,
gas_limit: U256,
max_fee_per_gas: Option<U256>,
max_priority_fee_per_gas: Option<U256>,
nonce: Option<U256>,
estimate: bool,
access_list: Option<Vec<(H160, Vec<H256>)>>,
) -> Result<pallet_evm::CreateInfo, sp_runtime::DispatchError> {
let config = if estimate {
let mut config = <Runtime as pallet_evm::Config>::config().clone();
config.estimate = true;
Some(config)
} else {
None
};
let is_transactional = false;
let validate = true;
let mut estimated_transaction_len = data.len() +
190;
if max_fee_per_gas.is_some() {
estimated_transaction_len += 32;
}
if max_priority_fee_per_gas.is_some() {
estimated_transaction_len += 32;
}
if access_list.is_some() {
estimated_transaction_len += access_list.encoded_size();
}
let gas_limit = gas_limit.min(u64::MAX.into()).low_u64(); let without_base_extrinsic_weight = true; let (weight_limit, proof_size_base_cost) =
match <Runtime as pallet_evm::Config>::GasWeightMapping::gas_to_weight(
gas_limit,
without_base_extrinsic_weight
) {
weight_limit if weight_limit.proof_size() > 0 => {
(Some(weight_limit), Some(estimated_transaction_len as u64))
}
_ => (None, None),
};
let evm_config = config.as_ref().unwrap_or_else(|| <Runtime as pallet_evm::Config>::config());
<Runtime as pallet_evm::Config>::Runner::create(
from,
data,
value,
gas_limit.unique_saturated_into(),
max_fee_per_gas,
max_priority_fee_per_gas,
nonce,
access_list.unwrap_or_default(),
is_transactional,
validate,
weight_limit,
proof_size_base_cost,
evm_config,
).map_err(|err| err.error.into())
}
fn current_transaction_statuses() -> Option<Vec<TransactionStatus>> {
pallet_ethereum::CurrentTransactionStatuses::<Runtime>::get()
}
fn current_block() -> Option<pallet_ethereum::Block> {
pallet_ethereum::CurrentBlock::<Runtime>::get()
}
fn current_receipts() -> Option<Vec<pallet_ethereum::Receipt>> {
pallet_ethereum::CurrentReceipts::<Runtime>::get()
}
fn current_all() -> (
Option<pallet_ethereum::Block>,
Option<Vec<pallet_ethereum::Receipt>>,
Option<Vec<TransactionStatus>>,
) {
(
pallet_ethereum::CurrentBlock::<Runtime>::get(),
pallet_ethereum::CurrentReceipts::<Runtime>::get(),
pallet_ethereum::CurrentTransactionStatuses::<Runtime>::get(),
)
}
fn extrinsic_filter(
xts: Vec<<Block as BlockT>::Extrinsic>,
) -> Vec<pallet_ethereum::Transaction> {
xts.into_iter().filter_map(|xt| match xt.0.function {
RuntimeCall::Ethereum(transact { transaction }) => Some(transaction),
_ => None
}).collect::<Vec<pallet_ethereum::Transaction>>()
}
fn elasticity() -> Option<Permill> {
None
}
fn gas_limit_multiplier_support() {}
fn pending_block(
xts: Vec<<Block as BlockT>::Extrinsic>
) -> (
Option<pallet_ethereum::Block>, Option<sp_std::prelude::Vec<TransactionStatus>>
) {
for ext in xts.into_iter() {
let _ = Executive::apply_extrinsic(ext);
}
Ethereum::on_finalize(System::block_number() + 1);
(
pallet_ethereum::CurrentBlock::<Runtime>::get(),
pallet_ethereum::CurrentTransactionStatuses::<Runtime>::get()
)
}
fn initialize_pending_block(header: &<Block as BlockT>::Header) {
Executive::initialize_block(header)
}
}
impl fp_rpc::ConvertTransactionRuntimeApi<Block> for Runtime {
fn convert_transaction(transaction: EthTransaction) -> <Block as BlockT>::Extrinsic {
UncheckedExtrinsic::new_unsigned(
pallet_ethereum::Call::<Runtime>::transact { transaction }.into(),
)
}
}
#[cfg(feature = "try-runtime")]
impl frame_try_runtime::TryRuntime<Block> for Runtime {
fn on_runtime_upgrade(checks: frame_try_runtime::UpgradeCheckSelect) -> (Weight, Weight) {
let weight = Executive::try_runtime_upgrade(checks).unwrap();
(weight, RuntimeBlockWeights::get().max_block)
}
fn execute_block(block: Block, state_root_check: bool, signature_check: bool, select: frame_try_runtime::TryStateSelect) -> Weight {
Executive::try_execute_block(block, state_root_check, signature_check, select).expect("execute-block failed")
}
}
#[cfg(feature = "runtime-benchmarks")]
impl frame_benchmarking::Benchmark<Block> for Runtime {
fn benchmark_metadata(extra: bool) -> (
Vec<frame_benchmarking::BenchmarkList>,
Vec<frame_support::traits::StorageInfo>,
) {
use frame_benchmarking::{Benchmarking, BenchmarkList};
use frame_support::traits::StorageInfoTrait;
use frame_system_benchmarking::Pallet as SystemBench;
use cumulus_pallet_session_benchmarking::Pallet as SessionBench;
use pallet_xcm::benchmarking::Pallet as PalletXcmExtrinsicsBenchmark;
let mut list = Vec::<BenchmarkList>::new();
list_benchmarks!(list, extra);
let storage_info = AllPalletsWithSystem::storage_info();
(list, storage_info)
}
fn dispatch_benchmark(
config: frame_benchmarking::BenchmarkConfig
) -> Result<Vec<frame_benchmarking::BenchmarkBatch>, sp_runtime::RuntimeString> {
use frame_benchmarking::{BenchmarkError, Benchmarking, BenchmarkBatch};
use frame_system_benchmarking::Pallet as SystemBench;
impl frame_system_benchmarking::Config for Runtime {
fn setup_set_code_requirements(code: &sp_std::vec::Vec<u8>) -> Result<(), BenchmarkError> {
ParachainSystem::initialize_for_set_code_benchmark(code.len() as u32);
Ok(())
}
fn verify_set_code() {
System::assert_last_event(cumulus_pallet_parachain_system::Event::<Runtime>::ValidationFunctionStored.into());
}
}
use cumulus_pallet_session_benchmarking::Pallet as SessionBench;
impl cumulus_pallet_session_benchmarking::Config for Runtime {}
use pallet_xcm::benchmarking::Pallet as PalletXcmExtrinsicsBenchmark;
impl pallet_xcm::benchmarking::Config for Runtime {}
use frame_support::traits::WhitelistedStorageKeys;
let whitelist = AllPalletsWithSystem::whitelisted_storage_keys();
let mut batches = Vec::<BenchmarkBatch>::new();
let params = (&config, &whitelist);
add_benchmarks!(params, batches);
if batches.is_empty() { return Err("Benchmark not found for this pallet.".into()) }
Ok(batches)
}
}
impl sp_genesis_builder::GenesisBuilder<Block> for Runtime {
fn create_default_config() -> Vec<u8> {
create_default_config::<RuntimeGenesisConfig>()
}
fn build_config(config: Vec<u8>) -> sp_genesis_builder::Result {
build_config::<RuntimeGenesisConfig>(config)
}
}
}
#[cfg(feature = "runtime-benchmarks")]
mod benches {
frame_benchmarking::define_benchmarks!(
[frame_system, SystemBench::<Runtime>]
[pallet_timestamp, Timestamp]
[pallet_balances, Balances]
[pallet_multisig, Multisig]
[pallet_proxy, Proxy]
[pallet_utility, Utility]
[pallet_scheduler, Scheduler]
[pallet_collective_council, Council]
[pallet_democracy, Democracy]
[pallet_elections_phragmen, Elections]
[pallet_identity, Identity]
[pallet_vesting, Vesting]
[pallet_preimage, Preimage]
[pallet_fees, Fees]
[pallet_anchors, Anchor]
[pallet_anchors_v2, AnchorsV2]
[pallet_block_rewards, BlockRewards]
[pallet_collator_allowlist, CollatorAllowlist]
[pallet_collator_selection, CollatorSelection]
[pallet_pool_registry, PoolRegistry]
[pallet_pool_system, PoolSystem]
[pallet_permissions, Permissions]
[pallet_interest_accrual, InterestAccrual]
[pallet_uniques, Uniques]
[pallet_keystore, Keystore]
[pallet_restricted_tokens, Tokens]
[pallet_session, SessionBench::<Runtime>]
[pallet_loans, Loans]
[pallet_collator_selection, CollatorSelection]
[cumulus_pallet_xcmp_queue, XcmpQueue]
[pallet_transfer_allowlist, TransferAllowList]
[pallet_order_book, OrderBook]
[pallet_investments, Investments]
[pallet_xcm, PalletXcmExtrinsicsBenchmark::<Runtime>]
[pallet_oracle_feed, OraclePriceFeed]
[pallet_oracle_collection, OraclePriceCollection]
[pallet_remarks, Remarks]
[pallet_pool_fees, PoolFees]
[pallet_token_mux, TokenMux]
[pallet_collective_technical_fellowship, TechnicalCommittee]
[pallet_conviction_voting, ConvictionVoting]
[pallet_membership, TechnicalCommitteeMembership]
[pallet_referenda, Referenda]
[pallet_whitelist, Whitelist]
);
}
struct CheckInherents;
impl cumulus_pallet_parachain_system::CheckInherents<Block> for CheckInherents {
fn check_inherents(
block: &Block,
relay_state_proof: &cumulus_pallet_parachain_system::RelayChainStateProof,
) -> sp_inherents::CheckInherentsResult {
let relay_chain_slot = relay_state_proof
.read_slot()
.expect("Could not read the relay chain slot from the proof");
let inherent_data =
cumulus_primitives_timestamp::InherentDataProvider::from_relay_chain_slot_and_duration(
relay_chain_slot,
sp_std::time::Duration::from_secs(6),
)
.create_inherent_data()
.expect("Could not create the timestamp inherent data");
inherent_data.check_extrinsics(block)
}
}
cumulus_pallet_parachain_system::register_validate_block! {
Runtime = Runtime,
BlockExecutor = cumulus_pallet_aura_ext::BlockExecutor::<Runtime, Executive>,
CheckInherents = CheckInherents,
}