Enum EthMessage
pub enum EthMessage<N = EthNetworkPrimitives>where
N: NetworkPrimitives,{
Show 16 variants
Status(Status),
NewBlockHashes(NewBlockHashes),
NewBlock(Box<NewBlock<<N as NetworkPrimitives>::Block>>),
Transactions(Transactions),
NewPooledTransactionHashes66(NewPooledTransactionHashes66),
NewPooledTransactionHashes68(NewPooledTransactionHashes68),
GetBlockHeaders(RequestPair<GetBlockHeaders>),
BlockHeaders(RequestPair<BlockHeaders<<N as NetworkPrimitives>::BlockHeader>>),
GetBlockBodies(RequestPair<GetBlockBodies>),
BlockBodies(RequestPair<BlockBodies<<N as NetworkPrimitives>::BlockBody>>),
GetPooledTransactions(RequestPair<GetPooledTransactions>),
PooledTransactions(RequestPair<PooledTransactions>),
GetNodeData(RequestPair<GetNodeData>),
NodeData(RequestPair<NodeData>),
GetReceipts(RequestPair<GetReceipts>),
Receipts(RequestPair<Receipts>),
}
Expand description
Represents a message in the eth wire protocol, versions 66, 67 and 68.
The ethereum wire protocol is a set of messages that are broadcast to the network in two styles:
- A request message sent by a peer (such as
GetPooledTransactions
), and an associated response message (such asPooledTransactions
). - A message that is broadcast to the network, without a corresponding request.
The newer eth/66
is an efficiency upgrade on top of eth/65
, introducing a request id to
correlate request-response message pairs. This allows for request multiplexing.
The eth/67
is based on eth/66
but only removes two messages, GetNodeData
and
NodeData
.
The eth/68
changes only NewPooledTransactionHashes
to include types
and sized
. For
it, NewPooledTransactionHashes
is renamed as NewPooledTransactionHashes66
and
NewPooledTransactionHashes68
is defined.
Variants§
Status(Status)
Represents a Status message required for the protocol handshake.
NewBlockHashes(NewBlockHashes)
Represents a NewBlockHashes
message broadcast to the network.
NewBlock(Box<NewBlock<<N as NetworkPrimitives>::Block>>)
Represents a NewBlock
message broadcast to the network.
Transactions(Transactions)
Represents a Transactions message broadcast to the network.
NewPooledTransactionHashes66(NewPooledTransactionHashes66)
Represents a NewPooledTransactionHashes
message for eth/66 version.
NewPooledTransactionHashes68(NewPooledTransactionHashes68)
Represents a NewPooledTransactionHashes
message for eth/68 version.
GetBlockHeaders(RequestPair<GetBlockHeaders>)
Represents a GetBlockHeaders
request-response pair.
BlockHeaders(RequestPair<BlockHeaders<<N as NetworkPrimitives>::BlockHeader>>)
Represents a BlockHeaders
request-response pair.
GetBlockBodies(RequestPair<GetBlockBodies>)
Represents a GetBlockBodies
request-response pair.
BlockBodies(RequestPair<BlockBodies<<N as NetworkPrimitives>::BlockBody>>)
Represents a BlockBodies
request-response pair.
GetPooledTransactions(RequestPair<GetPooledTransactions>)
Represents a GetPooledTransactions
request-response pair.
PooledTransactions(RequestPair<PooledTransactions>)
Represents a PooledTransactions
request-response pair.
GetNodeData(RequestPair<GetNodeData>)
Represents a GetNodeData
request-response pair.
NodeData(RequestPair<NodeData>)
Represents a NodeData
request-response pair.
GetReceipts(RequestPair<GetReceipts>)
Represents a GetReceipts
request-response pair.
Receipts(RequestPair<Receipts>)
Represents a Receipts request-response pair.
Implementations§
§impl<N> EthMessage<N>where
N: NetworkPrimitives,
impl<N> EthMessage<N>where
N: NetworkPrimitives,
pub const fn message_id(&self) -> EthMessageID
pub const fn message_id(&self) -> EthMessageID
Returns the message’s ID.
Trait Implementations§
Source§impl<S, N> CanDisconnect<EthMessage<N>> for EthStream<S, N>where
S: CanDisconnect<Bytes> + Send,
EthStreamError: From<<S as Sink<Bytes>>::Error>,
N: NetworkPrimitives,
impl<S, N> CanDisconnect<EthMessage<N>> for EthStream<S, N>where
S: CanDisconnect<Bytes> + Send,
EthStreamError: From<<S as Sink<Bytes>>::Error>,
N: NetworkPrimitives,
Source§async fn disconnect(
&mut self,
reason: DisconnectReason,
) -> Result<(), EthStreamError>
async fn disconnect( &mut self, reason: DisconnectReason, ) -> Result<(), EthStreamError>
DisconnectReason
as disconnect
information if the stream implements a protocol that can carry the additional disconnect
metadata.§impl<N> Clone for EthMessage<N>where
N: Clone + NetworkPrimitives,
<N as NetworkPrimitives>::Block: Clone,
<N as NetworkPrimitives>::BlockHeader: Clone,
<N as NetworkPrimitives>::BlockBody: Clone,
impl<N> Clone for EthMessage<N>where
N: Clone + NetworkPrimitives,
<N as NetworkPrimitives>::Block: Clone,
<N as NetworkPrimitives>::BlockHeader: Clone,
<N as NetworkPrimitives>::BlockBody: Clone,
§fn clone(&self) -> EthMessage<N>
fn clone(&self) -> EthMessage<N>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl<N> Debug for EthMessage<N>where
N: Debug + NetworkPrimitives,
<N as NetworkPrimitives>::Block: Debug,
<N as NetworkPrimitives>::BlockHeader: Debug,
<N as NetworkPrimitives>::BlockBody: Debug,
impl<N> Debug for EthMessage<N>where
N: Debug + NetworkPrimitives,
<N as NetworkPrimitives>::Block: Debug,
<N as NetworkPrimitives>::BlockHeader: Debug,
<N as NetworkPrimitives>::BlockBody: Debug,
§impl<'de, N> Deserialize<'de> for EthMessage<N>where
N: NetworkPrimitives,
<N as NetworkPrimitives>::Block: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockHeader: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockBody: Serialize + DeserializeOwned,
impl<'de, N> Deserialize<'de> for EthMessage<N>where
N: NetworkPrimitives,
<N as NetworkPrimitives>::Block: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockHeader: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockBody: Serialize + DeserializeOwned,
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<EthMessage<N>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<EthMessage<N>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
§impl<N> Encodable for EthMessage<N>where
N: NetworkPrimitives,
impl<N> Encodable for EthMessage<N>where
N: NetworkPrimitives,
§impl<N> From<EthMessage<N>> for ProtocolMessage<N>where
N: NetworkPrimitives,
impl<N> From<EthMessage<N>> for ProtocolMessage<N>where
N: NetworkPrimitives,
§fn from(message: EthMessage<N>) -> ProtocolMessage<N>
fn from(message: EthMessage<N>) -> ProtocolMessage<N>
§impl<N> From<NewPooledTransactionHashes> for EthMessage<N>where
N: NetworkPrimitives,
impl<N> From<NewPooledTransactionHashes> for EthMessage<N>where
N: NetworkPrimitives,
§fn from(value: NewPooledTransactionHashes) -> EthMessage<N>
fn from(value: NewPooledTransactionHashes) -> EthMessage<N>
§impl<N> PartialEq for EthMessage<N>where
N: PartialEq + NetworkPrimitives,
<N as NetworkPrimitives>::Block: PartialEq,
<N as NetworkPrimitives>::BlockHeader: PartialEq,
<N as NetworkPrimitives>::BlockBody: PartialEq,
impl<N> PartialEq for EthMessage<N>where
N: PartialEq + NetworkPrimitives,
<N as NetworkPrimitives>::Block: PartialEq,
<N as NetworkPrimitives>::BlockHeader: PartialEq,
<N as NetworkPrimitives>::BlockBody: PartialEq,
§impl<N> Serialize for EthMessage<N>where
N: NetworkPrimitives,
<N as NetworkPrimitives>::Block: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockHeader: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockBody: Serialize + DeserializeOwned,
impl<N> Serialize for EthMessage<N>where
N: NetworkPrimitives,
<N as NetworkPrimitives>::Block: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockHeader: Serialize + DeserializeOwned,
<N as NetworkPrimitives>::BlockBody: Serialize + DeserializeOwned,
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Source§impl<S, N> Sink<EthMessage<N>> for EthStream<S, N>where
S: CanDisconnect<Bytes> + Unpin,
EthStreamError: From<<S as Sink<Bytes>>::Error>,
N: NetworkPrimitives,
impl<S, N> Sink<EthMessage<N>> for EthStream<S, N>where
S: CanDisconnect<Bytes> + Unpin,
EthStreamError: From<<S as Sink<Bytes>>::Error>,
N: NetworkPrimitives,
Source§type Error = EthStreamError
type Error = EthStreamError
Source§fn poll_ready(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>
fn poll_ready( self: Pin<&mut Self>, cx: &mut Context<'_>, ) -> Poll<Result<(), Self::Error>>
Sink
to receive a value. Read moreSource§fn start_send(
self: Pin<&mut Self>,
item: EthMessage<N>,
) -> Result<(), Self::Error>
fn start_send( self: Pin<&mut Self>, item: EthMessage<N>, ) -> Result<(), Self::Error>
poll_ready
which returned Poll::Ready(Ok(()))
. Read moreimpl<N> Eq for EthMessage<N>where
N: Eq + NetworkPrimitives,
<N as NetworkPrimitives>::Block: Eq,
<N as NetworkPrimitives>::BlockHeader: Eq,
<N as NetworkPrimitives>::BlockBody: Eq,
impl<N> StructuralPartialEq for EthMessage<N>where
N: NetworkPrimitives,
Auto Trait Implementations§
impl<N> Freeze for EthMessage<N>
impl<N> RefUnwindSafe for EthMessage<N>where
<N as NetworkPrimitives>::Block: RefUnwindSafe,
<N as NetworkPrimitives>::BlockHeader: RefUnwindSafe,
<N as NetworkPrimitives>::BlockBody: RefUnwindSafe,
impl<N> Send for EthMessage<N>
impl<N> Sync for EthMessage<N>
impl<N> Unpin for EthMessage<N>
impl<N> UnwindSafe for EthMessage<N>where
<N as NetworkPrimitives>::Block: UnwindSafe,
<N as NetworkPrimitives>::BlockHeader: UnwindSafe,
<N as NetworkPrimitives>::BlockBody: UnwindSafe,
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeDebug for Twhere
T: Debug,
impl<T> MaybeSendSync for T
impl<T> RpcObject for Twhere
T: RpcParam + RpcReturn,
impl<T> RpcParam for T
impl<T> RpcReturn for T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 136 bytes
Size for each variant:
Status
: 136 bytesNewBlockHashes
: 32 bytesNewBlock
: 16 bytesTransactions
: 32 bytesNewPooledTransactionHashes66
: 32 bytesNewPooledTransactionHashes68
: 80 bytesGetBlockHeaders
: 72 bytesBlockHeaders
: 40 bytesGetBlockBodies
: 40 bytesBlockBodies
: 40 bytesGetPooledTransactions
: 40 bytesPooledTransactions
: 40 bytesGetNodeData
: 40 bytesNodeData
: 40 bytesGetReceipts
: 40 bytesReceipts
: 40 bytes