Skip to main content

RpcRequestChunkPayload

Struct RpcRequestChunkPayload 

Source
pub struct RpcRequestChunkPayload {
    pub call_id: u64,
    pub flags: u16,
    pub headers: Vec<RpcHeader>,
    pub body: Bytes,
}
Expand description

Continuation chunk for a client-streaming or duplex REQUEST. Lives after the 24-byte EventMeta prefix in a DISPATCH_RPC_REQUEST_CHUNK event.

Unlike the initial RpcRequestPayload there is no service field (server already routed by service at the initial REQUEST) and no deadline_ns (the initial REQUEST’s deadline applies to the whole call). The call_id field is redundant with EventMeta::seq_or_ts but kept on the payload so the codec is self-contained — a reader handed a chunk’s bytes without the meta header can still recover its correlation id.

Bidi streaming plan (Phase A).

Fields§

§call_id: u64

Matches EventMeta::seq_or_ts and the original REQUEST’s call_id. Kept on the payload so the codec round-trips in isolation.

§flags: u16

Bitfield of FLAG_RPC_* constants. The only flag that makes sense on a chunk today is FLAG_RPC_REQUEST_END; other flags MUST be zero on the wire so future protocol extensions can claim them without colliding with existing chunks.

§headers: Vec<RpcHeader>

Per-chunk metadata. Typically empty; reserved for trace-span continuity across long uploads, content-type changes mid-stream, or other rare per-chunk concerns. Capped at MAX_RPC_HEADERS entries with the same per-field caps as RpcRequestPayload::headers.

§body: Bytes

Application-defined chunk body. Cap is MAX_RPC_BODY_LEN (4 MiB), same as the initial REQUEST body — clients that need >4 MiB total payload chunk their upload across multiple REQUEST_CHUNK events.

See RpcRequestPayload::body for the Bytes-vs-Vec<u8> rationale.

Implementations§

Source§

impl RpcRequestChunkPayload

Source

pub fn encoded_len(&self) -> usize

Compute the encoded byte length WITHOUT actually encoding. See RpcRequestPayload::encoded_len for the rationale.

Source

pub fn encode(&self) -> Vec<u8>

Encode to the wire bytes that follow the 24-byte EventMeta prefix in a DISPATCH_RPC_REQUEST_CHUNK event. Same encoder-bounds policy as RpcRequestPayload::encode: oversize fields panic in debug, the decoder enforces in release.

Source

pub fn decode(data: Bytes) -> Result<Self, RpcCodecError>

Decode from the wire bytes following the EventMeta prefix. Bounded by the same MAX_RPC_* caps as the initial REQUEST. Takes Bytes for zero-copy body slicing — see perf #84.

Trait Implementations§

Source§

impl Clone for RpcRequestChunkPayload

Source§

fn clone(&self) -> RpcRequestChunkPayload

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for RpcRequestChunkPayload

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for RpcRequestChunkPayload

Source§

fn eq(&self, other: &RpcRequestChunkPayload) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for RpcRequestChunkPayload

Source§

impl StructuralPartialEq for RpcRequestChunkPayload

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more