Skip to main content

Http2Layer

Struct Http2Layer 

Source
pub struct Http2Layer {
    pub index: LayerIndex,
    pub has_preface: bool,
}
Expand description

HTTP/2 protocol layer view.

Represents one or more HTTP/2 frames within a packet buffer. The index covers the portion of the buffer from the start of the HTTP/2 data (preface or first frame header) to the end.

Note: A single Http2Layer may contain multiple frames. Use frames::parse_all_frames or Http2Layer::all_frames to iterate them.

Fields§

§index: LayerIndex

Layer boundary index within the packet buffer.

§has_preface: bool

Whether the layer begins with the HTTP/2 client connection preface.

Implementations§

Source§

impl Http2Layer

Source

pub fn new(start: usize, end: usize, has_preface: bool) -> Self

Create a new HTTP/2 layer from start/end offsets and a preface flag.

Source

pub fn from_index(index: LayerIndex, has_preface: bool) -> Self

Create from an existing LayerIndex.

Source

pub fn has_preface_at(buf: &[u8], offset: usize) -> bool

Check if buf starting at offset begins with the HTTP/2 preface.

Source

pub fn frames_start(&self) -> usize

Get the offset where frames begin (after the preface if present).

Source

pub fn first_frame(&self, buf: &[u8]) -> Option<Http2Frame>

Get the first frame in this layer, skipping the preface if present.

Returns None if there are no frames or the buffer is too short.

Source

pub fn all_frames(&self, buf: &[u8]) -> Vec<Http2Frame>

Parse all frames in this layer’s buffer range.

Source

pub fn summary(&self, buf: &[u8]) -> String

Generate a human-readable summary for this layer.

Source

pub fn header_len(&self, buf: &[u8]) -> usize

Get the “header length” of this layer.

This returns the number of bytes that constitute the “header” portion:

  • If only a preface: 24 bytes
  • If a frame (no preface): 9 bytes (one frame header)
  • If preface + at least one frame: 33 bytes (24 + 9)
Source

pub fn get_field( &self, buf: &[u8], name: &str, ) -> Option<Result<FieldValue, FieldError>>

Get a field value from the first frame by name.

Supported fields: frame_type, flags, stream_id, length.

Source

pub fn set_field( &self, buf: &mut [u8], name: &str, value: FieldValue, ) -> Option<Result<(), FieldError>>

Set a field value by name.

Currently only stream_id supports mutation. Other fields require rebuilding the frame.

Source

pub fn field_names() -> &'static [&'static str]

Get the static list of field names for this layer type.

Trait Implementations§

Source§

impl Clone for Http2Layer

Source§

fn clone(&self) -> Http2Layer

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Http2Layer

Source§

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

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

impl Layer for Http2Layer

Source§

fn kind(&self) -> LayerKind

Get the kind of this layer
Source§

fn summary(&self, data: &[u8]) -> String

Get a human-readable summary of this layer
Source§

fn header_len(&self, data: &[u8]) -> usize

Get the header length for this layer
Source§

fn field_names(&self) -> &'static [&'static str]

Get the list of field names for this layer
Source§

fn hashret(&self, _data: &[u8]) -> Vec<u8>

Compute a hash for packet matching.
Source§

fn answers(&self, _data: &[u8], _other: &Self, _other_data: &[u8]) -> bool

Check if this packet answers another packet.
Source§

fn extract_padding<'a>(&self, data: &'a [u8]) -> (&'a [u8], &'a [u8])

Extract padding from the packet.

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<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V