logo
pub struct RequestResponse<TCodec> where
    TCodec: RequestResponseCodec
{ /* private fields */ }
Expand description

A request/response protocol for some message codec.

Implementations

Creates a new RequestResponse behaviour for the given protocols, codec and configuration.

Creates a RequestResponse which limits requests per peer.

The behaviour is wrapped in Throttled and detects the limits per peer at runtime which are then enforced.

Initiates sending a request.

If the targeted peer is currently not connected, a dialing attempt is initiated and the request is sent as soon as a connection is established.

Note: In order for such a dialing attempt to succeed, the RequestResonse protocol must either be embedded in another NetworkBehaviour that provides peer and address discovery, or known addresses of peers must be managed via RequestResponse::add_address and RequestResponse::remove_address.

Initiates sending a response to an inbound request.

If the ResponseChannel is already closed due to a timeout or the connection being closed, the response is returned as an Err for further handling. Once the response has been successfully sent on the corresponding connection, RequestResponseEvent::ResponseSent is emitted. In all other cases RequestResponseEvent::InboundFailure will be or has been emitted.

The provided ResponseChannel is obtained from an inbound RequestResponseMessage::Request.

Adds a known address for a peer that can be used for dialing attempts by the Swarm, i.e. is returned by NetworkBehaviour::addresses_of_peer.

Addresses added in this way are only removed by remove_address.

Removes an address of a peer previously added via add_address.

Checks whether a peer is currently connected.

Checks whether an outbound request to the peer with the provided PeerId initiated by RequestResponse::send_request is still pending, i.e. waiting for a response.

Checks whether an inbound request from the peer with the provided PeerId is still pending, i.e. waiting for a response by the local node through RequestResponse::send_response.

Trait Implementations

Handler for all the protocols the network behaviour supports.

Event generated by the NetworkBehaviour and that the swarm will report back.

Creates a new ProtocolsHandler for a connection with a peer. Read more

Addresses that this behaviour is aware of for this specific peer, and that may allow reaching the peer. Read more

Indicates the behaviour that we connected to the node with the given peer id. Read more

Informs the behaviour about a newly established connection to a peer.

Informs the behaviour about a closed connection to a peer. Read more

Indicates the behaviour that we disconnected from the node with the given peer id. Read more

Indicates to the behaviour that we tried to dial all the addresses known for a node, but failed. Read more

Informs the behaviour about an event generated by the handler dedicated to the peer identified by peer_id. for the behaviour. Read more

Polls for things that swarm should do. Read more

Informs the behaviour that the ConnectedPoint of an existing connection has changed.

Indicates to the behaviour that we tried to reach an address, but failed. Read more

Indicates to the behaviour that we have started listening on a new 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

Indicates to the behaviour that we have discovered a new external address for us.

A listener experienced an error.

A listener closed.

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Should always be Self

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.