Struct libp2p::request_response::Throttled
source · [−]pub struct Throttled<C> where
C: RequestResponseCodec + Send,
<C as RequestResponseCodec>::Protocol: Sync, { /* private fields */ }
Expand description
A wrapper around RequestResponse
which adds request limits per peer.
Implementations
sourceimpl<C> Throttled<C> where
C: RequestResponseCodec + Send + Clone,
<C as RequestResponseCodec>::Protocol: Sync,
impl<C> Throttled<C> where
C: RequestResponseCodec + Send + Clone,
<C as RequestResponseCodec>::Protocol: Sync,
sourcepub fn new<I>(c: C, protos: I, cfg: RequestResponseConfig) -> Throttled<C> where
I: IntoIterator<Item = (<C as RequestResponseCodec>::Protocol, ProtocolSupport)>,
C: Send,
<C as RequestResponseCodec>::Protocol: Sync,
pub fn new<I>(c: C, protos: I, cfg: RequestResponseConfig) -> Throttled<C> where
I: IntoIterator<Item = (<C as RequestResponseCodec>::Protocol, ProtocolSupport)>,
C: Send,
<C as RequestResponseCodec>::Protocol: Sync,
Create a new throttled request-response behaviour.
sourcepub fn from(behaviour: RequestResponse<Codec<C>>) -> Throttled<C>
pub fn from(behaviour: RequestResponse<Codec<C>>) -> Throttled<C>
Wrap an existing RequestResponse
behaviour and apply send/recv limits.
sourcepub fn set_receive_limit(&mut self, limit: NonZeroU16)
pub fn set_receive_limit(&mut self, limit: NonZeroU16)
Set the global default receive limit per peer.
sourcepub fn override_receive_limit(&mut self, p: &PeerId, limit: NonZeroU16)
pub fn override_receive_limit(&mut self, p: &PeerId, limit: NonZeroU16)
Override the receive limit of a single peer.
sourcepub fn remove_override(&mut self, p: &PeerId)
pub fn remove_override(&mut self, p: &PeerId)
Remove any limit overrides for the given peer.
sourcepub fn can_send(&mut self, p: &PeerId) -> bool
pub fn can_send(&mut self, p: &PeerId) -> bool
Has the limit of outbound requests been reached for the given peer?
sourcepub fn send_request(
&mut self,
p: &PeerId,
req: <C as RequestResponseCodec>::Request
) -> Result<RequestId, <C as RequestResponseCodec>::Request>
pub fn send_request(
&mut self,
p: &PeerId,
req: <C as RequestResponseCodec>::Request
) -> Result<RequestId, <C as RequestResponseCodec>::Request>
Send a request to a peer.
If the limit of outbound requests has been reached, the request is
returned. Sending more outbound requests should only be attempted
once Event::ResumeSending
has been received from NetworkBehaviour::poll
.
sourcepub fn send_response(
&mut self,
ch: ResponseChannel<Message<<C as RequestResponseCodec>::Response>>,
res: <C as RequestResponseCodec>::Response
) -> Result<(), <C as RequestResponseCodec>::Response>
pub fn send_response(
&mut self,
ch: ResponseChannel<Message<<C as RequestResponseCodec>::Response>>,
res: <C as RequestResponseCodec>::Response
) -> Result<(), <C as RequestResponseCodec>::Response>
Answer an inbound request with a response.
See RequestResponse::send_response
for details.
sourcepub fn add_address(&mut self, p: &PeerId, a: Multiaddr)
pub fn add_address(&mut self, p: &PeerId, a: Multiaddr)
Add a known peer address.
See RequestResponse::add_address
for details.
sourcepub fn remove_address(&mut self, p: &PeerId, a: &Multiaddr)
pub fn remove_address(&mut self, p: &PeerId, a: &Multiaddr)
Remove a previously added peer address.
See RequestResponse::remove_address
for details.
sourcepub fn is_connected(&self, p: &PeerId) -> bool
pub fn is_connected(&self, p: &PeerId) -> bool
Are we connected to the given peer?
See RequestResponse::is_connected
for details.
sourcepub fn is_pending_outbound(&self, p: &PeerId, r: &RequestId) -> bool
pub fn is_pending_outbound(&self, p: &PeerId, r: &RequestId) -> bool
Are we waiting for a response to the given request?
See RequestResponse::is_pending_outbound
for details.
sourcepub fn is_pending_inbound(&self, p: &PeerId, r: &RequestId) -> bool
pub fn is_pending_inbound(&self, p: &PeerId, r: &RequestId) -> bool
Is the remote waiting for the local node to respond to the given request?
See RequestResponse::is_pending_inbound
for details.
Trait Implementations
sourceimpl<C> NetworkBehaviour for Throttled<C> where
C: 'static + RequestResponseCodec + Send + Clone,
<C as RequestResponseCodec>::Protocol: Sync,
impl<C> NetworkBehaviour for Throttled<C> where
C: 'static + RequestResponseCodec + Send + Clone,
<C as RequestResponseCodec>::Protocol: Sync,
type ProtocolsHandler = RequestResponseHandler<Codec<C>>
type ProtocolsHandler = RequestResponseHandler<Codec<C>>
Handler for all the protocols the network behaviour supports.
type OutEvent = Event<<C as RequestResponseCodec>::Request, <C as RequestResponseCodec>::Response, Message<<C as RequestResponseCodec>::Response>>
type OutEvent = Event<<C as RequestResponseCodec>::Request, <C as RequestResponseCodec>::Response, Message<<C as RequestResponseCodec>::Response>>
Event generated by the NetworkBehaviour
and that the swarm will report back.
sourcepub fn new_handler(
&mut self
) -> <Throttled<C> as NetworkBehaviour>::ProtocolsHandler
pub fn new_handler(
&mut self
) -> <Throttled<C> as NetworkBehaviour>::ProtocolsHandler
Creates a new ProtocolsHandler
for a connection with a peer. Read more
sourcepub fn addresses_of_peer(&mut self, p: &PeerId) -> Vec<Multiaddr, Global>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
pub fn addresses_of_peer(&mut self, p: &PeerId) -> Vec<Multiaddr, Global>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
Addresses that this behaviour is aware of for this specific peer, and that may allow reaching the peer. Read more
sourcepub fn inject_connection_established(
&mut self,
p: &PeerId,
id: &ConnectionId,
end: &ConnectedPoint
)
pub fn inject_connection_established(
&mut self,
p: &PeerId,
id: &ConnectionId,
end: &ConnectedPoint
)
Informs the behaviour about a newly established connection to a peer.
sourcepub fn inject_connection_closed(
&mut self,
peer: &PeerId,
id: &ConnectionId,
end: &ConnectedPoint
)
pub fn inject_connection_closed(
&mut self,
peer: &PeerId,
id: &ConnectionId,
end: &ConnectedPoint
)
Informs the behaviour about a closed connection to a peer. Read more
sourcepub fn inject_connected(&mut self, p: &PeerId)
pub fn inject_connected(&mut self, p: &PeerId)
Indicates the behaviour that we connected to the node with the given peer id. Read more
sourcepub fn inject_disconnected(&mut self, p: &PeerId)
pub fn inject_disconnected(&mut self, p: &PeerId)
Indicates the behaviour that we disconnected from the node with the given peer id. Read more
sourcepub fn inject_dial_failure(&mut self, p: &PeerId)
pub fn inject_dial_failure(&mut self, p: &PeerId)
Indicates to the behaviour that we tried to dial all the addresses known for a node, but failed. Read more
sourcepub fn inject_event(
&mut self,
p: PeerId,
i: ConnectionId,
e: RequestResponseHandlerEvent<Codec<C>>
)
pub fn inject_event(
&mut self,
p: PeerId,
i: ConnectionId,
e: RequestResponseHandlerEvent<Codec<C>>
)
Informs the behaviour about an event generated by the handler dedicated to the peer identified by peer_id
.
for the behaviour. Read more
sourcepub fn poll(
&mut self,
cx: &mut Context<'_>,
params: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<RequestProtocol<Codec<C>>, <Throttled<C> as NetworkBehaviour>::OutEvent>>
pub fn poll(
&mut self,
cx: &mut Context<'_>,
params: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<RequestProtocol<Codec<C>>, <Throttled<C> as NetworkBehaviour>::OutEvent>>
Polls for things that swarm should do. Read more
sourcefn inject_address_change(
&mut self,
&PeerId,
&ConnectionId,
_old: &ConnectedPoint,
_new: &ConnectedPoint
)
fn inject_address_change(
&mut self,
&PeerId,
&ConnectionId,
_old: &ConnectedPoint,
_new: &ConnectedPoint
)
Informs the behaviour that the ConnectedPoint
of an existing connection has changed.
sourcefn inject_addr_reach_failure(
&mut self,
_peer_id: Option<&PeerId>,
_addr: &Multiaddr,
_error: &dyn Error
)
fn inject_addr_reach_failure(
&mut self,
_peer_id: Option<&PeerId>,
_addr: &Multiaddr,
_error: &dyn Error
)
Indicates to the behaviour that we tried to reach an address, but failed. Read more
sourcefn inject_new_listen_addr(&mut self, _addr: &Multiaddr)
fn inject_new_listen_addr(&mut self, _addr: &Multiaddr)
Indicates to the behaviour that we have started listening on a new multiaddr.
sourcefn inject_expired_listen_addr(&mut self, _addr: &Multiaddr)
fn inject_expired_listen_addr(&mut self, _addr: &Multiaddr)
Indicates to the behaviour that a new multiaddr we were listening on has expired, which means that we are no longer listening in it. Read more
sourcefn inject_new_external_addr(&mut self, _addr: &Multiaddr)
fn inject_new_external_addr(&mut self, _addr: &Multiaddr)
Indicates to the behaviour that we have discovered a new external address for us.
sourcefn inject_listener_error(
&mut self,
_id: ListenerId,
_err: &(dyn Error + 'static)
)
fn inject_listener_error(
&mut self,
_id: ListenerId,
_err: &(dyn Error + 'static)
)
A listener experienced an error.
sourcefn inject_listener_closed(
&mut self,
_id: ListenerId,
_reason: Result<(), &Error>
)
fn inject_listener_closed(
&mut self,
_id: ListenerId,
_reason: Result<(), &Error>
)
A listener closed.
Auto Trait Implementations
impl<C> !RefUnwindSafe for Throttled<C>
impl<C> Send for Throttled<C>
impl<C> Sync for Throttled<C> where
C: Sync,
<C as RequestResponseCodec>::Request: Sync,
<C as RequestResponseCodec>::Response: Sync,
impl<C> Unpin for Throttled<C> where
C: Unpin,
<C as RequestResponseCodec>::Protocol: Unpin,
<C as RequestResponseCodec>::Request: Unpin,
<C as RequestResponseCodec>::Response: Unpin,
impl<C> !UnwindSafe for Throttled<C>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more