mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 18:07:58 +00:00
4c810609d6
The first step towards https://github.com/paritytech/polkadot-sdk/issues/3155 Brings all templates under the following structure ``` templates | parachain | | polkadot-launch | | runtime --> parachain-template-runtime | | pallets --> pallet-parachain-template | | node --> parachain-template-node | minimal | | runtime --> minimal-template-runtime | | pallets --> pallet-minimal-template | | node --> minimal-template-node | solochain | | runtime --> solochain-template-runtime | | pallets --> pallet-template (the naming is not consistent here) | | node --> solochain-template-node ``` The only note-worthy changes in this PR are: - More `Cargo.toml` fields are forwarded to use the one from the workspace. - parachain template now has weights and benchmarks - adds a shell pallet to the minimal template - remove a few unused deps A list of possible follow-ups: - [ ] Unify READMEs, create a parent README for all - [ ] remove references to `docs.substrate.io` in templates - [ ] make all templates use `#[derive_impl]` - [ ] update and unify all licenses - [ ] Remove polkadot launch, use https://github.com/paritytech/polkadot-sdk/blob/35349df993ea2e7c4769914ef5d199e787b23d4c/cumulus/zombienet/examples/small_network.toml instead.
202 lines
6.5 KiB
Rust
202 lines
6.5 KiB
Rust
use cumulus_primitives_core::ParaId;
|
|
use parachain_template_runtime as runtime;
|
|
use runtime::{AccountId, AuraId, Signature, EXISTENTIAL_DEPOSIT};
|
|
use sc_chain_spec::{ChainSpecExtension, ChainSpecGroup};
|
|
use sc_service::ChainType;
|
|
use serde::{Deserialize, Serialize};
|
|
use sp_core::{sr25519, Pair, Public};
|
|
use sp_runtime::traits::{IdentifyAccount, Verify};
|
|
|
|
/// Specialized `ChainSpec` for the normal parachain runtime.
|
|
pub type ChainSpec = sc_service::GenericChainSpec<(), Extensions>;
|
|
|
|
/// The default XCM version to set in genesis config.
|
|
const SAFE_XCM_VERSION: u32 = xcm::prelude::XCM_VERSION;
|
|
|
|
/// Helper function to generate a crypto pair from seed
|
|
pub fn get_from_seed<TPublic: Public>(seed: &str) -> <TPublic::Pair as Pair>::Public {
|
|
TPublic::Pair::from_string(&format!("//{}", seed), None)
|
|
.expect("static values are valid; qed")
|
|
.public()
|
|
}
|
|
|
|
/// The extensions for the [`ChainSpec`].
|
|
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize, ChainSpecGroup, ChainSpecExtension)]
|
|
#[serde(deny_unknown_fields)]
|
|
pub struct Extensions {
|
|
/// The relay chain of the Parachain.
|
|
pub relay_chain: String,
|
|
/// The id of the Parachain.
|
|
pub para_id: u32,
|
|
}
|
|
|
|
impl Extensions {
|
|
/// Try to get the extension from the given `ChainSpec`.
|
|
pub fn try_get(chain_spec: &dyn sc_service::ChainSpec) -> Option<&Self> {
|
|
sc_chain_spec::get_extension(chain_spec.extensions())
|
|
}
|
|
}
|
|
|
|
type AccountPublic = <Signature as Verify>::Signer;
|
|
|
|
/// Generate collator keys from seed.
|
|
///
|
|
/// This function's return type must always match the session keys of the chain in tuple format.
|
|
pub fn get_collator_keys_from_seed(seed: &str) -> AuraId {
|
|
get_from_seed::<AuraId>(seed)
|
|
}
|
|
|
|
/// Helper function to generate an account ID from seed
|
|
pub fn get_account_id_from_seed<TPublic: Public>(seed: &str) -> AccountId
|
|
where
|
|
AccountPublic: From<<TPublic::Pair as Pair>::Public>,
|
|
{
|
|
AccountPublic::from(get_from_seed::<TPublic>(seed)).into_account()
|
|
}
|
|
|
|
/// 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 template_session_keys(keys: AuraId) -> runtime::SessionKeys {
|
|
runtime::SessionKeys { aura: keys }
|
|
}
|
|
|
|
pub fn development_config() -> ChainSpec {
|
|
// Give your base currency a unit name and decimal places
|
|
let mut properties = sc_chain_spec::Properties::new();
|
|
properties.insert("tokenSymbol".into(), "UNIT".into());
|
|
properties.insert("tokenDecimals".into(), 12.into());
|
|
properties.insert("ss58Format".into(), 42.into());
|
|
|
|
ChainSpec::builder(
|
|
runtime::WASM_BINARY.expect("WASM binary was not built, please build it!"),
|
|
Extensions {
|
|
relay_chain: "rococo-local".into(),
|
|
// You MUST set this to the correct network!
|
|
para_id: 1000,
|
|
},
|
|
)
|
|
.with_name("Development")
|
|
.with_id("dev")
|
|
.with_chain_type(ChainType::Development)
|
|
.with_genesis_config_patch(testnet_genesis(
|
|
// initial collators.
|
|
vec![
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_collator_keys_from_seed("Alice"),
|
|
),
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_collator_keys_from_seed("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"),
|
|
],
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
1000.into(),
|
|
))
|
|
.build()
|
|
}
|
|
|
|
pub fn local_testnet_config() -> ChainSpec {
|
|
// Give your base currency a unit name and decimal places
|
|
let mut properties = sc_chain_spec::Properties::new();
|
|
properties.insert("tokenSymbol".into(), "UNIT".into());
|
|
properties.insert("tokenDecimals".into(), 12.into());
|
|
properties.insert("ss58Format".into(), 42.into());
|
|
|
|
#[allow(deprecated)]
|
|
ChainSpec::builder(
|
|
runtime::WASM_BINARY.expect("WASM binary was not built, please build it!"),
|
|
Extensions {
|
|
relay_chain: "rococo-local".into(),
|
|
// You MUST set this to the correct network!
|
|
para_id: 1000,
|
|
},
|
|
)
|
|
.with_name("Local Testnet")
|
|
.with_id("local_testnet")
|
|
.with_chain_type(ChainType::Local)
|
|
.with_genesis_config_patch(testnet_genesis(
|
|
// initial collators.
|
|
vec![
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
get_collator_keys_from_seed("Alice"),
|
|
),
|
|
(
|
|
get_account_id_from_seed::<sr25519::Public>("Bob"),
|
|
get_collator_keys_from_seed("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"),
|
|
],
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
1000.into(),
|
|
))
|
|
.with_protocol_id("template-local")
|
|
.with_properties(properties)
|
|
.build()
|
|
}
|
|
|
|
fn testnet_genesis(
|
|
invulnerables: Vec<(AccountId, AuraId)>,
|
|
endowed_accounts: Vec<AccountId>,
|
|
root: AccountId,
|
|
id: ParaId,
|
|
) -> 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": EXISTENTIAL_DEPOSIT * 16,
|
|
},
|
|
"session": {
|
|
"keys": invulnerables
|
|
.into_iter()
|
|
.map(|(acc, aura)| {
|
|
(
|
|
acc.clone(), // account id
|
|
acc, // validator id
|
|
template_session_keys(aura), // session keys
|
|
)
|
|
})
|
|
.collect::<Vec<_>>(),
|
|
},
|
|
"polkadotXcm": {
|
|
"safeXcmVersion": Some(SAFE_XCM_VERSION),
|
|
},
|
|
"sudo": { "key": Some(root) }
|
|
})
|
|
}
|