mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 21:01:02 +00:00
4450b61571
The `parachains-common` contains a lots of constants and type definitions which are used for `polkadot-sdk`'s testnet runtimes and also for `polkadot-fellows`'s production [SP runtimes](https://github.com/polkadot-fellows/runtimes/tree/main/system-parachains/constants). This PR cleans `parachains-common` module to contain only common and generic functionality. Testnet-specific constants have been moved to the separate module dedicated just for testnets: `polkadot-sdk/cumulus/parachains/runtimes/constants/` Part of: https://github.com/paritytech/polkadot-sdk/issues/3054 --------- Co-authored-by: georgepisaltu <george.pisaltu@parity.io>
362 lines
12 KiB
Rust
362 lines
12 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// This file is part of Cumulus.
|
|
|
|
// Cumulus is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Cumulus is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Cumulus. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use crate::chain_spec::{get_account_id_from_seed, get_collator_keys_from_seed, GenericChainSpec};
|
|
use cumulus_primitives_core::ParaId;
|
|
use parachains_common::Balance as BridgeHubBalance;
|
|
use sc_chain_spec::ChainSpec;
|
|
use sp_core::sr25519;
|
|
use std::str::FromStr;
|
|
|
|
/// Collects all supported BridgeHub configurations
|
|
#[derive(Debug, PartialEq)]
|
|
pub enum BridgeHubRuntimeType {
|
|
Kusama,
|
|
Polkadot,
|
|
|
|
Rococo,
|
|
RococoLocal,
|
|
// used by benchmarks
|
|
RococoDevelopment,
|
|
|
|
Westend,
|
|
WestendLocal,
|
|
// used by benchmarks
|
|
WestendDevelopment,
|
|
}
|
|
|
|
impl FromStr for BridgeHubRuntimeType {
|
|
type Err = String;
|
|
|
|
fn from_str(value: &str) -> Result<Self, Self::Err> {
|
|
match value {
|
|
polkadot::BRIDGE_HUB_POLKADOT => Ok(BridgeHubRuntimeType::Polkadot),
|
|
kusama::BRIDGE_HUB_KUSAMA => Ok(BridgeHubRuntimeType::Kusama),
|
|
westend::BRIDGE_HUB_WESTEND => Ok(BridgeHubRuntimeType::Westend),
|
|
westend::BRIDGE_HUB_WESTEND_LOCAL => Ok(BridgeHubRuntimeType::WestendLocal),
|
|
westend::BRIDGE_HUB_WESTEND_DEVELOPMENT => Ok(BridgeHubRuntimeType::WestendDevelopment),
|
|
rococo::BRIDGE_HUB_ROCOCO => Ok(BridgeHubRuntimeType::Rococo),
|
|
rococo::BRIDGE_HUB_ROCOCO_LOCAL => Ok(BridgeHubRuntimeType::RococoLocal),
|
|
rococo::BRIDGE_HUB_ROCOCO_DEVELOPMENT => Ok(BridgeHubRuntimeType::RococoDevelopment),
|
|
_ => Err(format!("Value '{}' is not configured yet", value)),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl BridgeHubRuntimeType {
|
|
pub const ID_PREFIX: &'static str = "bridge-hub";
|
|
|
|
pub fn load_config(&self) -> Result<Box<dyn ChainSpec>, String> {
|
|
match self {
|
|
BridgeHubRuntimeType::Polkadot => Ok(Box::new(GenericChainSpec::from_json_bytes(
|
|
&include_bytes!("../../chain-specs/bridge-hub-polkadot.json")[..],
|
|
)?)),
|
|
BridgeHubRuntimeType::Kusama => Ok(Box::new(GenericChainSpec::from_json_bytes(
|
|
&include_bytes!("../../chain-specs/bridge-hub-kusama.json")[..],
|
|
)?)),
|
|
BridgeHubRuntimeType::Westend => Ok(Box::new(GenericChainSpec::from_json_bytes(
|
|
&include_bytes!("../../chain-specs/bridge-hub-westend.json")[..],
|
|
)?)),
|
|
BridgeHubRuntimeType::WestendLocal => Ok(Box::new(westend::local_config(
|
|
westend::BRIDGE_HUB_WESTEND_LOCAL,
|
|
"Westend BridgeHub Local",
|
|
"westend-local",
|
|
ParaId::new(1002),
|
|
Some("Bob".to_string()),
|
|
))),
|
|
BridgeHubRuntimeType::WestendDevelopment => Ok(Box::new(westend::local_config(
|
|
westend::BRIDGE_HUB_WESTEND_DEVELOPMENT,
|
|
"Westend BridgeHub Development",
|
|
"westend-dev",
|
|
ParaId::new(1002),
|
|
Some("Bob".to_string()),
|
|
))),
|
|
BridgeHubRuntimeType::Rococo => Ok(Box::new(GenericChainSpec::from_json_bytes(
|
|
&include_bytes!("../../chain-specs/bridge-hub-rococo.json")[..],
|
|
)?)),
|
|
BridgeHubRuntimeType::RococoLocal => Ok(Box::new(rococo::local_config(
|
|
rococo::BRIDGE_HUB_ROCOCO_LOCAL,
|
|
"Rococo BridgeHub Local",
|
|
"rococo-local",
|
|
ParaId::new(1013),
|
|
Some("Bob".to_string()),
|
|
|_| (),
|
|
))),
|
|
BridgeHubRuntimeType::RococoDevelopment => Ok(Box::new(rococo::local_config(
|
|
rococo::BRIDGE_HUB_ROCOCO_DEVELOPMENT,
|
|
"Rococo BridgeHub Development",
|
|
"rococo-dev",
|
|
ParaId::new(1013),
|
|
Some("Bob".to_string()),
|
|
|_| (),
|
|
))),
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Check if 'id' satisfy BridgeHub-like format
|
|
fn ensure_id(id: &str) -> Result<&str, String> {
|
|
if id.starts_with(BridgeHubRuntimeType::ID_PREFIX) {
|
|
Ok(id)
|
|
} else {
|
|
Err(format!(
|
|
"Invalid 'id' attribute ({}), should start with prefix: {}",
|
|
id,
|
|
BridgeHubRuntimeType::ID_PREFIX
|
|
))
|
|
}
|
|
}
|
|
|
|
/// Sub-module for Rococo setup
|
|
pub mod rococo {
|
|
use super::{get_account_id_from_seed, get_collator_keys_from_seed, sr25519, ParaId};
|
|
use crate::chain_spec::{Extensions, GenericChainSpec, SAFE_XCM_VERSION};
|
|
use parachains_common::{AccountId, AuraId};
|
|
use sc_chain_spec::ChainType;
|
|
|
|
use super::BridgeHubBalance;
|
|
|
|
pub(crate) const BRIDGE_HUB_ROCOCO: &str = "bridge-hub-rococo";
|
|
pub(crate) const BRIDGE_HUB_ROCOCO_LOCAL: &str = "bridge-hub-rococo-local";
|
|
pub(crate) const BRIDGE_HUB_ROCOCO_DEVELOPMENT: &str = "bridge-hub-rococo-dev";
|
|
const BRIDGE_HUB_ROCOCO_ED: BridgeHubBalance =
|
|
bridge_hub_rococo_runtime::ExistentialDeposit::get();
|
|
|
|
pub fn local_config<ModifyProperties: Fn(&mut sc_chain_spec::Properties)>(
|
|
id: &str,
|
|
chain_name: &str,
|
|
relay_chain: &str,
|
|
para_id: ParaId,
|
|
bridges_pallet_owner_seed: Option<String>,
|
|
modify_props: ModifyProperties,
|
|
) -> GenericChainSpec {
|
|
// Rococo defaults
|
|
let mut properties = sc_chain_spec::Properties::new();
|
|
properties.insert("ss58Format".into(), 42.into());
|
|
properties.insert("tokenSymbol".into(), "ROC".into());
|
|
properties.insert("tokenDecimals".into(), 12.into());
|
|
modify_props(&mut properties);
|
|
|
|
GenericChainSpec::builder(
|
|
bridge_hub_rococo_runtime::WASM_BINARY
|
|
.expect("WASM binary was not built, please build it!"),
|
|
Extensions { relay_chain: relay_chain.to_string(), para_id: para_id.into() },
|
|
)
|
|
.with_name(chain_name)
|
|
.with_id(super::ensure_id(id).expect("invalid id"))
|
|
.with_chain_type(ChainType::Local)
|
|
.with_genesis_config_patch(genesis(
|
|
// initial collators.
|
|
vec![
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_collator_keys_from_seed::<AuraId>("Alice"),
|
|
),
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_collator_keys_from_seed::<AuraId>("Bob"),
|
|
),
|
|
],
|
|
vec![
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_account_id_from_seed::<sr25519::Public>("Charlie"),
|
|
get_account_id_from_seed::<sr25519::Public>("Dave"),
|
|
get_account_id_from_seed::<sr25519::Public>("Eve"),
|
|
get_account_id_from_seed::<sr25519::Public>("Ferdie"),
|
|
get_account_id_from_seed::<sr25519::Public>("Alice//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Bob//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Charlie//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Dave//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Eve//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Ferdie//stash"),
|
|
],
|
|
para_id,
|
|
bridges_pallet_owner_seed
|
|
.as_ref()
|
|
.map(|seed| get_account_id_from_seed::<sr25519::Public>(seed)),
|
|
))
|
|
.with_properties(properties)
|
|
.build()
|
|
}
|
|
|
|
fn genesis(
|
|
invulnerables: Vec<(AccountId, AuraId)>,
|
|
endowed_accounts: Vec<AccountId>,
|
|
id: ParaId,
|
|
bridges_pallet_owner: Option<AccountId>,
|
|
) -> serde_json::Value {
|
|
serde_json::json!({
|
|
"balances": {
|
|
"balances": endowed_accounts.iter().cloned().map(|k| (k, 1u64 << 60)).collect::<Vec<_>>(),
|
|
},
|
|
"parachainInfo": {
|
|
"parachainId": id,
|
|
},
|
|
"collatorSelection": {
|
|
"invulnerables": invulnerables.iter().cloned().map(|(acc, _)| acc).collect::<Vec<_>>(),
|
|
"candidacyBond": BRIDGE_HUB_ROCOCO_ED * 16,
|
|
},
|
|
"session": {
|
|
"keys": invulnerables
|
|
.into_iter()
|
|
.map(|(acc, aura)| {
|
|
(
|
|
acc.clone(), // account id
|
|
acc, // validator id
|
|
bridge_hub_rococo_runtime::SessionKeys { aura }, // session keys
|
|
)
|
|
})
|
|
.collect::<Vec<_>>(),
|
|
},
|
|
"polkadotXcm": {
|
|
"safeXcmVersion": Some(SAFE_XCM_VERSION),
|
|
},
|
|
"bridgeWestendGrandpa": {
|
|
"owner": bridges_pallet_owner.clone(),
|
|
},
|
|
"bridgeWestendMessages": {
|
|
"owner": bridges_pallet_owner.clone(),
|
|
},
|
|
"ethereumSystem": {
|
|
"paraId": id,
|
|
"assetHubParaId": 1000
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
/// Sub-module for Kusama setup
|
|
pub mod kusama {
|
|
pub(crate) const BRIDGE_HUB_KUSAMA: &str = "bridge-hub-kusama";
|
|
}
|
|
|
|
/// Sub-module for Westend setup.
|
|
pub mod westend {
|
|
use super::{get_account_id_from_seed, get_collator_keys_from_seed, sr25519, ParaId};
|
|
use crate::chain_spec::{Extensions, GenericChainSpec, SAFE_XCM_VERSION};
|
|
use parachains_common::{AccountId, AuraId};
|
|
use sc_chain_spec::ChainType;
|
|
|
|
use super::BridgeHubBalance;
|
|
|
|
pub(crate) const BRIDGE_HUB_WESTEND: &str = "bridge-hub-westend";
|
|
pub(crate) const BRIDGE_HUB_WESTEND_LOCAL: &str = "bridge-hub-westend-local";
|
|
pub(crate) const BRIDGE_HUB_WESTEND_DEVELOPMENT: &str = "bridge-hub-westend-dev";
|
|
const BRIDGE_HUB_WESTEND_ED: BridgeHubBalance =
|
|
bridge_hub_westend_runtime::ExistentialDeposit::get();
|
|
|
|
pub fn local_config(
|
|
id: &str,
|
|
chain_name: &str,
|
|
relay_chain: &str,
|
|
para_id: ParaId,
|
|
bridges_pallet_owner_seed: Option<String>,
|
|
) -> GenericChainSpec {
|
|
let mut properties = sc_chain_spec::Properties::new();
|
|
properties.insert("tokenSymbol".into(), "WND".into());
|
|
properties.insert("tokenDecimals".into(), 12.into());
|
|
|
|
GenericChainSpec::builder(
|
|
bridge_hub_westend_runtime::WASM_BINARY
|
|
.expect("WASM binary was not build, please build it!"),
|
|
Extensions { relay_chain: relay_chain.to_string(), para_id: para_id.into() },
|
|
)
|
|
.with_name(chain_name)
|
|
.with_id(super::ensure_id(id).expect("invalid id"))
|
|
.with_chain_type(ChainType::Local)
|
|
.with_genesis_config_patch(genesis(
|
|
// initial collators.
|
|
vec![
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_collator_keys_from_seed::<AuraId>("Alice"),
|
|
),
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_collator_keys_from_seed::<AuraId>("Bob"),
|
|
),
|
|
],
|
|
vec![
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_account_id_from_seed::<sr25519::Public>("Charlie"),
|
|
get_account_id_from_seed::<sr25519::Public>("Dave"),
|
|
get_account_id_from_seed::<sr25519::Public>("Eve"),
|
|
get_account_id_from_seed::<sr25519::Public>("Ferdie"),
|
|
get_account_id_from_seed::<sr25519::Public>("Alice//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Bob//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Charlie//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Dave//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Eve//stash"),
|
|
get_account_id_from_seed::<sr25519::Public>("Ferdie//stash"),
|
|
],
|
|
para_id,
|
|
bridges_pallet_owner_seed
|
|
.as_ref()
|
|
.map(|seed| get_account_id_from_seed::<sr25519::Public>(seed)),
|
|
))
|
|
.with_properties(properties)
|
|
.build()
|
|
}
|
|
|
|
fn genesis(
|
|
invulnerables: Vec<(AccountId, AuraId)>,
|
|
endowed_accounts: Vec<AccountId>,
|
|
id: ParaId,
|
|
bridges_pallet_owner: Option<AccountId>,
|
|
) -> serde_json::Value {
|
|
serde_json::json!({
|
|
"balances": {
|
|
"balances": endowed_accounts.iter().cloned().map(|k| (k, 1u64 << 60)).collect::<Vec<_>>(),
|
|
},
|
|
"parachainInfo": {
|
|
"parachainId": id,
|
|
},
|
|
"collatorSelection": {
|
|
"invulnerables": invulnerables.iter().cloned().map(|(acc, _)| acc).collect::<Vec<_>>(),
|
|
"candidacyBond": BRIDGE_HUB_WESTEND_ED * 16,
|
|
},
|
|
"session": {
|
|
"keys": invulnerables
|
|
.into_iter()
|
|
.map(|(acc, aura)| {
|
|
(
|
|
acc.clone(), // account id
|
|
acc, // validator id
|
|
bridge_hub_westend_runtime::SessionKeys { aura }, // session keys
|
|
)
|
|
})
|
|
.collect::<Vec<_>>(),
|
|
},
|
|
"polkadotXcm": {
|
|
"safeXcmVersion": Some(SAFE_XCM_VERSION),
|
|
},
|
|
"bridgeRococoGrandpa": {
|
|
"owner": bridges_pallet_owner.clone(),
|
|
},
|
|
"bridgeRococoMessages": {
|
|
"owner": bridges_pallet_owner.clone(),
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
/// Sub-module for Polkadot setup
|
|
pub mod polkadot {
|
|
pub(crate) const BRIDGE_HUB_POLKADOT: &str = "bridge-hub-polkadot";
|
|
}
|