// Copyright 2019 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 . use std::collections::HashMap; use futures::channel::mpsc; use primitives::storage::StorageKey; use state_machine::ExecutionStrategy; use sr_primitives::{ traits::{Block as BlockT, NumberFor}, generic::BlockId }; use consensus::BlockOrigin; use crate::blockchain::Info; use crate::notifications::StorageEventStream; use crate::error; /// Type that implements `futures::Stream` of block import events. pub type ImportNotifications = mpsc::UnboundedReceiver>; /// A stream of block finality notifications. pub type FinalityNotifications = mpsc::UnboundedReceiver>; /// Expected hashes of blocks at given heights. /// /// This may be used as chain spec extension to filter out known, unwanted forks. pub type ForkBlocks = Option, ::Hash>>; /// Execution strategies settings. #[derive(Debug, Clone)] pub struct ExecutionStrategies { /// Execution strategy used when syncing. pub syncing: ExecutionStrategy, /// Execution strategy used when importing blocks. pub importing: ExecutionStrategy, /// Execution strategy used when constructing blocks. pub block_construction: ExecutionStrategy, /// Execution strategy used for offchain workers. pub offchain_worker: ExecutionStrategy, /// Execution strategy used in other cases. pub other: ExecutionStrategy, } impl Default for ExecutionStrategies { fn default() -> ExecutionStrategies { ExecutionStrategies { syncing: ExecutionStrategy::NativeElseWasm, importing: ExecutionStrategy::NativeElseWasm, block_construction: ExecutionStrategy::AlwaysWasm, offchain_worker: ExecutionStrategy::NativeWhenPossible, other: ExecutionStrategy::NativeElseWasm, } } } /// Figure out the block type for a given type (for now, just a `Client`). pub trait BlockOf { /// The type of the block. type Type: BlockT; } /// A source of blockchain events. pub trait BlockchainEvents { /// Get block import event stream. Not guaranteed to be fired for every /// imported block. fn import_notification_stream(&self) -> ImportNotifications; /// Get a stream of finality notifications. Not guaranteed to be fired for every /// finalized block. fn finality_notification_stream(&self) -> FinalityNotifications; /// Get storage changes event stream. /// /// Passing `None` as `filter_keys` subscribes to all storage changes. fn storage_changes_notification_stream( &self, filter_keys: Option<&[StorageKey]>, child_filter_keys: Option<&[(StorageKey, Option>)]>, ) -> error::Result>; } /// Fetch block body by ID. pub trait BlockBody { /// Get block body by ID. Returns `None` if the body is not stored. fn block_body(&self, id: &BlockId ) -> error::Result::Extrinsic>>>; } /// Provide a list of potential uncle headers for a given block. pub trait ProvideUncles { /// Gets the uncles of the block with `target_hash` going back `max_generation` ancestors. fn uncles(&self, target_hash: Block::Hash, max_generation: NumberFor) -> error::Result>; } /// Client info #[derive(Debug)] pub struct ClientInfo { /// Best block hash. pub chain: Info, /// State Cache Size currently used by the backend pub used_state_cache_size: Option, } /// Summary of an imported block #[derive(Clone, Debug)] pub struct BlockImportNotification { /// Imported block header hash. pub hash: Block::Hash, /// Imported block origin. pub origin: BlockOrigin, /// Imported block header. pub header: Block::Header, /// Is this the new best block. pub is_new_best: bool, /// List of retracted blocks ordered by block number. pub retracted: Vec, } /// Summary of a finalized block. #[derive(Clone, Debug)] pub struct FinalityNotification { /// Imported block header hash. pub hash: Block::Hash, /// Imported block header. pub header: Block::Header, }