Struct sc_network::config::Params
source · [−]pub struct Params<B: BlockT, H: ExHashT> {
pub role: Role,
pub executor: Option<Box<dyn Fn(Pin<Box<dyn Future<Output = ()> + Send>>) + Send>>,
pub network_config: NetworkConfiguration,
pub chain: Arc<dyn Client<B>>,
pub on_demand: Option<Arc<OnDemand<B>>>,
pub transaction_pool: Arc<dyn TransactionPool<H, B>>,
pub protocol_id: ProtocolId,
pub import_queue: Box<dyn ImportQueue<B>>,
pub block_announce_validator: Box<dyn BlockAnnounceValidator<B> + Send>,
pub metrics_registry: Option<Registry>,
pub block_request_protocol_config: RequestResponseConfig,
pub light_client_request_protocol_config: RequestResponseConfig,
}
Expand description
Network initialization parameters.
Fields
role: Role
Assigned role for our node (full, light, …).
executor: Option<Box<dyn Fn(Pin<Box<dyn Future<Output = ()> + Send>>) + Send>>
How to spawn background tasks. If you pass None
, then a threads pool will be used by
default.
network_config: NetworkConfiguration
Network layer configuration.
chain: Arc<dyn Client<B>>
Client that contains the blockchain.
on_demand: Option<Arc<OnDemand<B>>>
The OnDemand
object acts as a “receiver” for block data requests from the client.
If Some
, the network worker will process these requests and answer them.
Normally used only for light clients.
transaction_pool: Arc<dyn TransactionPool<H, B>>
Pool of transactions.
The network worker will fetch transactions from this object in order to propagate them on the network.
protocol_id: ProtocolId
Name of the protocol to use on the wire. Should be different for each chain.
import_queue: Box<dyn ImportQueue<B>>
Import queue to use.
The import queue is the component that verifies that blocks received from other nodes are valid.
block_announce_validator: Box<dyn BlockAnnounceValidator<B> + Send>
Type to check incoming block announcements.
metrics_registry: Option<Registry>
Registry for recording prometheus metrics to.
block_request_protocol_config: RequestResponseConfig
Request response configuration for the block request protocol.
RequestResponseConfig
[name
] is used to tag outgoing block requests with the correct
protocol name. In addition all of RequestResponseConfig
is used to handle incoming block
requests, if enabled.
Can be constructed either via [block_request_handler::generate_protocol_config
] allowing
outgoing but not incoming requests, or constructed via
[block_request_handler::BlockRequestHandler::new
] allowing both outgoing and incoming
requests.
light_client_request_protocol_config: RequestResponseConfig
Request response configuration for the light client request protocol.
Can be constructed either via [light_client_requests::generate_protocol_config
] allowing
outgoing but not incoming requests, or constructed via
[light_client_requests::handler::LightClientRequestHandler::new
] allowing both outgoing
and incoming requests.
Auto Trait Implementations
impl<B, H> !RefUnwindSafe for Params<B, H>
impl<B, H> Send for Params<B, H>
impl<B, H> !Sync for Params<B, H>
impl<B, H> Unpin for Params<B, H>
impl<B, H> !UnwindSafe for Params<B, H>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> CheckedConversion for T
impl<T> CheckedConversion for T
sourcefn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
Convert from a value of T
into an equivalent instance of Option<Self>
. Read more
sourcefn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
Consume self to return Some
equivalent value of Option<T>
. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T, Outer> IsWrappedBy<Outer> for T where
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for T where
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
sourceimpl<T> Pointable for T
impl<T> Pointable for T
sourceimpl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
sourcefn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
Convert from a value of T
into an equivalent instance of Self
. Read more
sourcefn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of T
. Read more
sourceimpl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
sourcepub fn unchecked_into(self) -> T
pub fn unchecked_into(self) -> T
The counterpart to unchecked_from
.
sourceimpl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
sourcepub fn unique_saturated_into(self) -> T
pub fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of T
.
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more