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,
_: PortUse,
) -> Result<THandler<Self>, ConnectionDenied>
fn handle_established_outbound_connection( &mut self, _: ConnectionId, _: PeerId, _: &Multiaddr, _: Endpoint, _: PortUse, ) -> 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 moreAuto 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§
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
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> 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