mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 22:47:56 +00:00
febf29390a
* DigestItem::ChangesTrieSignal * introduce changes_trie::State * introduce config activation block * ChangesTrieSignal::as_new_configuration * moved well_known_cache_keys to client * extracted DbChangesTrieStorage to separate file * change meaning of none in blockchain cache * changes trie config (FULL) cache draft * eliminating const ChangesTrieConfiguration * delay pruning * continue elimination * do not prune CT config from cache * removed redundant code * fix some TODOs * introduce ConfigurationRange * use Configuration range in build * build skewed digest * remove debug print * extracted surface iterator * key_changes works with skewed digests * fix client build * add test for NeverPrune * fix TODO * fixed some TODOs * more tests * fixing TODOs * fixed compilation * update runtime version * git rid of large tuple * too long lines * config_activation_block -> zero * obsolete TODO * removed unjustified expect * update TODOs with issue number * new CT pruning algorithm fixed cache + multiple blocks finalization track CT configuraiton on light clients support CT configuration change revert revert CT config test new CT pruning algorithm fixed cache + multiple blocks finalization track CT configuraiton on light clients support CT configuration change revert revert CT config test * BlockIdOrHeader isn't really required * removed debug leftovers + some docs * more docs * more post-merge fixes * more post-merge fixes * revertes some unnecessary changes * reverted unnecessary changes * fix compilation + unnecessary changes * (restart CI) * fix cache update when finalizing multiple blocks * fixed tests * collect_extrinsics -> set_collect_extrinsics * restore lost test * do not calculate block number twice * Update primitives/blockchain/src/error.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * map_err -> unwrap_or * document get_at Result * delete abandoned file * added weight for set_changes_trie_config * prefer_configs -> fail_if_disabled * Update client/api/src/backend.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * Update client/db/src/changes_tries_storage.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * CommitOperation+merge -> CommitOperations * fixed test compilation * merged two different CTRange structs * lost file * uggrade db from v0 to v1 (init CT cache + add column) * fix after merge Co-authored-by: cheme <emericchevalier.pro@gmail.com> Co-authored-by: Gavin Wood <github@gavwood.com>
110 lines
4.0 KiB
Rust
110 lines
4.0 KiB
Rust
// Copyright 2017-2020 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate 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.
|
|
|
|
// Substrate 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 Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Tool for creating the genesis block.
|
|
|
|
use std::collections::BTreeMap;
|
|
use sp_io::hashing::{blake2_256, twox_128};
|
|
use super::{AuthorityId, AccountId, WASM_BINARY, system};
|
|
use codec::{Encode, KeyedVec, Joiner};
|
|
use sp_core::{ChangesTrieConfiguration, map};
|
|
use sp_core::storage::{well_known_keys, Storage};
|
|
use sp_runtime::traits::{Block as BlockT, Hash as HashT, Header as HeaderT};
|
|
|
|
/// Configuration of a general Substrate test genesis block.
|
|
pub struct GenesisConfig {
|
|
changes_trie_config: Option<ChangesTrieConfiguration>,
|
|
authorities: Vec<AuthorityId>,
|
|
balances: Vec<(AccountId, u64)>,
|
|
heap_pages_override: Option<u64>,
|
|
/// Additional storage key pairs that will be added to the genesis map.
|
|
extra_storage: Storage,
|
|
}
|
|
|
|
impl GenesisConfig {
|
|
pub fn new(
|
|
changes_trie_config: Option<ChangesTrieConfiguration>,
|
|
authorities: Vec<AuthorityId>,
|
|
endowed_accounts: Vec<AccountId>,
|
|
balance: u64,
|
|
heap_pages_override: Option<u64>,
|
|
extra_storage: Storage,
|
|
) -> Self {
|
|
GenesisConfig {
|
|
changes_trie_config,
|
|
authorities: authorities.clone(),
|
|
balances: endowed_accounts.into_iter().map(|a| (a, balance)).collect(),
|
|
heap_pages_override,
|
|
extra_storage,
|
|
}
|
|
}
|
|
|
|
pub fn genesis_map(&self) -> Storage {
|
|
let wasm_runtime = WASM_BINARY.to_vec();
|
|
let mut map: BTreeMap<Vec<u8>, Vec<u8>> = self.balances.iter()
|
|
.map(|&(ref account, balance)| (account.to_keyed_vec(b"balance:"), vec![].and(&balance)))
|
|
.map(|(k, v)| (blake2_256(&k[..])[..].to_vec(), v.to_vec()))
|
|
.chain(vec![
|
|
(well_known_keys::CODE.into(), wasm_runtime),
|
|
(
|
|
well_known_keys::HEAP_PAGES.into(),
|
|
vec![].and(&(self.heap_pages_override.unwrap_or(16 as u64))),
|
|
),
|
|
].into_iter())
|
|
.collect();
|
|
if let Some(ref changes_trie_config) = self.changes_trie_config {
|
|
map.insert(well_known_keys::CHANGES_TRIE_CONFIG.to_vec(), changes_trie_config.encode());
|
|
}
|
|
map.insert(twox_128(&b"sys:auth"[..])[..].to_vec(), self.authorities.encode());
|
|
// Add the extra storage entries.
|
|
map.extend(self.extra_storage.top.clone().into_iter());
|
|
|
|
// Assimilate the system genesis config.
|
|
let mut storage = Storage { top: map, children: self.extra_storage.children.clone()};
|
|
let mut config = system::GenesisConfig::default();
|
|
config.authorities = self.authorities.clone();
|
|
config.assimilate_storage(&mut storage).expect("Adding `system::GensisConfig` to the genesis");
|
|
|
|
storage
|
|
}
|
|
}
|
|
|
|
pub fn insert_genesis_block(
|
|
storage: &mut Storage,
|
|
) -> sp_core::hash::H256 {
|
|
let child_roots = storage.children.iter().map(|(sk, child_content)| {
|
|
let state_root = <<<crate::Block as BlockT>::Header as HeaderT>::Hashing as HashT>::trie_root(
|
|
child_content.data.clone().into_iter().collect(),
|
|
);
|
|
(sk.clone(), state_root.encode())
|
|
});
|
|
// add child roots to storage
|
|
storage.top.extend(child_roots);
|
|
let state_root = <<<crate::Block as BlockT>::Header as HeaderT>::Hashing as HashT>::trie_root(
|
|
storage.top.clone().into_iter().collect()
|
|
);
|
|
let block: crate::Block = sc_client::genesis::construct_genesis_block(state_root);
|
|
let genesis_hash = block.header.hash();
|
|
storage.top.extend(additional_storage_with_genesis(&block));
|
|
genesis_hash
|
|
}
|
|
|
|
pub fn additional_storage_with_genesis(genesis_block: &crate::Block) -> BTreeMap<Vec<u8>, Vec<u8>> {
|
|
map![
|
|
twox_128(&b"latest"[..]).to_vec() => genesis_block.hash().as_fixed_bytes().to_vec()
|
|
]
|
|
}
|