diff --git a/Cargo.lock b/Cargo.lock index a14d5181..6b59e84e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -79,7 +79,6 @@ version = "0.0.3" dependencies = [ "aleph-bft", "aleph-bft-mock", - "aleph-bft-types", "async-trait", "clap 4.4.6", "env_logger", @@ -119,7 +118,6 @@ dependencies = [ "afl", "aleph-bft", "aleph-bft-mock", - "aleph-bft-types", "async-trait", "env_logger", "futures", @@ -169,9 +167,7 @@ dependencies = [ "aleph-bft-crypto", "async-trait", "futures", - "log", "parity-scale-codec", - "tokio", ] [[package]] diff --git a/consensus/src/alerts/service.rs b/consensus/src/alerts/service.rs index a9fdb611..ae319f4a 100644 --- a/consensus/src/alerts/service.rs +++ b/consensus/src/alerts/service.rs @@ -3,10 +3,9 @@ use crate::{ handler::{Handler, RmcResponse}, Alert, AlertMessage, ForkingNotification, NetworkMessage, }, - Data, Hasher, MultiKeychain, Multisigned, NodeIndex, Receiver, Recipient, Sender, + Data, Hasher, MultiKeychain, Multisigned, NodeIndex, Receiver, Recipient, Sender, Terminator, }; use aleph_bft_rmc::{DoublingDelayScheduler, Message as RmcMessage}; -use aleph_bft_types::Terminator; use futures::{FutureExt, StreamExt}; use log::{debug, error, warn}; use std::time::Duration; diff --git a/consensus/src/backup/saver.rs b/consensus/src/backup/saver.rs index bb3d4098..c4657f74 100644 --- a/consensus/src/backup/saver.rs +++ b/consensus/src/backup/saver.rs @@ -1,12 +1,10 @@ use std::io::Write; -use aleph_bft_types::Terminator; +use crate::{units::UncheckedSignedUnit, Data, Hasher, Receiver, Sender, Signature, Terminator}; use codec::Encode; use futures::{FutureExt, StreamExt}; use log::{debug, error}; -use crate::{units::UncheckedSignedUnit, Data, Hasher, Receiver, Sender, Signature}; - const LOG_TARGET: &str = "AlephBFT-backup-saver"; /// Component responsible for saving units into backup. @@ -81,12 +79,11 @@ mod tests { }; use aleph_bft_mock::{Data, Hasher64, Keychain, Saver, Signature}; - use aleph_bft_types::Terminator; use crate::{ backup::BackupSaver, units::{creator_set, preunit_to_unchecked_signed_unit, UncheckedSignedUnit}, - NodeCount, NodeIndex, + NodeCount, NodeIndex, Terminator, }; type TestBackupSaver = BackupSaver; diff --git a/consensus/src/consensus.rs b/consensus/src/consensus.rs index 19e8d013..276f302e 100644 --- a/consensus/src/consensus.rs +++ b/consensus/src/consensus.rs @@ -1,4 +1,3 @@ -use aleph_bft_types::{handle_task_termination, Terminator}; use futures::{ channel::{mpsc, oneshot}, future::pending, @@ -10,9 +9,10 @@ use crate::{ config::Config, creation, extender::Extender, + handle_task_termination, runway::{NotificationIn, NotificationOut}, terminal::Terminal, - Hasher, Receiver, Round, Sender, SpawnHandle, + Hasher, Receiver, Round, Sender, SpawnHandle, Terminator, }; pub(crate) async fn run( diff --git a/consensus/src/creation/mod.rs b/consensus/src/creation/mod.rs index f33e692b..c0c1fd9f 100644 --- a/consensus/src/creation/mod.rs +++ b/consensus/src/creation/mod.rs @@ -2,9 +2,8 @@ use crate::{ config::{Config as GeneralConfig, DelaySchedule}, runway::NotificationOut, units::{PreUnit, Unit}, - Hasher, NodeCount, NodeIndex, Receiver, Round, Sender, + Hasher, NodeCount, NodeIndex, Receiver, Round, Sender, Terminator, }; -use aleph_bft_types::Terminator; use futures::{ channel::{ mpsc::{SendError, TrySendError}, diff --git a/consensus/src/extender.rs b/consensus/src/extender.rs index 4007835b..b8796fde 100644 --- a/consensus/src/extender.rs +++ b/consensus/src/extender.rs @@ -1,10 +1,9 @@ use futures::{FutureExt, StreamExt}; use std::collections::{HashMap, VecDeque}; -use aleph_bft_types::Terminator; use log::{debug, warn}; -use crate::{Hasher, NodeCount, NodeIndex, NodeMap, Receiver, Round, Sender}; +use crate::{Hasher, NodeCount, NodeIndex, NodeMap, Receiver, Round, Sender, Terminator}; pub(crate) struct ExtenderUnit { creator: NodeIndex, diff --git a/consensus/src/lib.rs b/consensus/src/lib.rs index afa01749..8958d441 100644 --- a/consensus/src/lib.rs +++ b/consensus/src/lib.rs @@ -11,6 +11,7 @@ mod member; mod network; mod runway; mod terminal; +mod terminator; mod units; mod backup; @@ -29,6 +30,7 @@ pub use config::{ }; pub use member::{run_session, LocalIO}; pub use network::NetworkData; +pub use terminator::{handle_task_termination, Terminator}; type Receiver = futures::channel::mpsc::UnboundedReceiver; type Sender = futures::channel::mpsc::UnboundedSender; diff --git a/consensus/src/member.rs b/consensus/src/member.rs index e01431dd..196356a8 100644 --- a/consensus/src/member.rs +++ b/consensus/src/member.rs @@ -1,4 +1,5 @@ use crate::{ + handle_task_termination, member::Task::{CoordRequest, ParentsRequest, RequestNewest, UnitBroadcast}, network, runway::{ @@ -8,9 +9,9 @@ use crate::{ task_queue::TaskQueue, units::{UncheckedSignedUnit, UnitCoord}, Config, Data, DataProvider, FinalizationHandler, Hasher, MultiKeychain, Network, NodeIndex, - Receiver, Recipient, Round, Sender, Signature, SpawnHandle, UncheckedSigned, + Receiver, Recipient, Round, Sender, Signature, SpawnHandle, Terminator, UncheckedSigned, }; -use aleph_bft_types::{handle_task_termination, NodeMap, Terminator}; +use aleph_bft_types::NodeMap; use codec::{Decode, Encode}; use futures::{channel::mpsc, pin_mut, FutureExt, StreamExt}; use futures_timer::Delay; diff --git a/consensus/src/network.rs b/consensus/src/network.rs index 349a9201..8091e37a 100644 --- a/consensus/src/network.rs +++ b/consensus/src/network.rs @@ -1,8 +1,7 @@ use crate::{ alerts::AlertMessage, member::UnitMessage, Data, Hasher, Network, PartialMultisignature, - Receiver, Recipient, Sender, Signature, + Receiver, Recipient, Sender, Signature, Terminator, }; -use aleph_bft_types::Terminator; use codec::{Decode, Encode}; use futures::{FutureExt, StreamExt}; use log::{debug, error, warn}; diff --git a/consensus/src/runway/mod.rs b/consensus/src/runway/mod.rs index 0ebe831e..19eed02d 100644 --- a/consensus/src/runway/mod.rs +++ b/consensus/src/runway/mod.rs @@ -1,6 +1,6 @@ use crate::{ alerts::{Alert, ForkProof, ForkingNotification, NetworkMessage}, - consensus, + consensus, handle_task_termination, member::UnitMessage, units::{ ControlHash, PreUnit, SignedUnit, UncheckedSignedUnit, Unit, UnitCoord, UnitStore, @@ -8,9 +8,9 @@ use crate::{ }, Config, Data, DataProvider, FinalizationHandler, Hasher, Index, Keychain, MultiKeychain, NodeCount, NodeIndex, NodeMap, Receiver, Round, Sender, Signature, Signed, SpawnHandle, - UncheckedSigned, + Terminator, UncheckedSigned, }; -use aleph_bft_types::{handle_task_termination, Recipient, Terminator}; +use aleph_bft_types::Recipient; use futures::{ channel::{mpsc, oneshot}, pin_mut, Future, FutureExt, StreamExt, diff --git a/consensus/src/runway/packer.rs b/consensus/src/runway/packer.rs index 39522dfa..fdd3d217 100644 --- a/consensus/src/runway/packer.rs +++ b/consensus/src/runway/packer.rs @@ -1,8 +1,8 @@ use crate::{ units::{FullUnit, PreUnit, SignedUnit}, Data, DataProvider, Hasher, MultiKeychain, NodeIndex, Receiver, Sender, SessionId, Signed, + Terminator, }; -use aleph_bft_types::Terminator; use futures::{pin_mut, FutureExt, StreamExt}; use log::{debug, error}; use std::marker::PhantomData; @@ -100,10 +100,10 @@ mod tests { use super::Packer; use crate::{ units::{ControlHash, PreUnit, SignedUnit}, - NodeCount, NodeIndex, Receiver, Sender, SessionId, + NodeCount, NodeIndex, Receiver, Sender, SessionId, Terminator, }; use aleph_bft_mock::{Data, DataProvider, Hasher64, Keychain, StalledDataProvider}; - use aleph_bft_types::{NodeMap, Terminator}; + use aleph_bft_types::NodeMap; use futures::{ channel::{mpsc, oneshot}, pin_mut, FutureExt, StreamExt, diff --git a/consensus/src/terminal.rs b/consensus/src/terminal.rs index b511bd8e..f0f68ccd 100644 --- a/consensus/src/terminal.rs +++ b/consensus/src/terminal.rs @@ -8,9 +8,8 @@ use crate::{ extender::ExtenderUnit, runway::{NotificationIn, NotificationOut}, units::{ControlHash, Unit, UnitCoord}, - Hasher, NodeCount, NodeIndex, NodeMap, Receiver, Round, Sender, + Hasher, NodeCount, NodeIndex, NodeMap, Receiver, Round, Sender, Terminator, }; -use aleph_bft_types::Terminator; use codec::{Decode, Encode}; use log::{debug, trace, warn}; diff --git a/types/src/terminator.rs b/consensus/src/terminator.rs similarity index 99% rename from types/src/terminator.rs rename to consensus/src/terminator.rs index 7ff79c47..da06e9be 100644 --- a/types/src/terminator.rs +++ b/consensus/src/terminator.rs @@ -1,4 +1,3 @@ -use aleph_bft_crypto::NodeIndex; use futures::{ channel::oneshot::{channel, Receiver, Sender}, future::FusedFuture, @@ -171,7 +170,7 @@ pub async fn handle_task_termination( task_handle: T, target: &'static str, name: &'static str, - index: NodeIndex, + index: aleph_bft_types::NodeIndex, ) where T: FusedFuture>, { diff --git a/consensus/src/testing/alerts.rs b/consensus/src/testing/alerts.rs index c475c430..cbf877e8 100644 --- a/consensus/src/testing/alerts.rs +++ b/consensus/src/testing/alerts.rs @@ -2,11 +2,10 @@ use crate::{ alerts::{Alert, AlertMessage, ForkProof, ForkingNotification, Handler, Service}, units::{ControlHash, FullUnit, PreUnit}, Index, Indexed, Keychain as _, NodeCount, NodeIndex, NodeMap, Recipient, Round, Signable, - Signed, UncheckedSigned, + Signed, Terminator, UncheckedSigned, }; use aleph_bft_mock::{Data, Hasher64, Keychain, PartialMultisignature, Signature}; use aleph_bft_rmc::Message as RmcMessage; -use aleph_bft_types::Terminator; use futures::{ channel::{mpsc, oneshot}, FutureExt, StreamExt, diff --git a/consensus/src/testing/consensus.rs b/consensus/src/testing/consensus.rs index 83caca54..68671888 100644 --- a/consensus/src/testing/consensus.rs +++ b/consensus/src/testing/consensus.rs @@ -3,10 +3,9 @@ use crate::{ runway::{NotificationIn, NotificationOut}, testing::{complete_oneshot, gen_config, gen_delay_config, init_log}, units::{ControlHash, PreUnit, Unit, UnitCoord}, - Hasher, NodeIndex, SpawnHandle, + Hasher, NodeIndex, SpawnHandle, Terminator, }; use aleph_bft_mock::{Hasher64, Spawner}; -use aleph_bft_types::Terminator; use codec::Encode; use futures::{ channel::{ diff --git a/consensus/src/testing/creation.rs b/consensus/src/testing/creation.rs index bac2b078..152c43d6 100644 --- a/consensus/src/testing/creation.rs +++ b/consensus/src/testing/creation.rs @@ -3,10 +3,9 @@ use crate::{ runway::NotificationOut as GenericNotificationOut, testing::{gen_config, gen_delay_config}, units::{FullUnit as GenericFullUnit, PreUnit as GenericPreUnit, Unit as GenericUnit}, - NodeCount, Receiver, Round, Sender, + NodeCount, Receiver, Round, Sender, Terminator, }; use aleph_bft_mock::{Data, Hasher64}; -use aleph_bft_types::Terminator; use futures::{ channel::{mpsc, oneshot}, FutureExt, StreamExt, diff --git a/consensus/src/testing/dag.rs b/consensus/src/testing/dag.rs index e9a7a1dd..ac84ec5a 100644 --- a/consensus/src/testing/dag.rs +++ b/consensus/src/testing/dag.rs @@ -3,10 +3,9 @@ use crate::{ runway::{NotificationIn, NotificationOut}, testing::{complete_oneshot, gen_config, gen_delay_config}, units::{ControlHash, PreUnit, Unit}, - NodeCount, NodeIndex, NodeMap, NodeSubset, Receiver, Round, Sender, SpawnHandle, + NodeCount, NodeIndex, NodeMap, NodeSubset, Receiver, Round, Sender, SpawnHandle, Terminator, }; use aleph_bft_mock::{Hash64, Hasher64, Spawner}; -use aleph_bft_types::Terminator; use futures::{ channel::{mpsc, oneshot}, stream::StreamExt, diff --git a/consensus/src/testing/mod.rs b/consensus/src/testing/mod.rs index 429e85d9..f881086a 100644 --- a/consensus/src/testing/mod.rs +++ b/consensus/src/testing/mod.rs @@ -10,13 +10,12 @@ mod unreliable; use crate::{ create_config, run_session, Config, DelayConfig, LocalIO, Network as NetworkT, NodeCount, - NodeIndex, SpawnHandle, TaskHandle, + NodeIndex, SpawnHandle, TaskHandle, Terminator, }; use aleph_bft_mock::{ Data, DataProvider, FinalizationHandler, Hasher64, Keychain, Loader, Network as MockNetwork, PartialMultisignature, ReconnectSender as ReconnectSenderGeneric, Saver, Signature, Spawner, }; -use aleph_bft_types::Terminator; use futures::channel::{mpsc::UnboundedReceiver, oneshot}; use parking_lot::Mutex; use std::{sync::Arc, time::Duration}; diff --git a/examples/blockchain/Cargo.toml b/examples/blockchain/Cargo.toml index cbf3bad8..22bf17c5 100644 --- a/examples/blockchain/Cargo.toml +++ b/examples/blockchain/Cargo.toml @@ -9,7 +9,6 @@ publish = false [dependencies] aleph-bft = { path = "../../consensus", version = "*" } aleph-bft-mock = { path = "../../mock", version = "*" } -aleph-bft-types = { path = "../../types", version = "*" } async-trait = "0.1" clap = { version = "4", features = ["derive"] } codec = { package = "parity-scale-codec", version = "3.0", default-features = false, features = ["derive"] } diff --git a/examples/blockchain/src/chain.rs b/examples/blockchain/src/chain.rs index 0a6e60ff..7f6fb341 100644 --- a/examples/blockchain/src/chain.rs +++ b/examples/blockchain/src/chain.rs @@ -1,6 +1,5 @@ use crate::{network::NetworkData, DataStore}; -use aleph_bft::NodeIndex; -use aleph_bft_types::Terminator; +use aleph_bft::{NodeIndex, Terminator}; use codec::{Decode, Encode}; use futures::{ channel::mpsc::{UnboundedReceiver, UnboundedSender}, diff --git a/examples/blockchain/src/main.rs b/examples/blockchain/src/main.rs index 128a6c3e..5043dda4 100644 --- a/examples/blockchain/src/main.rs +++ b/examples/blockchain/src/main.rs @@ -10,9 +10,8 @@ use futures::{channel::oneshot, StreamExt}; use log::{debug, error, info}; use time::{macros::format_description, OffsetDateTime}; -use aleph_bft::{run_session, NodeIndex}; +use aleph_bft::{run_session, NodeIndex, Terminator}; use aleph_bft_mock::{FinalizationHandler, Keychain, Loader, Saver, Spawner}; -use aleph_bft_types::Terminator; use chain::{run_blockchain, Block, BlockNum, ChainConfig}; use data::{Data, DataProvider, DataStore}; use network::{Address, NetworkData, NetworkManager}; diff --git a/examples/blockchain/src/network.rs b/examples/blockchain/src/network.rs index cb9d08bb..9aa65b2a 100644 --- a/examples/blockchain/src/network.rs +++ b/examples/blockchain/src/network.rs @@ -1,7 +1,6 @@ use crate::{Block, Data}; -use aleph_bft::{NodeIndex, Recipient}; +use aleph_bft::{NodeIndex, Recipient, Terminator}; use aleph_bft_mock::{Hasher64, PartialMultisignature, Signature}; -use aleph_bft_types::Terminator; use codec::{Decode, Encode}; use futures::{ channel::mpsc::{self, UnboundedReceiver, UnboundedSender}, diff --git a/examples/ordering/src/main.rs b/examples/ordering/src/main.rs index eec0a5fd..49322311 100644 --- a/examples/ordering/src/main.rs +++ b/examples/ordering/src/main.rs @@ -1,9 +1,8 @@ mod dataio; mod network; -use aleph_bft::{run_session, NodeIndex}; +use aleph_bft::{run_session, NodeIndex, Terminator}; use aleph_bft_mock::{Keychain, Spawner}; -use aleph_bft_types::Terminator; use clap::Parser; use dataio::{Data, DataProvider, FinalizationHandler}; use futures::{channel::oneshot, StreamExt}; diff --git a/fuzz/Cargo.toml b/fuzz/Cargo.toml index f873f1e5..1226899a 100644 --- a/fuzz/Cargo.toml +++ b/fuzz/Cargo.toml @@ -11,7 +11,6 @@ cargo-fuzz = true [dependencies] aleph-bft = { path = "../consensus", version = "*" } aleph-bft-mock = { path = "../mock", version = "*" } -aleph-bft-types = { path = "../types", version = "*" } async-trait = "0.1" codec = { package = "parity-scale-codec", version = "3.0", default-features = false, features = ["derive", "std"] } env_logger = "0.10" diff --git a/fuzz/src/lib.rs b/fuzz/src/lib.rs index c30ac8b7..d909b63f 100644 --- a/fuzz/src/lib.rs +++ b/fuzz/src/lib.rs @@ -1,12 +1,11 @@ use aleph_bft::{ create_config, run_session, Config, DelayConfig, LocalIO, Network as NetworkT, NetworkData, - NodeCount, NodeIndex, Recipient, SpawnHandle, TaskHandle, + NodeCount, NodeIndex, Recipient, SpawnHandle, TaskHandle, Terminator, }; use aleph_bft_mock::{ Data, DataProvider, FinalizationHandler, Hasher64, Keychain, Loader, NetworkHook, PartialMultisignature, Router, Saver, Signature, }; -use aleph_bft_types::Terminator; use codec::{Decode, Encode, IoReader}; use futures::{ channel::{oneshot, oneshot::Receiver}, diff --git a/types/Cargo.toml b/types/Cargo.toml index e2e1ce47..7903c9f1 100644 --- a/types/Cargo.toml +++ b/types/Cargo.toml @@ -15,7 +15,3 @@ aleph-bft-crypto = { path = "../crypto", version = "0.8" } async-trait = "0.1" codec = { package = "parity-scale-codec", version = "3.0", default-features = false, features = ["derive"] } futures = "0.3" -log = "0.4" - -[dev-dependencies] -tokio = { version = "1", features = ["macros", "rt", "rt-multi-thread", "time"] } diff --git a/types/src/lib.rs b/types/src/lib.rs index a4473a34..4c247403 100644 --- a/types/src/lib.rs +++ b/types/src/lib.rs @@ -3,7 +3,6 @@ mod dataio; mod network; mod tasks; -mod terminator; pub use aleph_bft_crypto::{ IncompleteMultisignatureError, Index, Indexed, Keychain, MultiKeychain, Multisigned, NodeCount, @@ -13,7 +12,6 @@ pub use aleph_bft_crypto::{ pub use dataio::{DataProvider, FinalizationHandler}; pub use network::{Network, Recipient}; pub use tasks::{SpawnHandle, TaskHandle}; -pub use terminator::{handle_task_termination, Terminator}; use codec::Codec; use std::{fmt::Debug, hash::Hash as StdHash};