Expand description
Request/response protocols used in Polkadot.
Overview over request/responses as used in Polkadot
.
enum Protocol
…. List of all supported protocols.
enum Requests
…. List of all supported requests, each entry matches one in protocols, but
has the actual request as payload.
struct IncomingRequest
…. wrapper for incoming requests, containing a sender for sending
responses.
struct OutgoingRequest
…. wrapper for outgoing requests, containing a sender used by the
networking code for delivering responses/delivery errors.
trait IsRequest
…. A trait describing a particular request. It is used for gathering meta
data, like what is the corresponding response type.
Versioned (v1 module): The actual requests and responses as sent over the network.
Re-exports
pub use incoming::IncomingRequest;
pub use incoming::IncomingRequestReceiver;
pub use outgoing::OutgoingRequest;
pub use outgoing::OutgoingResult;
pub use outgoing::Recipient;
pub use outgoing::Requests;
pub use outgoing::ResponseSender;
Modules
Everything related to handling of incoming requests.
Configuration of the networking layer.
Everything related to handling of outgoing requests.
Actual versioned requests and responses, that are sent over the wire.
Requests and responses as sent over the wire for the individual protocols.
Structs
An iterator over the variants of Self
Type for getting on the wire
Protocol
names using genesis hash & fork id.Configuration for a single request-response protocol.
Enums
A protocol per subsystem seems to make the most sense, this way we don’t need any dispatching
within protocols.
The protocol name transmitted on the wire.
Constants
Timeout for requesting availability chunks.
We don’t want a slow peer to slow down all the others, at the same time we want to get out the
data quickly in full to at least some peers (as this will reduce load on us as they then can
start serving the data). So this value is a tradeoff. 3 seems to be sensible. So we would need
to have 3 slow nodes connected, to delay transfer for others by
STATEMENTS_TIMEOUT
.Traits
Common properties of any
Request
.