Struct sc_network::NetworkService
source · pub struct NetworkService<B: BlockT + 'static, H: ExHashT> { /* private fields */ }
Expand description
Substrate network service. Handles network IO and manages connectivity.
Implementations§
source§impl<B: BlockT + 'static, H: ExHashT> NetworkService<B, H>
impl<B: BlockT + 'static, H: ExHashT> NetworkService<B, H>
sourcepub async fn network_state(&self) -> Result<NetworkState, ()>
pub async fn network_state(&self) -> Result<NetworkState, ()>
Get network state.
Note: Use this only for debugging. This API is unstable. There are warnings literally everywhere about this. Please don’t use this function to retrieve actual information.
Returns an error if the NetworkWorker
is no longer running.
Trait Implementations§
source§impl<B, H> NetworkDHTProvider for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkDHTProvider for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
source§fn get_value(&self, key: &KademliaKey)
fn get_value(&self, key: &KademliaKey)
Start getting a value from the DHT.
This will generate either a ValueFound
or a ValueNotFound
event and pass it as an
item on the NetworkWorker
stream.
source§fn put_value(&self, key: KademliaKey, value: Vec<u8>)
fn put_value(&self, key: KademliaKey, value: Vec<u8>)
Start putting a value in the DHT.
This will generate either a ValuePut
or a ValuePutFailed
event and pass it as an
item on the NetworkWorker
stream.
source§impl<B, H> NetworkEventStream for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkEventStream for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
source§impl<B, H> NetworkNotification for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkNotification for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
source§fn write_notification(
&self,
target: PeerId,
protocol: ProtocolName,
message: Vec<u8>
)
fn write_notification( &self, target: PeerId, protocol: ProtocolName, message: Vec<u8> )
source§fn notification_sender(
&self,
target: PeerId,
protocol: ProtocolName
) -> Result<Box<dyn NotificationSenderT>, NotificationSenderError>
fn notification_sender( &self, target: PeerId, protocol: ProtocolName ) -> Result<Box<dyn NotificationSenderT>, NotificationSenderError>
NotificationSender
for a connected peer, if it exists. Read moresource§fn set_notification_handshake(&self, protocol: ProtocolName, handshake: Vec<u8>)
fn set_notification_handshake(&self, protocol: ProtocolName, handshake: Vec<u8>)
source§impl<B, H> NetworkPeers for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkPeers for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
source§fn add_known_address(&self, peer_id: PeerId, addr: Multiaddr)
fn add_known_address(&self, peer_id: PeerId, addr: Multiaddr)
source§fn report_peer(&self, who: PeerId, cost_benefit: ReputationChange)
fn report_peer(&self, who: PeerId, cost_benefit: ReputationChange)
source§fn disconnect_peer(&self, who: PeerId, protocol: ProtocolName)
fn disconnect_peer(&self, who: PeerId, protocol: ProtocolName)
source§fn accept_unreserved_peers(&self)
fn accept_unreserved_peers(&self)
source§fn deny_unreserved_peers(&self)
fn deny_unreserved_peers(&self)
source§fn add_reserved_peer(&self, peer: MultiaddrWithPeerId) -> Result<(), String>
fn add_reserved_peer(&self, peer: MultiaddrWithPeerId) -> Result<(), String>
source§fn remove_reserved_peer(&self, peer_id: PeerId)
fn remove_reserved_peer(&self, peer_id: PeerId)
PeerId
from the list of reserved peers for a sync protocol (default peer set).source§fn set_reserved_peers(
&self,
protocol: ProtocolName,
peers: HashSet<Multiaddr>
) -> Result<(), String>
fn set_reserved_peers( &self, protocol: ProtocolName, peers: HashSet<Multiaddr> ) -> Result<(), String>
source§fn add_peers_to_reserved_set(
&self,
protocol: ProtocolName,
peers: HashSet<Multiaddr>
) -> Result<(), String>
fn add_peers_to_reserved_set( &self, protocol: ProtocolName, peers: HashSet<Multiaddr> ) -> Result<(), String>
source§fn remove_peers_from_reserved_set(
&self,
protocol: ProtocolName,
peers: Vec<PeerId>
) -> Result<(), String>
fn remove_peers_from_reserved_set( &self, protocol: ProtocolName, peers: Vec<PeerId> ) -> Result<(), String>
source§fn sync_num_connected(&self) -> usize
fn sync_num_connected(&self) -> usize
source§impl<B, H> NetworkRequest for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkRequest for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
source§fn request<'life0, 'async_trait>(
&'life0 self,
target: PeerId,
protocol: ProtocolName,
request: Vec<u8>,
connect: IfDisconnected
) -> Pin<Box<dyn Future<Output = Result<Vec<u8>, RequestFailure>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn request<'life0, 'async_trait>( &'life0 self, target: PeerId, protocol: ProtocolName, request: Vec<u8>, connect: IfDisconnected ) -> Pin<Box<dyn Future<Output = Result<Vec<u8>, RequestFailure>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
source§fn start_request(
&self,
target: PeerId,
protocol: ProtocolName,
request: Vec<u8>,
tx: Sender<Result<Vec<u8>, RequestFailure>>,
connect: IfDisconnected
)
fn start_request( &self, target: PeerId, protocol: ProtocolName, request: Vec<u8>, tx: Sender<Result<Vec<u8>, RequestFailure>>, connect: IfDisconnected )
request
which starts a request whose response is delivered on a provided
channel. Read moresource§impl<B, H> NetworkSigner for NetworkService<B, H>where
B: Block,
H: ExHashT,
impl<B, H> NetworkSigner for NetworkService<B, H>where B: Block, H: ExHashT,
source§impl<B, H> NetworkStateInfo for NetworkService<B, H>where
B: Block,
H: ExHashT,
impl<B, H> NetworkStateInfo for NetworkService<B, H>where B: Block, H: ExHashT,
source§fn external_addresses(&self) -> Vec<Multiaddr>
fn external_addresses(&self) -> Vec<Multiaddr>
Returns the local external addresses.
source§fn listen_addresses(&self) -> Vec<Multiaddr>
fn listen_addresses(&self) -> Vec<Multiaddr>
Returns the listener addresses (without trailing /p2p/
with our PeerId
).
source§fn local_peer_id(&self) -> PeerId
fn local_peer_id(&self) -> PeerId
Returns the local Peer ID.
source§impl<B, H> NetworkStatusProvider for NetworkService<B, H>where
B: BlockT + 'static,
H: ExHashT,
impl<B, H> NetworkStatusProvider for NetworkService<B, H>where B: BlockT + 'static, H: ExHashT,
Auto Trait Implementations§
impl<B, H> !RefUnwindSafe for NetworkService<B, H>
impl<B, H> Send for NetworkService<B, H>
impl<B, H> Sync for NetworkService<B, H>
impl<B, H> Unpin for NetworkService<B, H>where B: Unpin, H: Unpin,
impl<B, H> !UnwindSafe for NetworkService<B, H>
Blanket Implementations§
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,
§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>,
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
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.