mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-08 04:18:01 +00:00
76f9ecae47
* Start with something * Whatever * Update * MOARE * Make cumulus-network compile and tests work * Update more and fixes * More stuff * More fixes * Make collator build * Make test almost work * Remove contracts runtime * More test work * Make service compile * Fix test-service * Fix test client * More fixes * Fix collator test * Fix network tests (again) * Make everything compile, finally * Fix tests * Update to latest masters * Remove ignore * Switch to different branch in polkadot for now * Update reference * Make it compile with latest changes * Update collator/src/lib.rs Co-authored-by: Robert Habermeier <rphmeier@gmail.com> * Update to latest upstream * Update to latest master * Fix test Co-authored-by: Robert Habermeier <rphmeier@gmail.com>
147 lines
4.5 KiB
Rust
147 lines
4.5 KiB
Rust
// Copyright 2019 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 cumulus_primitives::ParaId;
|
|
use hex_literal::hex;
|
|
use rococo_parachain_primitives::{AccountId, Signature};
|
|
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<parachain_runtime::GenesisConfig, Extensions>;
|
|
|
|
/// 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: &Box<dyn sc_service::ChainSpec>) -> Option<&Self> {
|
|
sc_chain_spec::get_extension(chain_spec.extensions())
|
|
}
|
|
}
|
|
|
|
type AccountPublic = <Signature as Verify>::Signer;
|
|
|
|
/// 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()
|
|
}
|
|
|
|
pub fn get_chain_spec(id: ParaId) -> ChainSpec {
|
|
ChainSpec::from_genesis(
|
|
"Local Testnet",
|
|
"local_testnet",
|
|
ChainType::Local,
|
|
move || {
|
|
testnet_genesis(
|
|
get_account_id_from_seed::<sr25519::Public>("Alice"),
|
|
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"),
|
|
],
|
|
id,
|
|
)
|
|
},
|
|
vec![],
|
|
None,
|
|
None,
|
|
None,
|
|
Extensions {
|
|
relay_chain: "westend-dev".into(),
|
|
para_id: id.into(),
|
|
},
|
|
)
|
|
}
|
|
|
|
pub fn staging_test_net(id: ParaId) -> ChainSpec {
|
|
ChainSpec::from_genesis(
|
|
"Staging Testnet",
|
|
"staging_testnet",
|
|
ChainType::Live,
|
|
move || {
|
|
testnet_genesis(
|
|
hex!["9ed7705e3c7da027ba0583a22a3212042f7e715d3c168ba14f1424e2bc111d00"].into(),
|
|
vec![
|
|
hex!["9ed7705e3c7da027ba0583a22a3212042f7e715d3c168ba14f1424e2bc111d00"].into(),
|
|
],
|
|
id,
|
|
)
|
|
},
|
|
Vec::new(),
|
|
None,
|
|
None,
|
|
None,
|
|
Extensions {
|
|
relay_chain: "westend-dev".into(),
|
|
para_id: id.into(),
|
|
},
|
|
)
|
|
}
|
|
|
|
fn testnet_genesis(
|
|
root_key: AccountId,
|
|
endowed_accounts: Vec<AccountId>,
|
|
id: ParaId,
|
|
) -> parachain_runtime::GenesisConfig {
|
|
parachain_runtime::GenesisConfig {
|
|
frame_system: Some(parachain_runtime::SystemConfig {
|
|
code: parachain_runtime::WASM_BINARY
|
|
.expect("WASM binary was not build, please build it!")
|
|
.to_vec(),
|
|
changes_trie_config: Default::default(),
|
|
}),
|
|
pallet_balances: Some(parachain_runtime::BalancesConfig {
|
|
balances: endowed_accounts
|
|
.iter()
|
|
.cloned()
|
|
.map(|k| (k, 1 << 60))
|
|
.collect(),
|
|
}),
|
|
pallet_sudo: Some(parachain_runtime::SudoConfig { key: root_key }),
|
|
parachain_info: Some(parachain_runtime::ParachainInfoConfig { parachain_id: id }),
|
|
}
|
|
}
|