Skip to content
Snippets Groups Projects
lib.rs 16.5 KiB
Newer Older
Shawn Tabrizi's avatar
Shawn Tabrizi committed
#![cfg_attr(not(feature = "std"), no_std)]
// `construct_runtime!` does a lot of recursion and requires us to increase the limit to 256.
#![recursion_limit="256"]

// Make the WASM binary available.
#[cfg(feature = "std")]
include!(concat!(env!("OUT_DIR"), "/wasm_binary.rs"));

Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_std::prelude::*;
use sp_core::{crypto::KeyTypeId, OpaqueMetadata};
Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_runtime::{
Ricardo Rius's avatar
Ricardo Rius committed
	ApplyExtrinsicResult, generic, create_runtime_str, impl_opaque_keys, MultiSignature,
	transaction_validity::{TransactionValidity, TransactionSource},
Shawn Tabrizi's avatar
Shawn Tabrizi committed
};
Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_runtime::traits::{
	BlakeTwo256, Block as BlockT, AccountIdLookup, Verify, IdentifyAccount, NumberFor,
Shawn Tabrizi's avatar
Shawn Tabrizi committed
};
Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_api::impl_runtime_apis;
use sp_consensus_aura::sr25519::AuthorityId as AuraId;
Dan Forbes's avatar
Dan Forbes committed
use pallet_grandpa::{AuthorityId as GrandpaId, AuthorityList as GrandpaAuthorityList};
use pallet_grandpa::fg_primitives;
Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_version::RuntimeVersion;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
#[cfg(feature = "std")]
Joshy Orndorff's avatar
Joshy Orndorff committed
use sp_version::NativeVersion;
Shawn Tabrizi's avatar
Shawn Tabrizi committed

// A few exports that help ease life for downstream crates.
#[cfg(any(feature = "std", test))]
Joshy Orndorff's avatar
Joshy Orndorff committed
pub use sp_runtime::BuildStorage;
Dan Forbes's avatar
Dan Forbes committed
pub use pallet_timestamp::Call as TimestampCall;
pub use pallet_balances::Call as BalancesCall;
Joshy Orndorff's avatar
Joshy Orndorff committed
pub use sp_runtime::{Permill, Perbill};
pub use frame_support::{
	construct_runtime, parameter_types, StorageValue,
	traits::{KeyOwnerProofSystem, Randomness},
	weights::{
		Weight, IdentityFee,
		constants::{BlockExecutionWeight, ExtrinsicBaseWeight, RocksDbWeight, WEIGHT_PER_SECOND},
	},
Joshy Orndorff's avatar
Joshy Orndorff committed
};
Dan Forbes's avatar
Dan Forbes committed
use pallet_transaction_payment::CurrencyAdapter;
Dan Forbes's avatar
Dan Forbes committed
/// Import the template pallet.
pub use pallet_template;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
/// An index to a block.
pub type BlockNumber = u32;

/// Alias to 512-bit hash when used in the context of a transaction signature on the chain.
Joshy Orndorff's avatar
Joshy Orndorff committed
pub type Signature = MultiSignature;
Shawn Tabrizi's avatar
Shawn Tabrizi committed

/// Some way of identifying an account on the chain. We intentionally make it equivalent
/// to the public key of our transaction signing scheme.
Joshy Orndorff's avatar
Joshy Orndorff committed
pub type AccountId = <<Signature as Verify>::Signer as IdentifyAccount>::AccountId;
Shawn Tabrizi's avatar
Shawn Tabrizi committed

/// The type for looking up accounts. We don't expect more than 4 billion of them, but you
/// never know...
pub type AccountIndex = u32;

/// Balance of an account.
pub type Balance = u128;

/// Index of a transaction in the chain.
pub type Index = u32;

/// A hash of some data used by the chain.
Joshy Orndorff's avatar
Joshy Orndorff committed
pub type Hash = sp_core::H256;
Shawn Tabrizi's avatar
Shawn Tabrizi committed

