Struct sc_network_sync::engine::SyncingEngine
source · pub struct SyncingEngine<B: BlockT, Client> { /* private fields */ }
Implementations§
source§impl<B, Client> SyncingEngine<B, Client>where
B: BlockT,
Client: HeaderBackend<B> + BlockBackend<B> + HeaderMetadata<B, Error = Error> + ProofProvider<B> + Send + Sync + 'static,
impl<B, Client> SyncingEngine<B, Client>where
B: BlockT,
Client: HeaderBackend<B> + BlockBackend<B> + HeaderMetadata<B, Error = Error> + ProofProvider<B> + Send + Sync + 'static,
pub fn new( roles: Roles, client: Arc<Client>, metrics_registry: Option<&Registry>, net_config: &FullNetworkConfiguration, protocol_id: ProtocolId, fork_id: &Option<String>, block_announce_validator: Box<dyn BlockAnnounceValidator<B> + Send>, warp_sync_params: Option<WarpSyncParams<B>>, network_service: NetworkServiceHandle, import_queue: Box<dyn ImportQueueService<B>>, block_downloader: Arc<dyn BlockDownloader<B>>, state_request_protocol_name: ProtocolName, warp_sync_protocol_name: Option<ProtocolName>, peer_store_handle: PeerStoreHandle ) -> Result<(Self, SyncingService<B>, NonDefaultSetConfig), ClientError>
sourcepub fn report_metrics(&self)
pub fn report_metrics(&self)
Report Prometheus metrics.
sourcepub fn push_block_announce_validation(
&mut self,
peer_id: PeerId,
announce: BlockAnnounce<B::Header>
)
pub fn push_block_announce_validation( &mut self, peer_id: PeerId, announce: BlockAnnounce<B::Header> )
Push a block announce validation.
sourcepub fn announce_block(&mut self, hash: B::Hash, data: Option<Vec<u8>>)
pub fn announce_block(&mut self, hash: B::Hash, data: Option<Vec<u8>>)
Make sure an important block is propagated to peers.
In chain-based consensus, we often need to make sure non-best forks are at least temporarily synced.
pub async fn run(self)
Auto Trait Implementations§
impl<B, Client> !RefUnwindSafe for SyncingEngine<B, Client>
impl<B, Client> Send for SyncingEngine<B, Client>
impl<B, Client> !Sync for SyncingEngine<B, Client>
impl<B, Client> Unpin for SyncingEngine<B, Client>
impl<B, Client> !UnwindSafe for SyncingEngine<B, Client>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of
T
. Read moresource§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of
T
.