pub struct Behaviour { /* private fields */ }
Expand description
A NetworkBehaviour
that enforces a set of memory usage based limits.
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 MemoryUsageLimitExceeded
error if (and only if) this
behaviour denied the connection.
If you employ multiple NetworkBehaviour
s that manage connections, it may also be a different error.
Behaviour::with_max_bytes and Behaviour::with_max_percentage are mutually exclusive. If you need to employ both of them, compose two instances of Behaviour into your custom behaviour.
Example
#[derive(NetworkBehaviour)]
struct MyBehaviour {
identify: identify::Behaviour,
limits: memory_connection_limits::Behaviour
}
Implementations§
source§impl Behaviour
impl Behaviour
sourcepub fn with_max_bytes(max_allowed_bytes: usize) -> Self
pub fn with_max_bytes(max_allowed_bytes: usize) -> Self
Sets the process memory usage threshold in absolute bytes.
New inbound and outbound connections will be denied when the threshold is reached.
sourcepub fn with_max_percentage(percentage: f64) -> Self
pub fn with_max_percentage(percentage: f64) -> Self
Sets the process memory usage threshold in the percentage of the total physical memory.
New inbound and outbound connections will be denied when the threshold is reached.
sourcepub fn max_allowed_bytes(&self) -> usize
pub fn max_allowed_bytes(&self) -> usize
Gets the process memory usage threshold in bytes.
Trait Implementations§
source§impl NetworkBehaviour for Behaviour
impl NetworkBehaviour for Behaviour
§type ConnectionHandler = ConnectionHandler
type ConnectionHandler = ConnectionHandler
source§fn handle_pending_inbound_connection(
&mut self,
_: ConnectionId,
_: &Multiaddr,
_: &Multiaddr
) -> Result<(), ConnectionDenied>
fn handle_pending_inbound_connection( &mut self, _: ConnectionId, _: &Multiaddr, _: &Multiaddr ) -> Result<(), ConnectionDenied>
source§fn handle_established_inbound_connection(
&mut self,
_: ConnectionId,
_: PeerId,
_: &Multiaddr,
_: &Multiaddr
) -> Result<THandler<Self>, ConnectionDenied>
fn handle_established_inbound_connection( &mut self, _: ConnectionId, _: PeerId, _: &Multiaddr, _: &Multiaddr ) -> Result<THandler<Self>, ConnectionDenied>
source§fn handle_pending_outbound_connection(
&mut self,
_: ConnectionId,
_: Option<PeerId>,
_: &[Multiaddr],
_: Endpoint
) -> Result<Vec<Multiaddr>, ConnectionDenied>
fn handle_pending_outbound_connection( &mut self, _: ConnectionId, _: Option<PeerId>, _: &[Multiaddr], _: Endpoint ) -> Result<Vec<Multiaddr>, ConnectionDenied>
source§fn handle_established_outbound_connection(
&mut self,
_: ConnectionId,
_: PeerId,
_: &Multiaddr,
_: Endpoint
) -> Result<THandler<Self>, ConnectionDenied>
fn handle_established_outbound_connection( &mut self, _: ConnectionId, _: PeerId, _: &Multiaddr, _: Endpoint ) -> Result<THandler<Self>, ConnectionDenied>
source§fn on_swarm_event(&mut self, _: FromSwarm<'_>)
fn on_swarm_event(&mut self, _: FromSwarm<'_>)
Swarm
.source§fn on_connection_handler_event(
&mut self,
_id: PeerId,
_: ConnectionId,
event: THandlerOutEvent<Self>
)
fn on_connection_handler_event( &mut self, _id: PeerId, _: ConnectionId, event: THandlerOutEvent<Self> )
ConnectionHandler
dedicated to the peer identified by peer_id
. for the behaviour. Read more