From a0787402ee58c4ad4f05295f7f438edd8eca218f Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 18:42:06 -0600 Subject: [PATCH 01/11] refactor(mainnet): remove pop api chain extension --- Cargo.lock | 76 +++++++++++ runtime/live/src/config/contracts.rs | 6 +- runtime/live/src/extensions.rs | 195 --------------------------- runtime/live/src/lib.rs | 9 +- 4 files changed, 83 insertions(+), 203 deletions(-) delete mode 100644 runtime/live/src/extensions.rs diff --git a/Cargo.lock b/Cargo.lock index 9f217ed1..9bc40f16 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -10298,6 +10298,7 @@ dependencies = [ "parity-scale-codec", "polkadot-cli", "polkadot-primitives", + "pop-runtime", "pop-runtime-common", "pop-runtime-devnet", "pop-runtime-testnet", @@ -10346,6 +10347,81 @@ dependencies = [ "scale-info", ] +[[package]] +name = "pop-runtime" +version = "0.1.0" +dependencies = [ + "cumulus-pallet-aura-ext", + "cumulus-pallet-parachain-system", + "cumulus-pallet-session-benchmarking", + "cumulus-pallet-xcm", + "cumulus-pallet-xcmp-queue", + "cumulus-primitives-aura", + "cumulus-primitives-core", + "cumulus-primitives-storage-weight-reclaim", + "cumulus-primitives-utility", + "enumflags2", + "env_logger 0.11.5", + "frame-benchmarking", + "frame-executive", + "frame-metadata-hash-extension", + "frame-support", + "frame-system", + "frame-system-benchmarking", + "frame-system-rpc-runtime-api", + "frame-try-runtime", + "hex", + "hex-literal", + "log", + "pallet-assets", + "pallet-aura", + "pallet-authorship", + "pallet-balances", + "pallet-collator-selection", + "pallet-contracts", + "pallet-message-queue", + "pallet-multisig", + "pallet-nft-fractionalization", + "pallet-nfts", + "pallet-nfts-runtime-api", + "pallet-preimage", + "pallet-proxy", + "pallet-scheduler", + "pallet-session", + "pallet-sudo", + "pallet-timestamp", + "pallet-transaction-payment", + "pallet-transaction-payment-rpc-runtime-api", + "pallet-utility", + "pallet-xcm", + "parachains-common", + "parity-scale-codec", + "polkadot-parachain-primitives", + "polkadot-runtime-common", + "pop-primitives", + "pop-runtime-common", + "scale-info", + "smallvec", + "sp-api", + "sp-block-builder", + "sp-consensus-aura", + "sp-core", + "sp-genesis-builder", + "sp-inherents", + "sp-io", + "sp-offchain", + "sp-runtime", + "sp-session", + "sp-std", + "sp-transaction-pool", + "sp-version", + "staging-parachain-info", + "staging-xcm", + "staging-xcm-builder", + "staging-xcm-executor", + "substrate-wasm-builder", +] + [[package]] name = "pop-runtime-common" version = "0.0.0" diff --git a/runtime/live/src/config/contracts.rs b/runtime/live/src/config/contracts.rs index 3222a38a..cc3c127d 100644 --- a/runtime/live/src/config/contracts.rs +++ b/runtime/live/src/config/contracts.rs @@ -5,8 +5,8 @@ use frame_support::{ use frame_system::{pallet_prelude::BlockNumberFor, EnsureSigned}; use crate::{ - deposit, extensions, Balance, Balances, BalancesCall, Perbill, Runtime, RuntimeCall, - RuntimeEvent, RuntimeHoldReason, Timestamp, + deposit, Balance, Balances, BalancesCall, Perbill, Runtime, RuntimeCall, RuntimeEvent, + RuntimeHoldReason, Timestamp, }; fn schedule() -> pallet_contracts::Schedule { @@ -48,7 +48,7 @@ impl pallet_contracts::Config for Runtime { /// itself is not allowed to change the indices of existing pallets, too. type CallFilter = Nothing; type CallStack = [pallet_contracts::Frame; 23]; - type ChainExtension = extensions::PopApiExtension; + type ChainExtension = (); type CodeHashLockupDepositPercent = CodeHashLockupDepositPercent; type Currency = Balances; type Debug = (); diff --git a/runtime/live/src/extensions.rs b/runtime/live/src/extensions.rs deleted file mode 100644 index 3e84c834..00000000 --- a/runtime/live/src/extensions.rs +++ /dev/null @@ -1,195 +0,0 @@ -use frame_support::{ - dispatch::{GetDispatchInfo, RawOrigin}, - pallet_prelude::*, - traits::{Contains, OriginTrait}, -}; -use pallet_contracts::{ - chain_extension::{ - BufInBufOutState, ChainExtension, ChargedAmount, Environment, Ext, InitState, RetVal, - }, - WeightInfo, -}; -use pop_primitives::storage_keys::RuntimeStateKeys; -use sp_core::crypto::UncheckedFrom; -use sp_runtime::{traits::Dispatchable, DispatchError}; -use sp_std::vec::Vec; - -use crate::{AccountId, AllowedApiCalls, RuntimeCall, RuntimeOrigin}; - -const LOG_TARGET: &str = "pop-api::extension"; - -#[derive(Default)] -pub struct PopApiExtension; - -impl ChainExtension for PopApiExtension -where - T: pallet_contracts::Config - + frame_system::Config< - RuntimeOrigin = RuntimeOrigin, - AccountId = AccountId, - RuntimeCall = RuntimeCall, - >, - T::AccountId: UncheckedFrom + AsRef<[u8]>, -{ - fn call(&mut self, env: Environment) -> Result - where - E: Ext, - { - log::debug!(target:LOG_TARGET, " extension called "); - match v0::FuncId::try_from(env.func_id())? { - v0::FuncId::Dispatch => { - match dispatch::(env) { - Ok(()) => Ok(RetVal::Converging(0)), - Err(DispatchError::Module(error)) => { - // encode status code = pallet index in runtime + error index, allowing for - // 999 errors - Ok(RetVal::Converging( - (error.index as u32 * 1_000) + u32::from_le_bytes(error.error), - )) - }, - Err(e) => Err(e), - } - }, - v0::FuncId::ReadState => { - read_state::(env)?; - Ok(RetVal::Converging(0)) - }, - } - } -} - -pub mod v0 { - #[derive(Debug)] - pub enum FuncId { - Dispatch, - ReadState, - } -} - -impl TryFrom for v0::FuncId { - type Error = DispatchError; - - fn try_from(func_id: u16) -> Result { - let id = match func_id { - 0x0 => Self::Dispatch, - 0x1 => Self::ReadState, - _ => { - log::error!("called an unregistered `func_id`: {:}", func_id); - return Err(DispatchError::Other("unimplemented func_id")); - }, - }; - - Ok(id) - } -} - -fn dispatch_call( - env: &mut Environment, - call: RuntimeCall, - mut origin: RuntimeOrigin, - log_prefix: &str, -) -> Result<(), DispatchError> -where - E: Ext, -{ - let charged_dispatch_weight = env.charge_weight(call.get_dispatch_info().weight)?; - - log::debug!(target:LOG_TARGET, "{} inputted RuntimeCall: {:?}", log_prefix, call); - - origin.add_filter(AllowedApiCalls::contains); - - match call.dispatch(origin) { - Ok(info) => { - log::debug!(target:LOG_TARGET, "{} success, actual weight: {:?}", log_prefix, info.actual_weight); - - // refund weight if the actual weight is less than the charged weight - if let Some(actual_weight) = info.actual_weight { - env.adjust_weight(charged_dispatch_weight, actual_weight); - } - - Ok(()) - }, - Err(err) => { - log::debug!(target:LOG_TARGET, "{} failed: error: {:?}", log_prefix, err.error); - Err(err.error) - }, - } -} - -fn charge_overhead_weight( - env: &mut Environment, - len: u32, - log_prefix: &str, -) -> Result -where - T: pallet_contracts::Config, - E: Ext, -{ - // calculate weight for reading bytes of `len` - // reference: https://github.com/paritytech/polkadot-sdk/blob/117a9433dac88d5ac00c058c9b39c511d47749d2/substrate/frame/contracts/src/wasm/runtime.rs#L267 - let base_weight: Weight = T::WeightInfo::seal_return(len); - - // debug_message weight is a good approximation of the additional overhead of going - // from contract layer to substrate layer. - // reference: https://github.com/paritytech/ink-examples/blob/b8d2caa52cf4691e0ddd7c919e4462311deb5ad0/psp22-extension/runtime/psp22-extension-example.rs#L236 - let overhead: Weight = T::WeightInfo::seal_debug_message(len); - - let charged_weight = env.charge_weight(base_weight.saturating_add(overhead))?; - log::debug!(target: LOG_TARGET, "{} charged weight: {:?}", log_prefix, charged_weight); - - Ok(charged_weight) -} - -fn dispatch(env: Environment) -> Result<(), DispatchError> -where - T: pallet_contracts::Config, - RuntimeOrigin: From>, - E: Ext, -{ - const LOG_PREFIX: &str = " dispatch |"; - - let mut env = env.buf_in_buf_out(); - let len = env.in_len(); - - charge_overhead_weight::(&mut env, len, LOG_PREFIX)?; - - // read the input as RuntimeCall - let call: RuntimeCall = env.read_as_unbounded(len)?; - - // contract is the origin by default - let origin: RuntimeOrigin = RawOrigin::Signed(env.ext().address().clone()).into(); - - dispatch_call::(&mut env, call, origin, LOG_PREFIX) -} - -fn read_state(env: Environment) -> Result<(), DispatchError> -where - T: pallet_contracts::Config, - E: Ext, -{ - const LOG_PREFIX: &str = " read_state |"; - - let mut env = env.buf_in_buf_out(); - - // To be conservative, we charge the weight for reading the input bytes of a fixed-size type. - let base_weight: Weight = T::WeightInfo::seal_return(env.in_len()); - let charged_weight = env.charge_weight(base_weight)?; - - log::debug!(target:LOG_TARGET, "{} charged weight: {:?}", LOG_PREFIX, charged_weight); - - let key: RuntimeStateKeys = env.read_as()?; - - let result = match key { - _ => Vec::::default(), - } - .encode(); - - log::trace!( - target:LOG_TARGET, - "{} result: {:?}.", LOG_PREFIX, result - ); - env.write(&result, false, None).map_err(|e| { - log::trace!(target: LOG_TARGET, "{:?}", e); - DispatchError::Other("unable to write results to contract memory") - }) -} diff --git a/runtime/live/src/lib.rs b/runtime/live/src/lib.rs index c247420c..f91f9e56 100644 --- a/runtime/live/src/lib.rs +++ b/runtime/live/src/lib.rs @@ -7,7 +7,6 @@ include!(concat!(env!("OUT_DIR"), "/wasm_binary.rs")); mod config; -mod extensions; mod weights; use config::xcm::{RelayLocation, XcmOriginToTransactDispatchOrigin}; @@ -244,10 +243,10 @@ impl Contains for FilteredCalls { matches!( c, RuntimeCall::Balances( - force_adjust_total_issuance { .. } | - force_set_balance { .. } | - force_transfer { .. } | - force_unreserve { .. } + force_adjust_total_issuance { .. } + | force_set_balance { .. } + | force_transfer { .. } + | force_unreserve { .. } ) ) } From 812fd0ba570c901d1c6940ce9ff12c6c343f0832 Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 20:04:58 -0600 Subject: [PATCH 02/11] refactor(mainnet): change `live` to mainnet runtime` --- Cargo.toml | 28 +++++++-------- node/src/chain_spec.rs | 14 ++++---- node/src/command.rs | 34 +++++++++++-------- runtime/{live => mainnet}/Cargo.toml | 0 runtime/{live => mainnet}/build.rs | 0 .../{live => mainnet}/src/config/assets.rs | 0 .../{live => mainnet}/src/config/contracts.rs | 0 runtime/{live => mainnet}/src/config/mod.rs | 0 runtime/{live => mainnet}/src/config/proxy.rs | 0 runtime/{live => mainnet}/src/config/xcm.rs | 0 runtime/{live => mainnet}/src/lib.rs | 0 .../src/weights/block_weights.rs | 0 .../src/weights/extrinsic_weights.rs | 0 runtime/{live => mainnet}/src/weights/mod.rs | 0 .../src/weights/paritydb_weights.rs | 0 .../src/weights/rocksdb_weights.rs | 0 16 files changed, 40 insertions(+), 36 deletions(-) rename runtime/{live => mainnet}/Cargo.toml (100%) rename runtime/{live => mainnet}/build.rs (100%) rename runtime/{live => mainnet}/src/config/assets.rs (100%) rename runtime/{live => mainnet}/src/config/contracts.rs (100%) rename runtime/{live => mainnet}/src/config/mod.rs (100%) rename runtime/{live => mainnet}/src/config/proxy.rs (100%) rename runtime/{live => mainnet}/src/config/xcm.rs (100%) rename runtime/{live => mainnet}/src/lib.rs (100%) rename runtime/{live => mainnet}/src/weights/block_weights.rs (100%) rename runtime/{live => mainnet}/src/weights/extrinsic_weights.rs (100%) rename runtime/{live => mainnet}/src/weights/mod.rs (100%) rename runtime/{live => mainnet}/src/weights/paritydb_weights.rs (100%) rename runtime/{live => mainnet}/src/weights/rocksdb_weights.rs (100%) diff --git a/Cargo.toml b/Cargo.toml index 45b67456..410d1c88 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ inherits = "release" lto = true [workspace.package] -authors = [ "R0GUE " ] +authors = ["R0GUE "] description = "Pop Network makes it easy for smart contract developers to use the Power of Polkadot." edition = "2021" homepage = "https://r0gue.io" @@ -15,36 +15,36 @@ license = "Unlicense" repository = "https://github.com/r0gue-io/pop-node/" [workspace] -exclude = [ "pop-api", "tests/contracts" ] +exclude = ["pop-api", "tests/contracts"] members = [ - "integration-tests", - "node", - "primitives", - "runtime/devnet", - "runtime/live", - "runtime/testnet", + "integration-tests", + "node", + "primitives", + "runtime/devnet", + "runtime/mainnet", + "runtime/testnet", ] resolver = "2" [workspace.dependencies] -clap = { version = "4.4.18", features = [ "derive" ] } +clap = { version = "4.4.18", features = ["derive"] } codec = { package = "parity-scale-codec", version = "3.6.12", default-features = false, features = [ - "derive", + "derive", ] } futures = "0.3.28" hex-literal = "0.4.1" -jsonrpsee = { version = "0.23.2", features = [ "server" ] } +jsonrpsee = { version = "0.23.2", features = ["server"] } log = { version = "0.4.21", default-features = false } scale-info = { version = "2.11.1", default-features = false, features = [ - "derive", + "derive", ] } serde = "1.0.197" serde_json = "1.0.114" smallvec = "1.11.2" subxt = "0.34.0" subxt-signer = "0.34.0" -tokio = { version = "1.36", features = [ "macros", "rt-multi-thread", "time" ] } +tokio = { version = "1.36", features = ["macros", "rt-multi-thread", "time"] } tracing-subscriber = { version = "0.3", default-features = false } # Build @@ -53,7 +53,7 @@ substrate-wasm-builder = "23.0.0" # Local pop-primitives = { path = "./primitives", default-features = false } -pop-runtime = { path = "runtime/live", default-features = true } # default-features=true required for `-p pop-node` builds +pop-runtime = { path = "runtime/mainnet", default-features = true } # default-features=true required for `-p pop-node` builds pop-runtime-common = { path = "runtime/common", default-features = false } pop-runtime-devnet = { path = "runtime/devnet", default-features = true } # default-features=true required for `-p pop-node` builds pop-runtime-testnet = { path = "runtime/testnet", default-features = true } # default-features=true required for `-p pop-node` builds diff --git a/node/src/chain_spec.rs b/node/src/chain_spec.rs index 9e7820f5..59c5fa22 100644 --- a/node/src/chain_spec.rs +++ b/node/src/chain_spec.rs @@ -13,7 +13,7 @@ pub type DevnetChainSpec = sc_service::GenericChainSpec; pub type TestnetChainSpec = sc_service::GenericChainSpec; /// Specialized `ChainSpec` for the live parachain runtime. -pub type LiveChainSpec = sc_service::GenericChainSpec; +pub type MainnetChainSpec = sc_service::GenericChainSpec; /// The default XCM version to set in genesis config. const SAFE_XCM_VERSION: u32 = xcm::prelude::XCM_VERSION; @@ -81,7 +81,7 @@ pub fn pop_testnet_session_keys(keys: AuraId) -> pop_runtime_testnet::SessionKey /// Generate the session keys from individual elements. /// /// The input must be a tuple of individual keys (a single arg for now since we have just one key). -pub fn pop_live_session_keys(keys: AuraId) -> pop_runtime::SessionKeys { +pub fn pop_mainnet_session_keys(keys: AuraId) -> pop_runtime::SessionKeys { pop_runtime::SessionKeys { aura: keys } } @@ -189,7 +189,7 @@ pub fn testnet_config(relay: Relay) -> TestnetChainSpec { .build() } -pub fn live_config(relay: Relay) -> LiveChainSpec { +pub fn mainnet_config(relay: Relay) -> MainnetChainSpec { let mut properties = sc_chain_spec::Properties::new(); let (extensions, para_id) = configure_for_relay(relay, &mut properties); @@ -209,14 +209,14 @@ pub fn live_config(relay: Relay) -> LiveChainSpec { AccountId::from_ss58check("5FPL3ZLqUk6MyBoZrQZ1Co29WAteX6T6N68TZ6jitHvhpyuD").unwrap(); #[allow(deprecated)] - LiveChainSpec::builder( + MainnetChainSpec::builder( pop_runtime::WASM_BINARY.expect("WASM binary was not built, please build it!"), extensions, ) .with_name("Pop Network") .with_id("pop") .with_chain_type(ChainType::Live) - .with_genesis_config_patch(live_genesis( + .with_genesis_config_patch(mainnet_genesis( // initial collators. vec![ // POP COLLATOR 0 @@ -234,7 +234,7 @@ pub fn live_config(relay: Relay) -> LiveChainSpec { .build() } -fn live_genesis( +fn mainnet_genesis( invulnerables: Vec<(AccountId, AuraId)>, root: AccountId, id: ParaId, @@ -260,7 +260,7 @@ fn live_genesis( ( acc.clone(), // account id acc, // validator id - pop_live_session_keys(aura), // session keys + pop_mainnet_session_keys(aura), // session keys ) }) .collect::>(), diff --git a/node/src/command.rs b/node/src/command.rs index 45bddafe..c2514ea3 100644 --- a/node/src/command.rs +++ b/node/src/command.rs @@ -23,7 +23,7 @@ use crate::{ enum Runtime { Devnet, Testnet, - Live, + Mainnet, } trait RuntimeResolver { @@ -36,8 +36,8 @@ fn runtime(id: &str) -> Runtime { Runtime::Devnet } else if id.starts_with("test") || id.ends_with("testnet") { Runtime::Testnet - } else if id.eq("pop") || id.ends_with("live") { - Runtime::Live + } else if id.eq("pop") || id.ends_with("live") || id.ends_with("mainnet") { + Runtime::Mainnet } else { log::warn!( "No specific runtime was recognized for ChainSpec's Id: '{}', so Runtime::Devnet will \ @@ -72,18 +72,20 @@ impl RuntimeResolver for PathBuf { fn load_spec(id: &str) -> std::result::Result, String> { Ok(match id { - "dev" | "devnet" | "dev-paseo" => - Box::new(chain_spec::development_config(Relay::PaseoLocal)), + "dev" | "devnet" | "dev-paseo" => { + Box::new(chain_spec::development_config(Relay::PaseoLocal)) + }, "test" | "testnet" | "pop-paseo" => Box::new(chain_spec::testnet_config(Relay::Paseo)), - "pop-network" | "pop" | "pop-polkadot" => - Box::new(chain_spec::live_config(Relay::Polkadot)), + "pop-network" | "pop" | "pop-polkadot" => { + Box::new(chain_spec::mainnet_config(Relay::Polkadot)) + }, "" | "local" => Box::new(chain_spec::development_config(Relay::PaseoLocal)), path => { let path: PathBuf = path.into(); match path.runtime() { Runtime::Devnet => Box::new(chain_spec::DevnetChainSpec::from_json_file(path)?), Runtime::Testnet => Box::new(chain_spec::TestnetChainSpec::from_json_file(path)?), - Runtime::Live => Box::new(chain_spec::LiveChainSpec::from_json_file(path)?), + Runtime::Mainnet => Box::new(chain_spec::MainnetChainSpec::from_json_file(path)?), } }, }) @@ -181,7 +183,7 @@ macro_rules! construct_async_run { { $( $code )* }.map(|v| (v, task_manager)) }) } - Runtime::Live => { + Runtime::Mainnet => { runner.async_run(|$config| { let $components = new_partial::( &$config @@ -205,7 +207,7 @@ macro_rules! construct_benchmark_partials { let $partials = new_partial::(&$config)?; $code }, - Runtime::Live => { + Runtime::Mainnet => { let $partials = new_partial::(&$config)?; $code }, @@ -283,7 +285,7 @@ pub fn run() -> Result<()> { let runner = cli.create_runner(cmd)?; // Switch on the concrete benchmark sub-command- match cmd { - BenchmarkCmd::Pallet(cmd) => + BenchmarkCmd::Pallet(cmd) => { if cfg!(feature = "runtime-benchmarks") { runner.sync_run(|config| { cmd.run_with_spec::, ReclaimHostFunctions>(Some( @@ -294,7 +296,8 @@ pub fn run() -> Result<()> { Err("Benchmarking wasn't enabled when building the node. You can enable \ it with `--features runtime-benchmarks`." .into()) - }, + } + }, BenchmarkCmd::Block(cmd) => runner.sync_run(|config| { construct_benchmark_partials!(config, |partials| cmd.run(partials.client)) }), @@ -311,8 +314,9 @@ pub fn run() -> Result<()> { cmd.run(config, partials.client.clone(), db, storage) }) }), - BenchmarkCmd::Machine(cmd) => - runner.sync_run(|config| cmd.run(&config, SUBSTRATE_REFERENCE_HARDWARE.clone())), + BenchmarkCmd::Machine(cmd) => { + runner.sync_run(|config| cmd.run(&config, SUBSTRATE_REFERENCE_HARDWARE.clone())) + }, // NOTE: this allows the Client to leniently implement // new benchmark commands without requiring a companion MR. #[allow(unreachable_patterns)] @@ -381,7 +385,7 @@ pub fn run() -> Result<()> { .map(|r| r.0) .map_err(Into::into) }, - Runtime::Live => { + Runtime::Mainnet => { sp_core::crypto::set_default_ss58_version( pop_runtime::SS58Prefix::get().into(), ); diff --git a/runtime/live/Cargo.toml b/runtime/mainnet/Cargo.toml similarity index 100% rename from runtime/live/Cargo.toml rename to runtime/mainnet/Cargo.toml diff --git a/runtime/live/build.rs b/runtime/mainnet/build.rs similarity index 100% rename from runtime/live/build.rs rename to runtime/mainnet/build.rs diff --git a/runtime/live/src/config/assets.rs b/runtime/mainnet/src/config/assets.rs similarity index 100% rename from runtime/live/src/config/assets.rs rename to runtime/mainnet/src/config/assets.rs diff --git a/runtime/live/src/config/contracts.rs b/runtime/mainnet/src/config/contracts.rs similarity index 100% rename from runtime/live/src/config/contracts.rs rename to runtime/mainnet/src/config/contracts.rs diff --git a/runtime/live/src/config/mod.rs b/runtime/mainnet/src/config/mod.rs similarity index 100% rename from runtime/live/src/config/mod.rs rename to runtime/mainnet/src/config/mod.rs diff --git a/runtime/live/src/config/proxy.rs b/runtime/mainnet/src/config/proxy.rs similarity index 100% rename from runtime/live/src/config/proxy.rs rename to runtime/mainnet/src/config/proxy.rs diff --git a/runtime/live/src/config/xcm.rs b/runtime/mainnet/src/config/xcm.rs similarity index 100% rename from runtime/live/src/config/xcm.rs rename to runtime/mainnet/src/config/xcm.rs diff --git a/runtime/live/src/lib.rs b/runtime/mainnet/src/lib.rs similarity index 100% rename from runtime/live/src/lib.rs rename to runtime/mainnet/src/lib.rs diff --git a/runtime/live/src/weights/block_weights.rs b/runtime/mainnet/src/weights/block_weights.rs similarity index 100% rename from runtime/live/src/weights/block_weights.rs rename to runtime/mainnet/src/weights/block_weights.rs diff --git a/runtime/live/src/weights/extrinsic_weights.rs b/runtime/mainnet/src/weights/extrinsic_weights.rs similarity index 100% rename from runtime/live/src/weights/extrinsic_weights.rs rename to runtime/mainnet/src/weights/extrinsic_weights.rs diff --git a/runtime/live/src/weights/mod.rs b/runtime/mainnet/src/weights/mod.rs similarity index 100% rename from runtime/live/src/weights/mod.rs rename to runtime/mainnet/src/weights/mod.rs diff --git a/runtime/live/src/weights/paritydb_weights.rs b/runtime/mainnet/src/weights/paritydb_weights.rs similarity index 100% rename from runtime/live/src/weights/paritydb_weights.rs rename to runtime/mainnet/src/weights/paritydb_weights.rs diff --git a/runtime/live/src/weights/rocksdb_weights.rs b/runtime/mainnet/src/weights/rocksdb_weights.rs similarity index 100% rename from runtime/live/src/weights/rocksdb_weights.rs rename to runtime/mainnet/src/weights/rocksdb_weights.rs From 8dfa2734a514e0e975297c1a6b6824aa348456b1 Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 22:04:23 -0600 Subject: [PATCH 03/11] chore(mainnet): remove unnecessary migrations --- runtime/mainnet/src/lib.rs | 11 +---------- 1 file changed, 1 insertion(+), 10 deletions(-) diff --git a/runtime/mainnet/src/lib.rs b/runtime/mainnet/src/lib.rs index f91f9e56..60471386 100644 --- a/runtime/mainnet/src/lib.rs +++ b/runtime/mainnet/src/lib.rs @@ -102,11 +102,7 @@ pub type UncheckedExtrinsic = generic::UncheckedExtrinsic; /// Migrations to apply on runtime upgrade. -pub type Migrations = ( - pallet_contracts::Migration, - cumulus_pallet_xcmp_queue::migration::v5::MigrateV4ToV5, - pallet_xcm::migration::MigrateToLatestXcmVersion, -); +pub type Migrations = (); /// Executive: handles dispatch to the various modules. pub type Executive = frame_executive::Executive< @@ -424,11 +420,6 @@ impl cumulus_pallet_xcmp_queue::Config for Runtime { type XcmpQueue = TransformOrigin; } -impl cumulus_pallet_xcmp_queue::migration::v5::V5Config for Runtime { - // This must be the same as the `ChannelInfo` from the `Config`: - type ChannelList = ParachainSystem; -} - parameter_types! { pub const Period: u32 = 6 * HOURS; pub const Offset: u32 = 0; From 5da5a0cce0d7279a81a9b35c3c8f77eb0b555db8 Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 22:13:40 -0600 Subject: [PATCH 04/11] chore(mainnet): secure contracts config --- runtime/mainnet/src/config/contracts.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/runtime/mainnet/src/config/contracts.rs b/runtime/mainnet/src/config/contracts.rs index cc3c127d..b509ef7e 100644 --- a/runtime/mainnet/src/config/contracts.rs +++ b/runtime/mainnet/src/config/contracts.rs @@ -69,14 +69,14 @@ impl pallet_contracts::Config for Runtime { type MaxDebugBufferLen = ConstU32<{ 2 * 1024 * 1024 }>; type MaxDelegateDependencies = ConstU32<32>; type MaxStorageKeyLen = ConstU32<128>; - type Migrations = (pallet_contracts::migration::v16::Migration,); + type Migrations = (); type Randomness = DummyRandomness; type RuntimeCall = RuntimeCall; type RuntimeEvent = RuntimeEvent; type RuntimeHoldReason = RuntimeHoldReason; type Schedule = Schedule; type Time = Timestamp; - type UnsafeUnstableInterface = ConstBool; + type UnsafeUnstableInterface = ConstBool; type UploadOrigin = EnsureSigned; type WeightInfo = pallet_contracts::weights::SubstrateWeight; type WeightPrice = pallet_transaction_payment::Pallet; From ffcfcae0d912b1e0bfa1009673551f1ca549e977 Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 22:28:03 -0600 Subject: [PATCH 05/11] feat(mainnet): add pop-up config, and add mainnet option in command.rs --- networks/mainnet.toml | 40 ++++++++++++++++++++++++++++++++++++++++ node/src/command.rs | 2 +- 2 files changed, 41 insertions(+), 1 deletion(-) create mode 100644 networks/mainnet.toml diff --git a/networks/mainnet.toml b/networks/mainnet.toml new file mode 100644 index 00000000..414df541 --- /dev/null +++ b/networks/mainnet.toml @@ -0,0 +1,40 @@ +# pop up parachain -f ./tests/networks/pop.toml + +[relaychain] +chain = "paseo-local" + +[relaychain.runtime_genesis_patch.balances] +balances = [ + # Pop sovereign account + ["5Ec4AhPKXY9B4ayGshkz2wFMh7N8gP7XKfAvtt1cigpG9FkJ", 60000000000000000], +] + +[[relaychain.nodes]] +name = "alice" +rpc_port = 8833 +validator = true + +[[relaychain.nodes]] +name = "bob" +validator = true + +[[parachains]] +id = 4001 +chain = "mainnet" +default_command = "./target/release/pop-node" + +[parachains.genesis_overrides.balances] +balances = [ + # Dev accounts + ["5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY", 10000000000000000], + ["5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty", 10000000000000000], + ["5FLSigC9HGRKVhB9FiEo4Y3koPsNmBmLJbpXg2mp1hXcS59Y", 10000000000000000], + ["5DAAnrj7VHTznn2AWBemMuyBwZWs6FNFjdyVXUeYum3PTXFy", 10000000000000000], + ["5HGjWAeFDfFCWPsjFQdVV2Msvz2XtMktvgocEZcCj68kUMaw", 10000000000000000], + ["5CiPPseXPECbkjWCa6MnjNokrgYjMqmKndv2rSnekmSK2DjL", 10000000000000000], +] + +[[parachains.collators]] +name = "pop" +rpc_port = 9944 +args = ["-lruntime::contracts=debug", "-lpopapi::extension=debug"] \ No newline at end of file diff --git a/node/src/command.rs b/node/src/command.rs index c2514ea3..a1bb41f2 100644 --- a/node/src/command.rs +++ b/node/src/command.rs @@ -76,7 +76,7 @@ fn load_spec(id: &str) -> std::result::Result, String> { Box::new(chain_spec::development_config(Relay::PaseoLocal)) }, "test" | "testnet" | "pop-paseo" => Box::new(chain_spec::testnet_config(Relay::Paseo)), - "pop-network" | "pop" | "pop-polkadot" => { + "pop-network" | "pop" | "pop-polkadot" | "mainnet" => { Box::new(chain_spec::mainnet_config(Relay::Polkadot)) }, "" | "local" => Box::new(chain_spec::development_config(Relay::PaseoLocal)), From 565e7a044a09c5fd19574983d36d98617f98cceb Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 22:44:56 -0600 Subject: [PATCH 06/11] style: fmt --- Cargo.toml | 28 ++++++++++++++-------------- node/src/command.rs | 20 ++++++++------------ runtime/mainnet/src/lib.rs | 8 ++++---- 3 files changed, 26 insertions(+), 30 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 410d1c88..335fef07 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ inherits = "release" lto = true [workspace.package] -authors = ["R0GUE "] +authors = [ "R0GUE " ] description = "Pop Network makes it easy for smart contract developers to use the Power of Polkadot." edition = "2021" homepage = "https://r0gue.io" @@ -15,36 +15,36 @@ license = "Unlicense" repository = "https://github.com/r0gue-io/pop-node/" [workspace] -exclude = ["pop-api", "tests/contracts"] +exclude = [ "pop-api", "tests/contracts" ] members = [ - "integration-tests", - "node", - "primitives", - "runtime/devnet", - "runtime/mainnet", - "runtime/testnet", + "integration-tests", + "node", + "primitives", + "runtime/devnet", + "runtime/mainnet", + "runtime/testnet", ] resolver = "2" [workspace.dependencies] -clap = { version = "4.4.18", features = ["derive"] } +clap = { version = "4.4.18", features = [ "derive" ] } codec = { package = "parity-scale-codec", version = "3.6.12", default-features = false, features = [ - "derive", + "derive", ] } futures = "0.3.28" hex-literal = "0.4.1" -jsonrpsee = { version = "0.23.2", features = ["server"] } +jsonrpsee = { version = "0.23.2", features = [ "server" ] } log = { version = "0.4.21", default-features = false } scale-info = { version = "2.11.1", default-features = false, features = [ - "derive", + "derive", ] } serde = "1.0.197" serde_json = "1.0.114" smallvec = "1.11.2" subxt = "0.34.0" subxt-signer = "0.34.0" -tokio = { version = "1.36", features = ["macros", "rt-multi-thread", "time"] } +tokio = { version = "1.36", features = [ "macros", "rt-multi-thread", "time" ] } tracing-subscriber = { version = "0.3", default-features = false } # Build @@ -53,7 +53,7 @@ substrate-wasm-builder = "23.0.0" # Local pop-primitives = { path = "./primitives", default-features = false } -pop-runtime = { path = "runtime/mainnet", default-features = true } # default-features=true required for `-p pop-node` builds +pop-runtime = { path = "runtime/mainnet", default-features = true } # default-features=true required for `-p pop-node` builds pop-runtime-common = { path = "runtime/common", default-features = false } pop-runtime-devnet = { path = "runtime/devnet", default-features = true } # default-features=true required for `-p pop-node` builds pop-runtime-testnet = { path = "runtime/testnet", default-features = true } # default-features=true required for `-p pop-node` builds diff --git a/node/src/command.rs b/node/src/command.rs index a1bb41f2..0b82edef 100644 --- a/node/src/command.rs +++ b/node/src/command.rs @@ -72,13 +72,11 @@ impl RuntimeResolver for PathBuf { fn load_spec(id: &str) -> std::result::Result, String> { Ok(match id { - "dev" | "devnet" | "dev-paseo" => { - Box::new(chain_spec::development_config(Relay::PaseoLocal)) - }, + "dev" | "devnet" | "dev-paseo" => + Box::new(chain_spec::development_config(Relay::PaseoLocal)), "test" | "testnet" | "pop-paseo" => Box::new(chain_spec::testnet_config(Relay::Paseo)), - "pop-network" | "pop" | "pop-polkadot" | "mainnet" => { - Box::new(chain_spec::mainnet_config(Relay::Polkadot)) - }, + "pop-network" | "pop" | "pop-polkadot" | "mainnet" => + Box::new(chain_spec::mainnet_config(Relay::Polkadot)), "" | "local" => Box::new(chain_spec::development_config(Relay::PaseoLocal)), path => { let path: PathBuf = path.into(); @@ -285,7 +283,7 @@ pub fn run() -> Result<()> { let runner = cli.create_runner(cmd)?; // Switch on the concrete benchmark sub-command- match cmd { - BenchmarkCmd::Pallet(cmd) => { + BenchmarkCmd::Pallet(cmd) => if cfg!(feature = "runtime-benchmarks") { runner.sync_run(|config| { cmd.run_with_spec::, ReclaimHostFunctions>(Some( @@ -296,8 +294,7 @@ pub fn run() -> Result<()> { Err("Benchmarking wasn't enabled when building the node. You can enable \ it with `--features runtime-benchmarks`." .into()) - } - }, + }, BenchmarkCmd::Block(cmd) => runner.sync_run(|config| { construct_benchmark_partials!(config, |partials| cmd.run(partials.client)) }), @@ -314,9 +311,8 @@ pub fn run() -> Result<()> { cmd.run(config, partials.client.clone(), db, storage) }) }), - BenchmarkCmd::Machine(cmd) => { - runner.sync_run(|config| cmd.run(&config, SUBSTRATE_REFERENCE_HARDWARE.clone())) - }, + BenchmarkCmd::Machine(cmd) => + runner.sync_run(|config| cmd.run(&config, SUBSTRATE_REFERENCE_HARDWARE.clone())), // NOTE: this allows the Client to leniently implement // new benchmark commands without requiring a companion MR. #[allow(unreachable_patterns)] diff --git a/runtime/mainnet/src/lib.rs b/runtime/mainnet/src/lib.rs index 60471386..3c1bfe8e 100644 --- a/runtime/mainnet/src/lib.rs +++ b/runtime/mainnet/src/lib.rs @@ -239,10 +239,10 @@ impl Contains for FilteredCalls { matches!( c, RuntimeCall::Balances( - force_adjust_total_issuance { .. } - | force_set_balance { .. } - | force_transfer { .. } - | force_unreserve { .. } + force_adjust_total_issuance { .. } | + force_set_balance { .. } | + force_transfer { .. } | + force_unreserve { .. } ) ) } From 7f7166becaead1acaf5648d481fb0c39652c1736 Mon Sep 17 00:00:00 2001 From: Peter White Date: Tue, 27 Aug 2024 22:48:52 -0600 Subject: [PATCH 07/11] feat(CI): add mainnet to CI release --- .github/workflows/release.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index c82d1b9f..d43fb075 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -28,7 +28,7 @@ jobs: contents: write strategy: matrix: - runtime: [ "devnet", "testnet" ] + runtime: [ "devnet", "testnet", "mainnet" ] steps: - name: Checkout sources uses: actions/checkout@v4 From 5c2ed5b1b950b24a0d3619366cd5636e769de4fc Mon Sep 17 00:00:00 2001 From: Alejandro Martinez Andres <11448715+al3mart@users.noreply.github.com> Date: Wed, 28 Aug 2024 17:00:30 +0200 Subject: [PATCH 08/11] chore: remove contracts & asset related pallets (#241) --- node/src/chain_spec.rs | 2 +- runtime/mainnet/src/config/assets.rs | 122 -------------------- runtime/mainnet/src/config/contracts.rs | 84 -------------- runtime/mainnet/src/config/mod.rs | 2 - runtime/mainnet/src/config/proxy.rs | 69 ++---------- runtime/mainnet/src/lib.rs | 141 +----------------------- 6 files changed, 12 insertions(+), 408 deletions(-) delete mode 100644 runtime/mainnet/src/config/assets.rs delete mode 100644 runtime/mainnet/src/config/contracts.rs diff --git a/node/src/chain_spec.rs b/node/src/chain_spec.rs index 59c5fa22..3f591033 100644 --- a/node/src/chain_spec.rs +++ b/node/src/chain_spec.rs @@ -103,7 +103,7 @@ fn configure_for_relay( (Extensions { relay_chain, para_id }, para_id) }, Relay::Polkadot => { - para_id = 3456; + para_id = 3395; properties.insert("tokenSymbol".into(), "DOT".into()); properties.insert("tokenDecimals".into(), 10.into()); (Extensions { relay_chain: "polkadot".into(), para_id }, para_id) diff --git a/runtime/mainnet/src/config/assets.rs b/runtime/mainnet/src/config/assets.rs deleted file mode 100644 index d66358a6..00000000 --- a/runtime/mainnet/src/config/assets.rs +++ /dev/null @@ -1,122 +0,0 @@ -use frame_support::{ - parameter_types, - traits::{AsEnsureOriginWithArg, ConstU32}, - BoundedVec, PalletId, -}; -use frame_system::{EnsureRoot, EnsureSigned}; -use pallet_nfts::PalletFeatures; -use parachains_common::{AssetIdForTrustBackedAssets, CollectionId, ItemId, Signature}; -use sp_runtime::traits::Verify; - -use crate::{ - deposit, AccountId, Assets, Balance, Balances, BlockNumber, Nfts, Runtime, RuntimeEvent, - RuntimeHoldReason, DAYS, EXISTENTIAL_DEPOSIT, UNIT, -}; - -/// We allow root to execute privileged asset operations. -pub type AssetsForceOrigin = EnsureRoot; - -parameter_types! { - pub const AssetDeposit: Balance = 10 * UNIT; - pub const AssetAccountDeposit: Balance = deposit(1, 16); - pub const ApprovalDeposit: Balance = EXISTENTIAL_DEPOSIT; - pub const AssetsStringLimit: u32 = 50; - /// Key = 32 bytes, Value = 36 bytes (32+1+1+1+1) - // https://github.com/paritytech/substrate/blob/069917b/frame/assets/src/lib.rs#L257L271 - pub const MetadataDepositBase: Balance = deposit(1, 68); - pub const MetadataDepositPerByte: Balance = deposit(0, 1); -} - -parameter_types! { - pub NftsPalletFeatures: PalletFeatures = PalletFeatures::all_enabled(); - pub const NftsCollectionDeposit: Balance = 10 * UNIT; - pub const NftsItemDeposit: Balance = UNIT / 100; - pub const NftsMetadataDepositBase: Balance = deposit(1, 129); - pub const NftsAttributeDepositBase: Balance = deposit(1, 0); - pub const NftsDepositPerByte: Balance = deposit(0, 1); - pub const NftsMaxDeadlineDuration: BlockNumber = 12 * 30 * DAYS; -} - -impl pallet_nfts::Config for Runtime { - // TODO: source from primitives - type ApprovalsLimit = ConstU32<20>; - type AttributeDepositBase = NftsAttributeDepositBase; - type CollectionDeposit = NftsCollectionDeposit; - // TODO: source from primitives - type CollectionId = CollectionId; - type CreateOrigin = AsEnsureOriginWithArg>; - type Currency = Balances; - type DepositPerByte = NftsDepositPerByte; - type Features = NftsPalletFeatures; - type ForceOrigin = AssetsForceOrigin; - #[cfg(feature = "runtime-benchmarks")] - type Helper = (); - type ItemAttributesApprovalsLimit = ConstU32<30>; - type ItemDeposit = NftsItemDeposit; - // TODO: source from primitives - type ItemId = ItemId; - // TODO: source from primitives - type KeyLimit = ConstU32<64>; - type Locker = (); - type MaxAttributesPerCall = ConstU32<10>; - type MaxDeadlineDuration = NftsMaxDeadlineDuration; - type MaxTips = ConstU32<10>; - type MetadataDepositBase = NftsMetadataDepositBase; - type OffchainPublic = ::Signer; - type OffchainSignature = Signature; - type RuntimeEvent = RuntimeEvent; - type StringLimit = ConstU32<256>; - type ValueLimit = ConstU32<256>; - type WeightInfo = pallet_nfts::weights::SubstrateWeight; -} - -parameter_types! { - pub const NftFractionalizationPalletId: PalletId = PalletId(*b"fraction"); - pub NewAssetSymbol: BoundedVec = (*b"FRAC").to_vec().try_into().unwrap(); - pub NewAssetName: BoundedVec = (*b"Frac").to_vec().try_into().unwrap(); -} - -impl pallet_nft_fractionalization::Config for Runtime { - type AssetBalance = >::Balance; - type AssetId = >::AssetId; - type Assets = Assets; - #[cfg(feature = "runtime-benchmarks")] - type BenchmarkHelper = (); - type Currency = Balances; - type Deposit = AssetDeposit; - type NewAssetName = NewAssetName; - type NewAssetSymbol = NewAssetSymbol; - type NftCollectionId = ::CollectionId; - type NftId = ::ItemId; - type Nfts = Nfts; - type PalletId = NftFractionalizationPalletId; - type RuntimeEvent = RuntimeEvent; - type RuntimeHoldReason = RuntimeHoldReason; - type StringLimit = AssetsStringLimit; - type WeightInfo = pallet_nft_fractionalization::weights::SubstrateWeight; -} - -pub type TrustBackedAssets = pallet_assets::Instance1; -pub type TrustBackedAssetsCall = pallet_assets::Call; -impl pallet_assets::Config for Runtime { - type ApprovalDeposit = ApprovalDeposit; - type AssetAccountDeposit = AssetAccountDeposit; - type AssetDeposit = AssetDeposit; - type AssetId = AssetIdForTrustBackedAssets; - type AssetIdParameter = codec::Compact; - type Balance = Balance; - #[cfg(feature = "runtime-benchmarks")] - type BenchmarkHelper = (); - type CallbackHandle = (); - type CreateOrigin = AsEnsureOriginWithArg>; - type Currency = Balances; - type Extra = (); - type ForceOrigin = AssetsForceOrigin; - type Freezer = (); - type MetadataDepositBase = MetadataDepositBase; - type MetadataDepositPerByte = MetadataDepositPerByte; - type RemoveItemsLimit = ConstU32<1000>; - type RuntimeEvent = RuntimeEvent; - type StringLimit = AssetsStringLimit; - type WeightInfo = pallet_assets::weights::SubstrateWeight; -} diff --git a/runtime/mainnet/src/config/contracts.rs b/runtime/mainnet/src/config/contracts.rs deleted file mode 100644 index b509ef7e..00000000 --- a/runtime/mainnet/src/config/contracts.rs +++ /dev/null @@ -1,84 +0,0 @@ -use frame_support::{ - parameter_types, - traits::{ConstBool, ConstU32, Nothing, Randomness}, -}; -use frame_system::{pallet_prelude::BlockNumberFor, EnsureSigned}; - -use crate::{ - deposit, Balance, Balances, BalancesCall, Perbill, Runtime, RuntimeCall, RuntimeEvent, - RuntimeHoldReason, Timestamp, -}; - -fn schedule() -> pallet_contracts::Schedule { - pallet_contracts::Schedule { - limits: pallet_contracts::Limits { - runtime_memory: 1024 * 1024 * 1024, - ..Default::default() - }, - ..Default::default() - } -} - -// randomness-collective-flip is insecure. Provide dummy randomness as placeholder for the -// deprecated trait. https://github.com/paritytech/polkadot-sdk/blob/9bf1a5e23884921498b381728bfddaae93f83744/substrate/frame/contracts/mock-network/src/parachain/contracts_config.rs#L45 -pub struct DummyRandomness(sp_std::marker::PhantomData); - -impl Randomness> for DummyRandomness { - fn random(_subject: &[u8]) -> (T::Hash, BlockNumberFor) { - (Default::default(), Default::default()) - } -} - -parameter_types! { - pub const DepositPerItem: Balance = deposit(1, 0); - pub const DepositPerByte: Balance = deposit(0, 1); - pub Schedule: pallet_contracts::Schedule = schedule::(); - pub const DefaultDepositLimit: Balance = deposit(1024, 1024 * 1024); - pub const CodeHashLockupDepositPercent: Perbill = Perbill::from_percent(0); -} - -impl pallet_contracts::Config for Runtime { - type AddressGenerator = pallet_contracts::DefaultAddressGenerator; - type ApiVersion = (); - /// The safest default is to allow no calls at all. - /// - /// Runtimes should whitelist dispatchables that are allowed to be called from contracts - /// and make sure they are stable. Dispatchables exposed to contracts are not allowed to - /// change because that would break already deployed contracts. The `RuntimeCall` structure - /// itself is not allowed to change the indices of existing pallets, too. - type CallFilter = Nothing; - type CallStack = [pallet_contracts::Frame; 23]; - type ChainExtension = (); - type CodeHashLockupDepositPercent = CodeHashLockupDepositPercent; - type Currency = Balances; - type Debug = (); - type DefaultDepositLimit = DefaultDepositLimit; - type DepositPerByte = DepositPerByte; - type DepositPerItem = DepositPerItem; - type Environment = (); - type InstantiateOrigin = EnsureSigned; - // This node is geared towards development and testing of contracts. - // We decided to increase the default allowed contract size for this - // reason (the default is `128 * 1024`). - // - // Our reasoning is that the error code `CodeTooLarge` is thrown - // if a too-large contract is uploaded. We noticed that it poses - // less friction during development when the requirement here is - // just more lax. - type MaxCodeLen = ConstU32<{ 256 * 1024 }>; - type MaxDebugBufferLen = ConstU32<{ 2 * 1024 * 1024 }>; - type MaxDelegateDependencies = ConstU32<32>; - type MaxStorageKeyLen = ConstU32<128>; - type Migrations = (); - type Randomness = DummyRandomness; - type RuntimeCall = RuntimeCall; - type RuntimeEvent = RuntimeEvent; - type RuntimeHoldReason = RuntimeHoldReason; - type Schedule = Schedule; - type Time = Timestamp; - type UnsafeUnstableInterface = ConstBool; - type UploadOrigin = EnsureSigned; - type WeightInfo = pallet_contracts::weights::SubstrateWeight; - type WeightPrice = pallet_transaction_payment::Pallet; - type Xcm = pallet_xcm::Pallet; -} diff --git a/runtime/mainnet/src/config/mod.rs b/runtime/mainnet/src/config/mod.rs index a3a64c92..a866ca8a 100644 --- a/runtime/mainnet/src/config/mod.rs +++ b/runtime/mainnet/src/config/mod.rs @@ -1,5 +1,3 @@ -mod assets; -mod contracts; mod proxy; // Public due to integration tests crate. pub mod xcm; diff --git a/runtime/mainnet/src/config/proxy.rs b/runtime/mainnet/src/config/proxy.rs index ff70240e..0b8ab9b9 100644 --- a/runtime/mainnet/src/config/proxy.rs +++ b/runtime/mainnet/src/config/proxy.rs @@ -5,19 +5,13 @@ use pop_runtime_common::proxy::{ }; use sp_runtime::traits::BlakeTwo256; -use super::assets::TrustBackedAssetsCall; use crate::{Balances, Runtime, RuntimeCall, RuntimeEvent}; impl InstanceFilter for ProxyType { fn filter(&self, c: &RuntimeCall) -> bool { match self { ProxyType::Any => true, - ProxyType::NonTransfer => !matches!( - c, - RuntimeCall::Balances { .. } | - RuntimeCall::Assets { .. } | - RuntimeCall::Nfts { .. } - ), + ProxyType::NonTransfer => !matches!(c, RuntimeCall::Balances { .. }), ProxyType::CancelProxy => matches!( c, RuntimeCall::Proxy(pallet_proxy::Call::reject_announcement { .. }) | @@ -25,61 +19,14 @@ impl InstanceFilter for ProxyType { RuntimeCall::Multisig { .. } ), ProxyType::Assets => { - matches!( - c, - RuntimeCall::Assets { .. } | - RuntimeCall::Utility { .. } | - RuntimeCall::Multisig { .. } | - RuntimeCall::Nfts { .. } - ) + matches!(c, RuntimeCall::Utility { .. } | RuntimeCall::Multisig { .. }) + }, + ProxyType::AssetOwner => { + matches!(c, RuntimeCall::Utility { .. } | RuntimeCall::Multisig { .. }) + }, + ProxyType::AssetManager => { + matches!(c, RuntimeCall::Utility { .. } | RuntimeCall::Multisig { .. }) }, - ProxyType::AssetOwner => matches!( - c, - RuntimeCall::Assets(TrustBackedAssetsCall::create { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::start_destroy { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::destroy_accounts { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::destroy_approvals { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::finish_destroy { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::transfer_ownership { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::set_team { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::set_metadata { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::clear_metadata { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::set_min_balance { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::create { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::destroy { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::redeposit { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::transfer_ownership { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::set_team { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::set_collection_max_supply { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::lock_collection { .. }) | - RuntimeCall::Utility { .. } | - RuntimeCall::Multisig { .. } - ), - ProxyType::AssetManager => matches!( - c, - RuntimeCall::Assets(TrustBackedAssetsCall::mint { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::burn { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::freeze { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::block { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::thaw { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::freeze_asset { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::thaw_asset { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::touch_other { .. }) | - RuntimeCall::Assets(TrustBackedAssetsCall::refund_other { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::force_mint { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::update_mint_settings { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::mint_pre_signed { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::set_attributes_pre_signed { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::lock_item_transfer { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::unlock_item_transfer { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::lock_item_properties { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::set_metadata { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::clear_metadata { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::set_collection_metadata { .. }) | - RuntimeCall::Nfts(pallet_nfts::Call::clear_collection_metadata { .. }) | - RuntimeCall::Utility { .. } | - RuntimeCall::Multisig { .. } - ), ProxyType::Collator => matches!( c, RuntimeCall::CollatorSelection { .. } | diff --git a/runtime/mainnet/src/lib.rs b/runtime/mainnet/src/lib.rs index 3c1bfe8e..f36bf203 100644 --- a/runtime/mainnet/src/lib.rs +++ b/runtime/mainnet/src/lib.rs @@ -18,9 +18,9 @@ use frame_support::{ genesis_builder_helper::{build_state, get_preset}, parameter_types, traits::{ - fungible::HoldConsideration, tokens::nonfungibles_v2::Inspect, ConstBool, ConstU32, - ConstU64, ConstU8, Contains, EitherOfDiverse, EqualPrivilegeOnly, EverythingBut, - LinearStoragePrice, TransformOrigin, VariantCountOf, + fungible::HoldConsideration, ConstBool, ConstU32, ConstU64, ConstU8, Contains, + EitherOfDiverse, EqualPrivilegeOnly, EverythingBut, LinearStoragePrice, TransformOrigin, + VariantCountOf, }, weights::{ ConstantMultiplier, Weight, WeightToFeeCoefficient, WeightToFeeCoefficients, @@ -183,18 +183,6 @@ pub const VERSION: RuntimeVersion = RuntimeVersion { state_version: 1, }; -type EventRecord = frame_system::EventRecord< - ::RuntimeEvent, - ::Hash, ->; - -// Prints debug output of the `contracts` pallet to stdout if the node is -// started with `-lruntime::contracts=debug`. -const CONTRACTS_DEBUG_OUTPUT: pallet_contracts::DebugInfo = - pallet_contracts::DebugInfo::UnsafeDebug; -const CONTRACTS_EVENTS: pallet_contracts::CollectEvents = - pallet_contracts::CollectEvents::UnsafeCollect; - /// The version information used to identify this runtime when compiled natively. #[cfg(feature = "std")] pub fn native_version() -> NativeVersion { @@ -608,10 +596,6 @@ mod runtime { #[runtime::pallet_index(33)] pub type MessageQueue = pallet_message_queue::Pallet; - // Contracts - #[runtime::pallet_index(40)] - pub type Contracts = pallet_contracts::Pallet; - // Proxy #[runtime::pallet_index(41)] pub type Proxy = pallet_proxy::Pallet; @@ -621,14 +605,6 @@ mod runtime { // Utility #[runtime::pallet_index(43)] pub type Utility = pallet_utility::Pallet; - - // Assets - #[runtime::pallet_index(50)] - pub type Nfts = pallet_nfts::Pallet; - #[runtime::pallet_index(51)] - pub type NftFractionalization = pallet_nft_fractionalization::Pallet; - #[runtime::pallet_index(52)] - pub type Assets = pallet_assets::Pallet; } #[cfg(feature = "runtime-benchmarks")] @@ -785,73 +761,6 @@ impl_runtime_apis! { } } - impl pallet_contracts::ContractsApi - for Runtime - { - fn call( - origin: AccountId, - dest: AccountId, - value: Balance, - gas_limit: Option, - storage_deposit_limit: Option, - input_data: Vec, - ) -> pallet_contracts::ContractExecResult { - let gas_limit = gas_limit.unwrap_or(RuntimeBlockWeights::get().max_block); - Contracts::bare_call( - origin, - dest, - value, - gas_limit, - storage_deposit_limit, - input_data, - CONTRACTS_DEBUG_OUTPUT, - CONTRACTS_EVENTS, - pallet_contracts::Determinism::Enforced, - ) - } - - fn instantiate( - origin: AccountId, - value: Balance, - gas_limit: Option, - storage_deposit_limit: Option, - code: pallet_contracts::Code, - data: Vec, - salt: Vec, - ) -> pallet_contracts::ContractInstantiateResult - { - let gas_limit = gas_limit.unwrap_or(RuntimeBlockWeights::get().max_block); - Contracts::bare_instantiate( - origin, - value, - gas_limit, - storage_deposit_limit, - code, - data, - salt, - CONTRACTS_DEBUG_OUTPUT, - CONTRACTS_EVENTS, - ) - } - - fn upload_code( - origin: AccountId, - code: Vec, - storage_deposit_limit: Option, - determinism: pallet_contracts::Determinism, - ) -> pallet_contracts::CodeUploadResult - { - Contracts::bare_upload_code(origin, code, storage_deposit_limit, determinism) - } - - fn get_storage( - address: AccountId, - key: Vec, - ) -> pallet_contracts::GetStorageResult { - Contracts::get_storage(address, key) - } - } - impl cumulus_primitives_aura::AuraUnincludedSegmentApi for Runtime { fn can_build_upon( included_hash: ::Hash, @@ -867,50 +776,6 @@ impl_runtime_apis! { } } - impl pallet_nfts_runtime_api::NftsApi for Runtime { - fn owner(collection: u32, item: u32) -> Option { - >::owner(&collection, &item) - } - - fn collection_owner(collection: u32) -> Option { - >::collection_owner(&collection) - } - - fn attribute( - collection: u32, - item: u32, - key: Vec, - ) -> Option> { - >::attribute(&collection, &item, &key) - } - - fn custom_attribute( - account: AccountId, - collection: u32, - item: u32, - key: Vec, - ) -> Option> { - >::custom_attribute( - &account, - &collection, - &item, - &key, - ) - } - - fn system_attribute( - collection: u32, - item: Option, - key: Vec, - ) -> Option> { - >::system_attribute(&collection, item.as_ref(), &key) - } - - fn collection_attribute(collection: u32, key: Vec) -> Option> { - >::collection_attribute(&collection, &key) - } - } - #[cfg(feature = "try-runtime")] impl frame_try_runtime::TryRuntime for Runtime { fn on_runtime_upgrade(checks: frame_try_runtime::UpgradeCheckSelect) -> (Weight, Weight) { From 33322cb7bd8b4629c3e558315e612af554691e34 Mon Sep 17 00:00:00 2001 From: Peter White Date: Wed, 28 Aug 2024 16:25:46 -0600 Subject: [PATCH 09/11] use prefix 0 instead of 42 for mainnet --- node/src/chain_spec.rs | 3 ++- runtime/mainnet/src/lib.rs | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/node/src/chain_spec.rs b/node/src/chain_spec.rs index 3f591033..4287025a 100644 --- a/node/src/chain_spec.rs +++ b/node/src/chain_spec.rs @@ -89,12 +89,12 @@ fn configure_for_relay( relay: Relay, properties: &mut sc_chain_spec::Properties, ) -> (Extensions, u32) { - properties.insert("ss58Format".into(), 42.into()); let para_id; match relay { Relay::Paseo | Relay::PaseoLocal => { para_id = 4001; + properties.insert("ss58Format".into(), 42.into()); properties.insert("tokenSymbol".into(), "PAS".into()); properties.insert("tokenDecimals".into(), 10.into()); @@ -104,6 +104,7 @@ fn configure_for_relay( }, Relay::Polkadot => { para_id = 3395; + properties.insert("ss58Format".into(), 0.into()); properties.insert("tokenSymbol".into(), "DOT".into()); properties.insert("tokenDecimals".into(), 10.into()); (Extensions { relay_chain: "polkadot".into(), para_id }, para_id) diff --git a/runtime/mainnet/src/lib.rs b/runtime/mainnet/src/lib.rs index f36bf203..2d107331 100644 --- a/runtime/mainnet/src/lib.rs +++ b/runtime/mainnet/src/lib.rs @@ -216,7 +216,7 @@ parameter_types! { }) .avg_block_initialization(AVERAGE_ON_INITIALIZE_RATIO) .build_or_panic(); - pub const SS58Prefix: u16 = 42; + pub const SS58Prefix: u16 = 0; } /// A type to identify filtered calls. From 022a33a724edd77bb1f70e9916506faf4d0184fe Mon Sep 17 00:00:00 2001 From: Peter White Date: Wed, 28 Aug 2024 16:50:11 -0600 Subject: [PATCH 10/11] set sudo address in chain spec --- node/src/chain_spec.rs | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/node/src/chain_spec.rs b/node/src/chain_spec.rs index 4287025a..f39cba79 100644 --- a/node/src/chain_spec.rs +++ b/node/src/chain_spec.rs @@ -206,8 +206,15 @@ pub fn mainnet_config(relay: Relay) -> MainnetChainSpec { AccountId::from_ss58check("5GMqrQuWpyyBBK7LAWXR5psWvKc1QMqtiyasjp23VNKZWgh6").unwrap(); let collator_2_aura_id: AuraId = AuraId::from_ss58check("5GMqrQuWpyyBBK7LAWXR5psWvKc1QMqtiyasjp23VNKZWgh6").unwrap(); + + // Multisig account for sudo, generated from the following signatories: + // - 15VPagCVayS6XvT5RogPYop3BJTJzwqR2mCGR1kVn3w58ygg + // - 142zako1kfvrpQ7pJKYR8iGUD58i4wjb78FUsmJ9WcXmkM5z + // - 15k9niqckMg338cFBoz9vWFGwnCtwPBquKvqJEfHApijZkDz + // - 14G3CUFnZUBnHZUhahexSZ6AgemaW9zMHBnGccy3df7actf4 + // - Threshold 2 let sudo_account_id: AccountId = - AccountId::from_ss58check("5FPL3ZLqUk6MyBoZrQZ1Co29WAteX6T6N68TZ6jitHvhpyuD").unwrap(); + AccountId::from_ss58check("15NMV2JX1NeMwarQiiZvuJ8ixUcvayFDcu1F9Wz1HNpSc8gP").unwrap(); #[allow(deprecated)] MainnetChainSpec::builder( From 10ffc07dcfcec11af66a25e11614f0fec2fd7029 Mon Sep 17 00:00:00 2001 From: Peter White Date: Wed, 28 Aug 2024 17:25:40 -0600 Subject: [PATCH 11/11] set single mainnet collator / invulnerable --- node/src/chain_spec.rs | 16 ++-------------- 1 file changed, 2 insertions(+), 14 deletions(-) diff --git a/node/src/chain_spec.rs b/node/src/chain_spec.rs index f39cba79..e3c8da68 100644 --- a/node/src/chain_spec.rs +++ b/node/src/chain_spec.rs @@ -195,17 +195,9 @@ pub fn mainnet_config(relay: Relay) -> MainnetChainSpec { let (extensions, para_id) = configure_for_relay(relay, &mut properties); let collator_0_account_id: AccountId = - AccountId::from_ss58check("5Gn9dVgCNUYtC5JVMBheQQv2x6Lpg5sAMcQVRupG1s3tP2gR").unwrap(); + AccountId::from_ss58check("15B6eUkXgoLA3dWruCRYWeBGNC8SCwuqiMtMTM1Zh2auSg3w").unwrap(); let collator_0_aura_id: AuraId = - AuraId::from_ss58check("5Gn9dVgCNUYtC5JVMBheQQv2x6Lpg5sAMcQVRupG1s3tP2gR").unwrap(); - let collator_1_account_id: AccountId = - AccountId::from_ss58check("5FyVvcSvSXCkBwvBEHkUh1VWGGrwaR3zbYBkU3Rc5DqV75S4").unwrap(); - let collator_1_aura_id: AuraId = - AuraId::from_ss58check("5FyVvcSvSXCkBwvBEHkUh1VWGGrwaR3zbYBkU3Rc5DqV75S4").unwrap(); - let collator_2_account_id: AccountId = - AccountId::from_ss58check("5GMqrQuWpyyBBK7LAWXR5psWvKc1QMqtiyasjp23VNKZWgh6").unwrap(); - let collator_2_aura_id: AuraId = - AuraId::from_ss58check("5GMqrQuWpyyBBK7LAWXR5psWvKc1QMqtiyasjp23VNKZWgh6").unwrap(); + AuraId::from_ss58check("15B6eUkXgoLA3dWruCRYWeBGNC8SCwuqiMtMTM1Zh2auSg3w").unwrap(); // Multisig account for sudo, generated from the following signatories: // - 15VPagCVayS6XvT5RogPYop3BJTJzwqR2mCGR1kVn3w58ygg @@ -229,10 +221,6 @@ pub fn mainnet_config(relay: Relay) -> MainnetChainSpec { vec![ // POP COLLATOR 0 (collator_0_account_id, collator_0_aura_id), - // POP COLLATOR 1 - (collator_1_account_id, collator_1_aura_id), - // POP COLLATOR 2 - (collator_2_account_id, collator_2_aura_id), ], sudo_account_id, para_id.into(),