Struct sc_network::config::Params [−][src]
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, }
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
impl<T> CheckedConversion for T
[src]
impl<T> CheckedConversion for T
[src]pub fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
[src]
Self: TryFrom<T>,
pub fn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
[src]
Self: TryInto<T>,
impl<T> Instrument for T
[src]
impl<T> Instrument for T
[src]pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T> Instrument for T
[src]
impl<T> Instrument for T
[src]pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]impl<T> SaturatedConversion for T
[src]
impl<T> SaturatedConversion for T
[src]pub fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
[src]
Self: UniqueSaturatedFrom<T>,
pub fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
[src]
Self: UniqueSaturatedInto<T>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]pub fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]pub fn unique_saturated_into(self) -> T
[src]
impl<T> WithSubscriber for T
[src]
impl<T> WithSubscriber for T
[src]pub fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
[src]
S: Into<Dispatch>,