Struct Behaviour
pub struct Behaviour { /* private fields */ }
Expand description
A NetworkBehaviour
that enforces a set of ConnectionLimits
.
For these limits to take effect, this needs to be composed into the behaviour tree of your application.
If a connection is denied due to a limit, either a
SwarmEvent::IncomingConnectionError
or SwarmEvent::OutgoingConnectionError
will be emitted. The ListenError::Denied
and respectively
the DialError::Denied
variant
contain a ConnectionDenied
type that can be downcast to Exceeded
error if (and only if)
this behaviour denied the connection.
You can also set Peer IDs that bypass the said limit. Connections that match the bypass rules will not be checked against or counted for limits.
If you employ multiple NetworkBehaviour
s that manage connections,
it may also be a different error.
§Example
#[derive(NetworkBehaviour)]
struct MyBehaviour {
identify: identify::Behaviour,
ping: ping::Behaviour,
limits: connection_limits::Behaviour,
}
Implementations§
§impl Behaviour
impl Behaviour
pub fn new(limits: ConnectionLimits) -> Behaviour
pub fn limits_mut(&mut self) -> &mut ConnectionLimits
pub fn limits_mut(&mut self) -> &mut ConnectionLimits
Returns a mutable reference to ConnectionLimits
.
Note: A new limit will not be enforced against existing connections.
pub fn bypass_peer_id(&mut self, peer_id: &PeerId)
pub fn bypass_peer_id(&mut self, peer_id: &PeerId)
Add the peer to bypass list.
pub fn remove_peer_id(&mut self, peer_id: &PeerId)
pub fn remove_peer_id(&mut self, peer_id: &PeerId)
Remove the peer from bypass list.
pub fn is_bypassed(&self, remote_peer: &PeerId) -> bool
pub fn is_bypassed(&self, remote_peer: &PeerId) -> bool
Whether the connection is bypassed.
Trait Implementations§
§impl NetworkBehaviour for Behaviour
impl NetworkBehaviour for Behaviour
§type ConnectionHandler = ConnectionHandler
type ConnectionHandler = ConnectionHandler
§type ToSwarm = Infallible
type ToSwarm = Infallible
NetworkBehaviour
and that the swarm will report back.§fn handle_pending_inbound_connection(
&mut self,
connection_id: ConnectionId,
_: &Multiaddr,
_: &Multiaddr,
) -> Result<(), ConnectionDenied>
fn handle_pending_inbound_connection( &mut self, connection_id: ConnectionId, _: &Multiaddr, _: &Multiaddr, ) -> Result<(), ConnectionDenied>
§fn handle_established_inbound_connection(
&mut self,
connection_id: ConnectionId,
peer: PeerId,
_: &Multiaddr,
_: &Multiaddr,
) -> Result<<Behaviour as NetworkBehaviour>::ConnectionHandler, ConnectionDenied>
fn handle_established_inbound_connection( &mut self, connection_id: ConnectionId, peer: PeerId, _: &Multiaddr, _: &Multiaddr, ) -> Result<<Behaviour as NetworkBehaviour>::ConnectionHandler, ConnectionDenied>
§fn handle_pending_outbound_connection(
&mut self,
connection_id: ConnectionId,
maybe_peer: Option<PeerId>,
_: &[Multiaddr],
_: Endpoint,
) -> Result<Vec<Multiaddr>, ConnectionDenied>
fn handle_pending_outbound_connection( &mut self, connection_id: ConnectionId, maybe_peer: Option<PeerId>, _: &[Multiaddr], _: Endpoint, ) -> Result<Vec<Multiaddr>, ConnectionDenied>
§fn handle_established_outbound_connection(
&mut self,
connection_id: ConnectionId,
peer: PeerId,
_: &Multiaddr,
_: Endpoint,
_: PortUse,
) -> Result<<Behaviour as NetworkBehaviour>::ConnectionHandler, ConnectionDenied>
fn handle_established_outbound_connection( &mut self, connection_id: ConnectionId, peer: PeerId, _: &Multiaddr, _: Endpoint, _: PortUse, ) -> Result<<Behaviour as NetworkBehaviour>::ConnectionHandler, ConnectionDenied>
§fn on_swarm_event(&mut self, event: FromSwarm<'_>)
fn on_swarm_event(&mut self, event: FromSwarm<'_>)
Swarm
.§fn on_connection_handler_event(
&mut self,
_id: PeerId,
_: ConnectionId,
event: <<Behaviour as NetworkBehaviour>::ConnectionHandler as ConnectionHandler>::ToBehaviour,
)
fn on_connection_handler_event( &mut self, _id: PeerId, _: ConnectionId, event: <<Behaviour as NetworkBehaviour>::ConnectionHandler as ConnectionHandler>::ToBehaviour, )
ConnectionHandler
dedicated to the peer identified by peer_id
. for the behaviour. Read more§fn poll(
&mut self,
_: &mut Context<'_>,
) -> Poll<ToSwarm<<Behaviour as NetworkBehaviour>::ToSwarm, <<Behaviour as NetworkBehaviour>::ConnectionHandler as ConnectionHandler>::FromBehaviour>>
fn poll( &mut self, _: &mut Context<'_>, ) -> Poll<ToSwarm<<Behaviour as NetworkBehaviour>::ToSwarm, <<Behaviour as NetworkBehaviour>::ConnectionHandler as ConnectionHandler>::FromBehaviour>>
Auto Trait Implementations§
impl Freeze for Behaviour
impl RefUnwindSafe for Behaviour
impl Send for Behaviour
impl Sync for Behaviour
impl Unpin for Behaviour
impl UnwindSafe for Behaviour
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more