mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-07 08:28:05 +00:00
fe08221479
* Introduce `wasm-builder` and `wasm-builder-runner` to retire `build.sh` Make use of `wasm-builder` in `test-runtime`. * Add build script and remove the wasm project * Port `node-runtime` to new wasm-builder * Make `substrate-executor` tests work with `wasm-builder` * Move `node-template` to `wasm-builder` * Remove `build.sh` :) * Remove the last include_bytes * Adds the missing build.rs files * Remove `build.sh` from CI * Debug CI * Make it work in CI * CI attempt 3 * Make `substrate-runtime-test` compile on stable * Ahhh, some missed `include_bytes!` * AHH * Add suggestions * Improve search for `Cargo.lock` and don't panic if it is not found * Searching from manifest path was no good idea * Make the `wasm-builder` source better configurable * Expose the bloaty wasm binary as well * Make sure to rerun WASM recompilation on changes in dependencies * Introduce new `WASM_BUILD_TYPE` env and make sure to call `build.rs` on changes to env variables * Remove `build.sh` from READMEs * Rename the projects * Fixes CI * Update lock file * Fixes merge-conflict * Apply suggestions from code review Co-Authored-By: TriplEight <denis.pisarev@parity.io> * Try to make windows happy * Replace all back slashes in paths with slashes * Apply suggestions from code review Co-Authored-By: Pierre Krieger <pierre.krieger1708@gmail.com> * Use cargo from `CARGO` env variable * Fix compilation * Use `rustup` for running the nightly build * Make individual projects skipable * Fix compilation * Fixes compilation * Build all WASM projects in one workspace * Replace more back slashes! * Remove `inlcude_bytes!` * Adds some documentation * Apply suggestions from code review Co-Authored-By: Shawn Tabrizi <shawntabrizi@gmail.com> * Apply suggestions from code review Co-Authored-By: Shawn Tabrizi <shawntabrizi@gmail.com> * More review comments * Update `Cargo.lock` * Set license * Apply suggestions from code review Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * More review comments + adds `TRIGGER_WASM_BUILD` env * Fix doc tests * Increase version + update README * Switch crates.io version of `wasm-builder` * Update README * Switch to released version of `wasm-builder-runner`
115 lines
2.9 KiB
Rust
115 lines
2.9 KiB
Rust
use primitives::{ed25519, sr25519, Pair};
|
|
use node_template_runtime::{
|
|
AccountId, GenesisConfig, AuraConfig, TimestampConfig, BalancesConfig,
|
|
SudoConfig, IndicesConfig, SystemConfig, WASM_BINARY, AuraId
|
|
};
|
|
use substrate_service;
|
|
|
|
// Note this is the URL for the telemetry server
|
|
//const STAGING_TELEMETRY_URL: &str = "wss://telemetry.polkadot.io/submit/";
|
|
|
|
/// Specialized `ChainSpec`. This is a specialization of the general Substrate ChainSpec type.
|
|
pub type ChainSpec = substrate_service::ChainSpec<GenesisConfig>;
|
|
|
|
/// The chain specification option. This is expected to come in from the CLI and
|
|
/// is little more than one of a number of alternatives which can easily be converted
|
|
/// from a string (`--chain=...`) into a `ChainSpec`.
|
|
#[derive(Clone, Debug)]
|
|
pub enum Alternative {
|
|
/// Whatever the current runtime is, with just Alice as an auth.
|
|
Development,
|
|
/// Whatever the current runtime is, with simple Alice/Bob auths.
|
|
LocalTestnet,
|
|
}
|
|
|
|
fn authority_key(s: &str) -> AuraId {
|
|
ed25519::Pair::from_string(&format!("//{}", s), None)
|
|
.expect("static values are valid; qed")
|
|
.public()
|
|
}
|
|
|
|
fn account_key(s: &str) -> AccountId {
|
|
sr25519::Pair::from_string(&format!("//{}", s), None)
|
|
.expect("static values are valid; qed")
|
|
.public()
|
|
}
|
|
|
|
impl Alternative {
|
|
/// Get an actual chain config from one of the alternatives.
|
|
pub(crate) fn load(self) -> Result<ChainSpec, String> {
|
|
Ok(match self {
|
|
Alternative::Development => ChainSpec::from_genesis(
|
|
"Development",
|
|
"dev",
|
|
|| testnet_genesis(vec![
|
|
authority_key("Alice")
|
|
], vec![
|
|
account_key("Alice")
|
|
],
|
|
account_key("Alice")
|
|
),
|
|
vec![],
|
|
None,
|
|
None,
|
|
None,
|
|
None
|
|
),
|
|
Alternative::LocalTestnet => ChainSpec::from_genesis(
|
|
"Local Testnet",
|
|
"local_testnet",
|
|
|| testnet_genesis(vec![
|
|
authority_key("Alice"),
|
|
authority_key("Bob"),
|
|
], vec![
|
|
account_key("Alice"),
|
|
account_key("Bob"),
|
|
account_key("Charlie"),
|
|
account_key("Dave"),
|
|
account_key("Eve"),
|
|
account_key("Ferdie"),
|
|
],
|
|
account_key("Alice"),
|
|
),
|
|
vec![],
|
|
None,
|
|
None,
|
|
None,
|
|
None
|
|
),
|
|
})
|
|
}
|
|
|
|
pub(crate) fn from(s: &str) -> Option<Self> {
|
|
match s {
|
|
"dev" => Some(Alternative::Development),
|
|
"" | "local" => Some(Alternative::LocalTestnet),
|
|
_ => None,
|
|
}
|
|
}
|
|
}
|
|
|
|
fn testnet_genesis(initial_authorities: Vec<AuraId>, endowed_accounts: Vec<AccountId>, root_key: AccountId) -> GenesisConfig {
|
|
GenesisConfig {
|
|
system: Some(SystemConfig {
|
|
code: WASM_BINARY.to_vec(),
|
|
changes_trie_config: Default::default(),
|
|
}),
|
|
aura: Some(AuraConfig {
|
|
authorities: initial_authorities.clone(),
|
|
}),
|
|
timestamp: Some(TimestampConfig {
|
|
minimum_period: 5, // 10 second block time.
|
|
}),
|
|
indices: Some(IndicesConfig {
|
|
ids: endowed_accounts.clone(),
|
|
}),
|
|
balances: Some(BalancesConfig {
|
|
balances: endowed_accounts.iter().cloned().map(|k|(k, 1 << 60)).collect(),
|
|
vesting: vec![],
|
|
}),
|
|
sudo: Some(SudoConfig {
|
|
key: root_key,
|
|
}),
|
|
}
|
|
}
|