/// Digest item type.
pub type DigestItem = generic::DigestItem<Hash>;

/// Opaque types. These are used by the CLI to instantiate machinery that don't need to know
/// the specifics of the runtime. They can then be made to be agnostic over specific formats
/// of data like extrinsics, allowing for them to continue syncing the network through upgrades
/// to even the core data structures.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
pub mod opaque {
	use super::*;

Joshy Orndorff's avatar
Joshy Orndorff committed
	pub use sp_runtime::OpaqueExtrinsic as UncheckedExtrinsic;
Shawn Tabrizi's avatar
Shawn Tabrizi committed

	/// Opaque block header type.
	pub type Header = generic::Header<BlockNumber, BlakeTwo256>;
	/// Opaque block type.
	pub type Block = generic::Block<Header, UncheckedExtrinsic>;
	/// Opaque block identifier type.
	pub type BlockId = generic::BlockId<Block>;

	impl_opaque_keys! {
		pub struct SessionKeys {
Joshy Orndorff's avatar
Joshy Orndorff committed
			pub aura: Aura,
			pub grandpa: Grandpa,
// To learn more about runtime versioning and what each of the following value means:
//   https://substrate.dev/docs/en/knowledgebase/runtime/upgrades#runtime-versioning
Shawn Tabrizi's avatar
Shawn Tabrizi committed
pub const VERSION: RuntimeVersion = RuntimeVersion {
	spec_name: create_runtime_str!("node-template"),
	impl_name: create_runtime_str!("node-template"),
Joshy Orndorff's avatar
Joshy Orndorff committed
	authoring_version: 1,
	// The version of the runtime specification. A full node will not attempt to use its native
	//   runtime in substitute for the on-chain Wasm runtime unless all of `spec_name`,
	//   `spec_version`, and `authoring_version` are the same between Wasm and native.
	// This value is set to 100 to notify Polkadot-JS App (https://polkadot.js.org/apps) to use
	//   the compatible custom types.
Joshy Orndorff's avatar
Joshy Orndorff committed
	impl_version: 1,
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	apis: RUNTIME_API_VERSIONS,
	transaction_version: 1,
Dan Forbes's avatar
Dan Forbes committed
/// This determines the average expected block time that we are targeting.
/// Blocks will be produced at a minimum duration defined by `SLOT_DURATION`.
/// `SLOT_DURATION` is picked up by `pallet_timestamp` which is in turn picked
/// up by `pallet_aura` to implement `fn slot_duration()`.
///
/// Change this to adjust the block time.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
pub const MILLISECS_PER_BLOCK: u64 = 6000;

// NOTE: Currently it is not possible to change the slot duration after the chain has started.
//       Attempting to do so will brick block production.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
pub const SLOT_DURATION: u64 = MILLISECS_PER_BLOCK;

Dan Forbes's avatar
Dan Forbes committed
// Time is measured by number of blocks.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
pub const MINUTES: BlockNumber = 60_000 / (MILLISECS_PER_BLOCK as BlockNumber);
pub const HOURS: BlockNumber = MINUTES * 60;
pub const DAYS: BlockNumber = HOURS * 24;

/// The version information used to identify this runtime when compiled natively.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
#[cfg(feature = "std")]
pub fn native_version() -> NativeVersion {
	NativeVersion {
		runtime_version: VERSION,
		can_author_with: Default::default(),
	}
}

Dan Forbes's avatar
Dan Forbes committed
const NORMAL_DISPATCH_RATIO: Perbill = Perbill::from_percent(75);

Shawn Tabrizi's avatar
Shawn Tabrizi committed
parameter_types! {
Dan Forbes's avatar
Dan Forbes committed
	pub const Version: RuntimeVersion = VERSION;
	pub const BlockHashCount: BlockNumber = 2400;
	/// We allow for 2 seconds of compute with a 6 second average block time.
Dan Forbes's avatar
Dan Forbes committed
	pub BlockWeights: frame_system::limits::BlockWeights = frame_system::limits::BlockWeights
		::with_sensible_defaults(2 * WEIGHT_PER_SECOND, NORMAL_DISPATCH_RATIO);
	pub BlockLength: frame_system::limits::BlockLength = frame_system::limits::BlockLength
		::max_with_normal_ratio(5 * 1024 * 1024, NORMAL_DISPATCH_RATIO);
	pub const SS58Prefix: u8 = 42;
Dan Forbes's avatar
Dan Forbes committed
// Configure FRAME pallets to include in runtime.

Dan Forbes's avatar
Dan Forbes committed
impl frame_system::Config for Runtime {
Dan Forbes's avatar
Dan Forbes committed
	/// The basic call filter to use in dispatchable.
	type BaseCallFilter = ();
Dan Forbes's avatar
Dan Forbes committed
	/// Block & extrinsics weights: base values and limits.
	type BlockWeights = BlockWeights;
	/// The maximum length of a block (in bytes).
	type BlockLength = BlockLength;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	/// The identifier used to distinguish between accounts.
	type AccountId = AccountId;
	/// The aggregated dispatch type that is available for extrinsics.
	type Call = Call;
	/// The lookup mechanism to get account ID from whatever is passed in dispatchers.
Dan Forbes's avatar
Dan Forbes committed
	type Lookup = AccountIdLookup<AccountId, ()>;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	/// The index type for storing how many extrinsics an account has signed.
	type Index = Index;
	/// The index type for blocks.
	type BlockNumber = BlockNumber;
	/// The type for hashing blocks and tries.
	type Hash = Hash;
	/// The hashing algorithm used.
	type Hashing = BlakeTwo256;
	/// The header type.
	type Header = generic::Header<BlockNumber, BlakeTwo256>;
	/// The ubiquitous event type.
	type Event = Event;
	/// The ubiquitous origin type.
	type Origin = Origin;
	/// Maximum number of block number to block hash mappings to keep (oldest pruned first).
	type BlockHashCount = BlockHashCount;
	/// The weight of database operations that the runtime can invoke.
	type DbWeight = RocksDbWeight;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	/// Version of the runtime.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type Version = Version;
Ricardo Rius's avatar
Ricardo Rius committed
	/// Converts a module to the index of the module in `construct_runtime!`.
	///
	/// This type is being generated by `construct_runtime!`.
	type PalletInfo = PalletInfo;
	/// What to do if a new account is created.
	type OnNewAccount = ();
	/// What to do if an account is fully reaped from the system.
	type OnKilledAccount = ();
	/// The data to be stored in an account.
Dan Forbes's avatar
Dan Forbes committed
	type AccountData = pallet_balances::AccountData<Balance>;
Dan Forbes's avatar
Dan Forbes committed
	/// Weight information for the extrinsics of this pallet.
	type SystemWeightInfo = ();
Dan Forbes's avatar
Dan Forbes committed
	/// This is used as an identifier of the chain. 42 is the generic substrate prefix.
	type SS58Prefix = SS58Prefix;
	/// The set code logic, just the default since we're not a parachain.
	type OnSetCode = ();
Dan Forbes's avatar
Dan Forbes committed
impl pallet_aura::Config for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type AuthorityId = AuraId;
Dan Forbes's avatar
Dan Forbes committed
impl pallet_grandpa::Config for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type Event = Event;
	type Call = Call;

	type KeyOwnerProofSystem = ();

	type KeyOwnerProof =
		<Self::KeyOwnerProofSystem as KeyOwnerProofSystem<(KeyTypeId, GrandpaId)>>::Proof;

	type KeyOwnerIdentification = <Self::KeyOwnerProofSystem as KeyOwnerProofSystem<(
		KeyTypeId,
		GrandpaId,
	)>>::IdentificationTuple;

	type HandleEquivocation = ();

	type WeightInfo = ();
Shawn Tabrizi's avatar
Shawn Tabrizi committed
}

parameter_types! {
	pub const MinimumPeriod: u64 = SLOT_DURATION / 2;
Dan Forbes's avatar
Dan Forbes committed
impl pallet_timestamp::Config for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	/// A timestamp: milliseconds since the unix epoch.
	type Moment = u64;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type OnTimestampSet = Aura;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type MinimumPeriod = MinimumPeriod;
Dan Forbes's avatar
Dan Forbes committed
	type WeightInfo = ();
Shawn Tabrizi's avatar
Shawn Tabrizi committed
}

parameter_types! {
	pub const ExistentialDeposit: u128 = 500;
	pub const MaxLocks: u32 = 50;
Dan Forbes's avatar
Dan Forbes committed
impl pallet_balances::Config for Runtime {
	type MaxLocks = MaxLocks;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	/// The type for recording an account's balance.
	type Balance = Balance;
	/// The ubiquitous event type.
	type Event = Event;
	type DustRemoval = ();
	type ExistentialDeposit = ExistentialDeposit;
	type AccountStore = System;
Dan Forbes's avatar
Dan Forbes committed
	type WeightInfo = pallet_balances::weights::SubstrateWeight<Runtime>;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
}

parameter_types! {
	pub const TransactionByteFee: Balance = 1;
}

Dan Forbes's avatar
Dan Forbes committed
impl pallet_transaction_payment::Config for Runtime {
	type OnChargeTransaction = CurrencyAdapter<Balances, ()>;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type TransactionByteFee = TransactionByteFee;
	type WeightToFee = IdentityFee<Balance>;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type FeeMultiplierUpdate = ();
Dan Forbes's avatar
Dan Forbes committed
impl pallet_sudo::Config for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type Event = Event;
	type Call = Call;
/// Configure the pallet-template in pallets/template.
Dan Forbes's avatar
Dan Forbes committed
impl pallet_template::Config for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	type Event = Event;
}

Dan Forbes's avatar
Dan Forbes committed
// Create the runtime by composing the FRAME pallets that were previously configured.
Shawn Tabrizi's avatar
Shawn Tabrizi committed
construct_runtime!(
	pub enum Runtime where
		Block = Block,
		NodeBlock = opaque::Block,
		UncheckedExtrinsic = UncheckedExtrinsic
	{
		System: frame_system::{Pallet, Call, Config, Storage, Event<T>},
		RandomnessCollectiveFlip: pallet_randomness_collective_flip::{Pallet, Call, Storage},
		Timestamp: pallet_timestamp::{Pallet, Call, Storage, Inherent},
		Aura: pallet_aura::{Pallet, Config<T>},
		Grandpa: pallet_grandpa::{Pallet, Call, Storage, Config, Event},
		Balances: pallet_balances::{Pallet, Call, Storage, Config<T>, Event<T>},
		TransactionPayment: pallet_transaction_payment::{Pallet, Storage},
		Sudo: pallet_sudo::{Pallet, Call, Config<T>, Storage, Event<T>},
		// Include the custom logic from the pallet-template in the runtime.
		TemplateModule: pallet_template::{Pallet, Call, Storage, Event<T>},
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	}
);

/// The address format for describing accounts.
Dan Forbes's avatar
Dan Forbes committed
pub type Address = sp_runtime::MultiAddress<AccountId, ()>;
Shawn Tabrizi's avatar
Shawn Tabrizi committed
/// Block header type as expected by this runtime.
pub type Header = generic::Header<BlockNumber, BlakeTwo256>;
/// Block type as expected by this runtime.
pub type Block = generic::Block<Header, UncheckedExtrinsic>;
/// A Block signed with a Justification
pub type SignedBlock = generic::SignedBlock<Block>;
/// BlockId type as expected by this runtime.
pub type BlockId = generic::BlockId<Block>;
/// The SignedExtension to the basic transaction logic.
pub type SignedExtra = (
Dan Forbes's avatar
Dan Forbes committed
	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>
Shawn Tabrizi's avatar
Shawn Tabrizi committed
);
/// Unchecked extrinsic type as expected by this runtime.
pub type UncheckedExtrinsic = generic::UncheckedExtrinsic<Address, Call, Signature, SignedExtra>;
/// Extrinsic type that has already been checked.
pub type CheckedExtrinsic = generic::CheckedExtrinsic<AccountId, Call, SignedExtra>;
/// Executive: handles dispatch to the various modules.
Dan Forbes's avatar
Dan Forbes committed
pub type Executive = frame_executive::Executive<
	Runtime,
	Block,
	frame_system::ChainContext<Runtime>,
	Runtime,
Shawn Tabrizi's avatar
Shawn Tabrizi committed

impl_runtime_apis! {
Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_api::Core<Block> for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		fn version() -> RuntimeVersion {
			VERSION
		}

		fn execute_block(block: Block) {
			Executive::execute_block(block);
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		}

		fn initialize_block(header: &<Block as BlockT>::Header) {
			Executive::initialize_block(header)
		}
	}

Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_api::Metadata<Block> for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		fn metadata() -> OpaqueMetadata {
			Runtime::metadata().into()
		}
	}

Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_block_builder::BlockBuilder<Block> for Runtime {
		fn apply_extrinsic(extrinsic: <Block as BlockT>::Extrinsic) -> ApplyExtrinsicResult {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
			Executive::apply_extrinsic(extrinsic)
		}

		fn finalize_block() -> <Block as BlockT>::Header {
			Executive::finalize_block()
		}

		fn inherent_extrinsics(data: sp_inherents::InherentData) -> Vec<<Block as BlockT>::Extrinsic> {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
			data.create_extrinsics()
		}

Joshy Orndorff's avatar
Joshy Orndorff committed
		fn check_inherents(
			block: Block,
			data: sp_inherents::InherentData,
		) -> sp_inherents::CheckInherentsResult {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
			data.check_extrinsics(&block)
		}

		fn random_seed() -> <Block as BlockT>::Hash {
			RandomnessCollectiveFlip::random_seed().0
Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_transaction_pool::runtime_api::TaggedTransactionQueue<Block> for Runtime {
Ricardo Rius's avatar
Ricardo Rius committed
		fn validate_transaction(
			source: TransactionSource,
			tx: <Block as BlockT>::Extrinsic,
		) -> TransactionValidity {
			Executive::validate_transaction(source, tx)
Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_offchain::OffchainWorkerApi<Block> for Runtime {
		fn offchain_worker(header: &<Block as BlockT>::Header) {
			Executive::offchain_worker(header)
Joshy Orndorff's avatar
Joshy Orndorff committed
	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())
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		}
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		fn authorities() -> Vec<AuraId> {
			Aura::authorities()
Joshy Orndorff's avatar
Joshy Orndorff committed
	impl sp_session::SessionKeys<Block> for Runtime {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
		fn generate_session_keys(seed: Option<Vec<u8>>) -> Vec<u8> {
			opaque::SessionKeys::generate(seed)
		}

		fn decode_session_keys(
			encoded: Vec<u8>,
		) -> Option<Vec<(Vec<u8>, KeyTypeId)>> {
			opaque::SessionKeys::decode_into_raw_public_keys(&encoded)
		}
Shawn Tabrizi's avatar
Shawn Tabrizi committed
	}
Shawn Tabrizi's avatar
Shawn Tabrizi committed

	impl fg_primitives::GrandpaApi<Block> for Runtime {
Joshy Orndorff's avatar
Joshy Orndorff committed
		fn grandpa_authorities() -> GrandpaAuthorityList {
Shawn Tabrizi's avatar
Shawn Tabrizi committed
			Grandpa::grandpa_authorities()
		}
Dan Forbes's avatar
Dan Forbes committed
		fn submit_report_equivocation_unsigned_extrinsic(
			_equivocation_proof: fg_primitives::EquivocationProof<
				<Block as BlockT>::Hash,
				NumberFor<Block>,
			>,
			_key_owner_proof: fg_primitives::OpaqueKeyOwnershipProof,
		) -> Option<()> {
			None
		}

		fn generate_key_ownership_proof(
			_set_id: fg_primitives::SetId,
			_authority_id: GrandpaId,
		) -> Option<fg_primitives::OpaqueKeyOwnershipProof> {
			// NOTE: this is the only implementation possible since we've
			// defined our key owner proof type as a bottom type (i.e. a type
			// with no values).
			None
		}
Dan Forbes's avatar
Dan Forbes committed
	impl frame_system_rpc_runtime_api::AccountNonceApi<Block, AccountId, Index> for Runtime {
		fn account_nonce(account: AccountId) -> Index {
			System::account_nonce(account)
		}
	}

	impl pallet_transaction_payment_rpc_runtime_api::TransactionPaymentApi<Block, Balance> for Runtime {
Dan Forbes's avatar
Dan Forbes committed
		fn query_info(
			uxt: <Block as BlockT>::Extrinsic,
			len: u32,
		) -> pallet_transaction_payment_rpc_runtime_api::RuntimeDispatchInfo<Balance> {
			TransactionPayment::query_info(uxt, len)
		}
Dan Forbes's avatar
Dan Forbes committed
		fn query_fee_details(
			uxt: <Block as BlockT>::Extrinsic,
			len: u32,
		) -> pallet_transaction_payment::FeeDetails<Balance> {
			TransactionPayment::query_fee_details(uxt, len)
		}

	#[cfg(feature = "runtime-benchmarks")]
	impl frame_benchmarking::Benchmark<Block> for Runtime {
		fn dispatch_benchmark(
			config: frame_benchmarking::BenchmarkConfig
		) -> Result<Vec<frame_benchmarking::BenchmarkBatch>, sp_runtime::RuntimeString> {
			use frame_benchmarking::{Benchmarking, BenchmarkBatch, add_benchmark, TrackedStorageKey};

			use frame_system_benchmarking::Pallet as SystemBench;
Dan Forbes's avatar
Dan Forbes committed
			impl frame_system_benchmarking::Config for Runtime {}

			let whitelist: Vec<TrackedStorageKey> = vec![
				// Block Number
				hex_literal::hex!("26aa394eea5630e07c48ae0c9558cef702a5c1b19ab7a04f536c519aca4983ac").to_vec().into(),
				// Total Issuance
				hex_literal::hex!("c2261276cc9d1f8598ea4b6a74b15c2f57c875e4cff74148e4628f264b974c80").to_vec().into(),
				// Execution Phase
				hex_literal::hex!("26aa394eea5630e07c48ae0c9558cef7ff553b5a9862a516939d82b3d3d8661a").to_vec().into(),
				// Event Count
				hex_literal::hex!("26aa394eea5630e07c48ae0c9558cef70a98fdbe9ce6c55837576c60c7af3850").to_vec().into(),
				// System Events
				hex_literal::hex!("26aa394eea5630e07c48ae0c9558cef780d41e5e16056765bc8461851072c9d7").to_vec().into(),
			];

			let mut batches = Vec::<BenchmarkBatch>::new();
			let params = (&config, &whitelist);

			add_benchmark!(params, batches, frame_system, SystemBench::<Runtime>);
			add_benchmark!(params, batches, pallet_balances, Balances);
			add_benchmark!(params, batches, pallet_timestamp, Timestamp);
			add_benchmark!(params, batches, pallet_template, TemplateModule);

			if batches.is_empty() { return Err("Benchmark not found for this pallet.".into()) }
			Ok(batches)
		}
	}
Shawn Tabrizi's avatar
Shawn Tabrizi committed
}