mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-27 17:31:07 +00:00
1a524b8207
* Add Call type to extensible transactions. Cleanup some naming * Merge Resource and BlockExhausted into just Exhausted * Fix * Another fix * Call * Some fixes * Fix srml tests. * Fix all tests. * Refactor crypto so each application of it has its own type. * Introduce new AuthorityProvider API into Aura This will eventually allow for dynamic determination of authority keys and avoid having to set them directly on CLI. * Introduce authority determinator for Babe. Experiment with modular consensus API. * Work in progress to introduce KeyTypeId and avoid polluting API with validator IDs * Finish up drafting imonline * Rework offchain workers API. * Rework API implementation. * Make it compile for wasm, simplify app_crypto. * Fix compilation of im-online. * Fix compilation of im-online. * Fix more compilation errors. * Make it compile. * Fixing tests. * Rewrite `keystore` * Fix session tests * Bring back `TryFrom`'s' * Fix `srml-grandpa` * Fix `srml-aura` * Fix consensus babe * More fixes * Make service generate keys from dev_seed * Build fixes * Remove offchain tests * More fixes and cleanups * Fixes finality grandpa * Fix `consensus-aura` * Fix cli * Fix `node-cli` * Fix chain_spec builder * Fix doc tests * Add authority getter for grandpa. * Test fix * Fixes * Make keystore accessible from the runtime * Move app crypto to its own crate * Update `Cargo.lock` * Make the crypto stuff usable from the runtime * Adds some runtime crypto tests * Use last finalized block for grandpa authority * Fix warning * Adds `SessionKeys` runtime api * Remove `FinalityPair` and `ConsensusPair` * Minor governance tweaks to get it inline with docs. * Make the governance be up to date with the docs. * Build fixes. * Generate the inital session keys * Failing keystore is a hard error * Make babe work again * Fix grandpa * Fix tests * Disable `keystore` in consensus critical stuff * Build fix. * ImOnline supports multiple authorities at once. * Update core/application-crypto/src/ed25519.rs * Merge branch 'master' into gav-in-progress * Remove unneeded code for now. * Some `session` testing * Support querying the public keys * Cleanup offchain * Remove warnings * More cleanup * Apply suggestions from code review Co-Authored-By: Benjamin Kampmann <ben.kampmann@googlemail.com> * More cleanups * JSONRPC API for setting keys. Also, rename traits::KeyStore* -> traits::BareCryptoStore* * Bad merge * Fix integration tests * Fix test build * Test fix * Fixes * Warnings * Another warning * Bump version.
113 lines
2.9 KiB
Rust
113 lines
2.9 KiB
Rust
use primitives::{sr25519, Pair};
|
|
use node_template_runtime::{
|
|
AccountId, GenesisConfig, AuraConfig, BalancesConfig,
|
|
SudoConfig, IndicesConfig, SystemConfig, WASM_BINARY, AuraId
|
|
};
|
|
use aura_primitives::sr25519::AuthorityPair as AuraPair;
|
|
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 {
|
|
AuraPair::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(),
|
|
}),
|
|
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,
|
|
}),
|
|
}
|
|
}
|