pub struct Behaviour { /* private fields */ }Expand description
NetworkBehaviour for AutoNAT.
The behaviour frequently runs probes to determine whether the local peer is behind NAT and/ or a firewall, or
publicly reachable.
In a probe, a dial-back request is sent to a peer that is randomly selected from the list of fixed servers and
connected peers. Upon receiving a dial-back request, the remote tries to dial the included addresses. When a
first address was successfully dialed, a status Ok will be send back together with the dialed address. If no address
can be reached a dial-error is send back.
Based on the received response, the sender assumes themselves to be public or private.
The status is retried in a frequency of Config::retry_interval or Config::retry_interval, depending on whether
enough confidence in the assumed NAT status was reached or not.
The confidence increases each time a probe confirms the assumed status, and decreases if a different status is reported.
If the confidence is 0, the status is flipped and the Behaviour will report the new status in an OutEvent.
Implementations§
source§impl Behaviour
impl Behaviour
pub fn new(local_peer_id: PeerId, config: Config) -> Behaviour
sourcepub fn public_address(&self) -> Option<&Multiaddr>
pub fn public_address(&self) -> Option<&Multiaddr>
Assumed public address of the local peer.
Returns None in case of status NatStatus::Private or NatStatus::Unknown.
sourcepub fn nat_status(&self) -> NatStatus
pub fn nat_status(&self) -> NatStatus
Assumed NAT status.
sourcepub fn confidence(&self) -> usize
pub fn confidence(&self) -> usize
Confidence in the assumed NAT status.
sourcepub fn add_server(&mut self, peer: PeerId, address: Option<Multiaddr>)
pub fn add_server(&mut self, peer: PeerId, address: Option<Multiaddr>)
Add a peer to the list over servers that may be used for probes. These peers are used for dial-request even if they are currently not connection, in which case a connection will be establish before sending the dial-request.
sourcepub fn remove_server(&mut self, peer: &PeerId)
pub fn remove_server(&mut self, peer: &PeerId)
Remove a peer from the list of servers.
See Behaviour::add_server for more info.
Trait Implementations§
source§impl NetworkBehaviour for Behaviour
impl NetworkBehaviour for Behaviour
§type ConnectionHandler = <RequestResponse<AutoNatCodec> as NetworkBehaviour>::ConnectionHandler
type ConnectionHandler = <RequestResponse<AutoNatCodec> as NetworkBehaviour>::ConnectionHandler
source§fn inject_connection_established(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
endpoint: &ConnectedPoint,
failed_addresses: Option<&Vec<Multiaddr, Global>>,
other_established: usize
)
fn inject_connection_established(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
endpoint: &ConnectedPoint,
failed_addresses: Option<&Vec<Multiaddr, Global>>,
other_established: usize
)
source§fn inject_connection_closed(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
endpoint: &ConnectedPoint,
handler: <<Behaviour as NetworkBehaviour>::ConnectionHandler as IntoConnectionHandler>::Handler,
remaining_established: usize
)
fn inject_connection_closed(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
endpoint: &ConnectedPoint,
handler: <<Behaviour as NetworkBehaviour>::ConnectionHandler as IntoConnectionHandler>::Handler,
remaining_established: usize
)
source§fn inject_dial_failure(
&mut self,
peer: Option<PeerId>,
handler: <Behaviour as NetworkBehaviour>::ConnectionHandler,
error: &DialError
)
fn inject_dial_failure(
&mut self,
peer: Option<PeerId>,
handler: <Behaviour as NetworkBehaviour>::ConnectionHandler,
error: &DialError
)
source§fn inject_address_change(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
old: &ConnectedPoint,
new: &ConnectedPoint
)
fn inject_address_change(
&mut self,
peer: &PeerId,
conn: &ConnectionId,
old: &ConnectedPoint,
new: &ConnectedPoint
)
ConnectedPoint of an existing connection has changed.source§fn inject_new_listen_addr(&mut self, id: ListenerId, addr: &Multiaddr)
fn inject_new_listen_addr(&mut self, id: ListenerId, addr: &Multiaddr)
source§fn inject_expired_listen_addr(&mut self, id: ListenerId, addr: &Multiaddr)
fn inject_expired_listen_addr(&mut self, id: ListenerId, addr: &Multiaddr)
source§fn inject_new_external_addr(&mut self, addr: &Multiaddr)
fn inject_new_external_addr(&mut self, addr: &Multiaddr)
source§fn inject_expired_external_addr(&mut self, addr: &Multiaddr)
fn inject_expired_external_addr(&mut self, addr: &Multiaddr)
source§fn poll(
&mut self,
cx: &mut Context<'_>,
params: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<<Behaviour as NetworkBehaviour>::OutEvent, <Behaviour as NetworkBehaviour>::ConnectionHandler, <<<Behaviour as NetworkBehaviour>::ConnectionHandler as IntoConnectionHandler>::Handler as ConnectionHandler>::InEvent>>
fn poll(
&mut self,
cx: &mut Context<'_>,
params: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<<Behaviour as NetworkBehaviour>::OutEvent, <Behaviour as NetworkBehaviour>::ConnectionHandler, <<<Behaviour as NetworkBehaviour>::ConnectionHandler as IntoConnectionHandler>::Handler as ConnectionHandler>::InEvent>>
source§fn new_handler(&mut self) -> <Behaviour as NetworkBehaviour>::ConnectionHandler
fn new_handler(&mut self) -> <Behaviour as NetworkBehaviour>::ConnectionHandler
ConnectionHandler for a connection with a peer. Read moresource§fn addresses_of_peer(&mut self, peer: &PeerId) -> Vec<Multiaddr, Global> ⓘ
fn addresses_of_peer(&mut self, peer: &PeerId) -> Vec<Multiaddr, Global> ⓘ
source§fn inject_event(
&mut self,
peer_id: PeerId,
conn: ConnectionId,
event: RequestResponseHandlerEvent<AutoNatCodec>
)
fn inject_event(
&mut self,
peer_id: PeerId,
conn: ConnectionId,
event: RequestResponseHandlerEvent<AutoNatCodec>
)
peer_id.
for the behaviour. Read more