mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 06:17:56 +00:00
1a7f5be07f
* Move import queue out of `sc-network` Add supplementary asynchronous API for the import queue which means it can be run as an independent task and communicated with through the `ImportQueueService`. This commit removes removes block and justification imports from `sc-network` and provides `ChainSync` with a handle to import queue so it can import blocks and justifications. Polling of the import queue is moved complete out of `sc-network` and `sc_consensus::Link` is implemented for `ChainSyncInterfaceHandled` so the import queue can still influence the syncing process. * Move stuff to SyncingEngine * Move `ChainSync` instanation to `SyncingEngine` Some of the tests have to be rewritten * Move peer hashmap to `SyncingEngine` * Let `SyncingEngine` to implement `ChainSyncInterface` * Introduce `SyncStatusProvider` * Move `sync_peer_(connected|disconnected)` to `SyncingEngine` * Implement `SyncEventStream` Remove `SyncConnected`/`SyncDisconnected` events from `NetworkEvenStream` and provide those events through `ChainSyncInterface` instead. Modify BEEFY/GRANDPA/transactions protocol and `NetworkGossip` to take `SyncEventStream` object which they listen to for incoming sync peer events. * Introduce `ChainSyncInterface` This interface provides a set of miscellaneous functions that other subsystems can use to query, for example, the syncing status. * Move event stream polling to `SyncingEngine` Subscribe to `NetworkStreamEvent` and poll the incoming notifications and substream events from `SyncingEngine`. The code needs refactoring. * Make `SyncingEngine` into an asynchronous runner This commits removes the last hard dependency of syncing from `sc-network` meaning the protocol now lives completely outside of `sc-network`, ignoring the hardcoded peerset entry which will be addressed in the future. Code needs a lot of refactoring. * Fix warnings * Code refactoring * Use `SyncingService` for BEEFY * Use `SyncingService` for GRANDPA * Remove call delegation from `NetworkService` * Remove `ChainSyncService` * Remove `ChainSync` service tests They were written for the sole purpose of verifying that `NetworWorker` continues to function while the calls are being dispatched to `ChainSync`. * Refactor code * Refactor code * Update client/finality-grandpa/src/communication/tests.rs Co-authored-by: Anton <anton.kalyaev@gmail.com> * Fix warnings * Apply review comments * Fix docs * Fix test * cargo-fmt * Update client/network/sync/src/engine.rs Co-authored-by: Anton <anton.kalyaev@gmail.com> * Update client/network/sync/src/engine.rs Co-authored-by: Anton <anton.kalyaev@gmail.com> * Add missing docs * Refactor code --------- Co-authored-by: Anton <anton.kalyaev@gmail.com>
51 lines
2.6 KiB
TOML
51 lines
2.6 KiB
TOML
[package]
|
|
name = "sc-consensus-beefy"
|
|
version = "4.0.0-dev"
|
|
authors = ["Parity Technologies <admin@parity.io>"]
|
|
edition = "2021"
|
|
license = "GPL-3.0-or-later WITH Classpath-exception-2.0"
|
|
repository = "https://github.com/paritytech/substrate"
|
|
description = "BEEFY Client gadget for substrate"
|
|
homepage = "https://substrate.io"
|
|
|
|
[dependencies]
|
|
array-bytes = "4.1"
|
|
async-trait = "0.1.57"
|
|
codec = { package = "parity-scale-codec", version = "3.2.2", features = ["derive"] }
|
|
fnv = "1.0.6"
|
|
futures = "0.3"
|
|
log = "0.4"
|
|
parking_lot = "0.12.1"
|
|
thiserror = "1.0"
|
|
wasm-timer = "0.2.5"
|
|
prometheus = { package = "substrate-prometheus-endpoint", version = "0.10.0-dev", path = "../../../utils/prometheus" }
|
|
sc-client-api = { version = "4.0.0-dev", path = "../../api" }
|
|
sc-consensus = { version = "0.10.0-dev", path = "../../consensus/common" }
|
|
sc-keystore = { version = "4.0.0-dev", path = "../../keystore" }
|
|
sc-network = { version = "0.10.0-dev", path = "../../network" }
|
|
sc-network-common = { version = "0.10.0-dev", path = "../../network/common" }
|
|
sc-network-gossip = { version = "0.10.0-dev", path = "../../network-gossip" }
|
|
sc-network-sync = { version = "0.10.0-dev", path = "../../network/sync" }
|
|
sc-utils = { version = "4.0.0-dev", path = "../../utils" }
|
|
sp-api = { version = "4.0.0-dev", path = "../../../primitives/api" }
|
|
sp-application-crypto = { version = "7.0.0", path = "../../../primitives/application-crypto" }
|
|
sp-arithmetic = { version = "6.0.0", path = "../../../primitives/arithmetic" }
|
|
sp-blockchain = { version = "4.0.0-dev", path = "../../../primitives/blockchain" }
|
|
sp-consensus = { version = "0.10.0-dev", path = "../../../primitives/consensus/common" }
|
|
sp-consensus-beefy = { version = "4.0.0-dev", path = "../../../primitives/consensus/beefy" }
|
|
sp-core = { version = "7.0.0", path = "../../../primitives/core" }
|
|
sp-keystore = { version = "0.13.0", path = "../../../primitives/keystore" }
|
|
sp-mmr-primitives = { version = "4.0.0-dev", path = "../../../primitives/merkle-mountain-range" }
|
|
sp-runtime = { version = "7.0.0", path = "../../../primitives/runtime" }
|
|
|
|
[dev-dependencies]
|
|
serde = "1.0.136"
|
|
tempfile = "3.1.0"
|
|
tokio = "1.22.0"
|
|
sc-block-builder = { version = "0.10.0-dev", path = "../../block-builder" }
|
|
sc-network-test = { version = "0.8.0", path = "../../network/test" }
|
|
sp-consensus-grandpa = { version = "4.0.0-dev", path = "../../../primitives/consensus/grandpa" }
|
|
sp-keyring = { version = "7.0.0", path = "../../../primitives/keyring" }
|
|
sp-tracing = { version = "6.0.0", path = "../../../primitives/tracing" }
|
|
substrate-test-runtime-client = { version = "2.0.0", path = "../../../test-utils/runtime/client" }
|