pub struct TcpSegment<B> { /* private fields */ }
Expand description

A TCP segment.

A TcpSegment shares its underlying memory with the byte slice it was parsed from or serialized to, meaning that no copying or extra allocation is necessary.

A TcpSegment - whether parsed using parse or created using TcpSegmentBuilder - maintains the invariant that the checksum is always valid.

Implementations§

source§

impl<B: ByteSlice> TcpSegment<B>

source

pub fn iter_options( &self ) -> impl Iterator<Item = TcpOption<'_>> + Debug + Clone

Iterate over the TCP header options.

source

pub fn body(&self) -> &[u8]

The segment body.

source

pub fn into_body(self) -> B

Consumes this packet and returns the body.

Note that the returned B has the same lifetime as the buffer from which this segment was parsed. By contrast, the body method returns a slice with the same lifetime as the receiver.

source

pub fn src_port(&self) -> NonZeroU16

The source port.

source

pub fn dst_port(&self) -> NonZeroU16

The destination port.

source

pub fn seq_num(&self) -> u32

The sequence number.

source

pub fn ack_num(&self) -> Option<u32>

The acknowledgement number.

If the ACK flag is not set, ack_num returns None.

source

pub fn psh(&self) -> bool

The PSH flag.

source

pub fn rst(&self) -> bool

The RST flag.

source

pub fn syn(&self) -> bool

The SYN flag.

source

pub fn fin(&self) -> bool

The FIN flag.

source

pub fn window_size(&self) -> u16

The sender’s window size.

source

pub fn header_len(&self) -> usize

The length of the header prefix and options.

source

pub fn builder<A: IpAddress>( &self, src_ip: A, dst_ip: A ) -> TcpSegmentBuilderWithOptions<A, ArrayVec<u8, MAX_OPTIONS_LEN>>

Constructs a builder with the same contents as this packet.

source

pub fn into_serializer<'a, A: IpAddress>( self, src_ip: A, dst_ip: A ) -> impl Serializer<Buffer = EmptyBuf> + Debug + 'a
where B: 'a,

Consumes this segment and constructs a [Serializer] with the same contents.

The returned Serializer has the Buffer type [EmptyBuf], which means it is not able to reuse the buffer backing this TcpSegment when serializing, and will always need to allocate a new buffer.

By consuming self instead of taking it by-reference, into_serializer is able to return a Serializer whose lifetime is restricted by the lifetime of the buffer from which this TcpSegment was parsed rather than by the lifetime on &self, which may be more restricted.

Trait Implementations§

source§

impl<B: ByteSlice, A: IpAddress> FromRaw<TcpSegmentRaw<B>, TcpParseArgs<A>> for TcpSegment<B>

§

type Error = ParseError

The type of error that may happen during validation.
source§

fn try_from_raw_with( raw: TcpSegmentRaw<B>, args: TcpParseArgs<A> ) -> Result<Self, Self::Error>

Attempts to create Self from the raw form in raw with args.
source§

impl<B: ByteSlice, A: IpAddress> ParsablePacket<B, TcpParseArgs<A>> for TcpSegment<B>

§

type Error = ParseError

The type of errors returned from parse and parse_mut.
source§

fn parse_metadata(&self) -> ParseMetadata

Gets metadata about this packet required by [GrowBuffer::undo_parse]. Read more
source§

fn parse<BV: BufferView<B>>( buffer: BV, args: TcpParseArgs<A> ) -> ParseResult<Self>

Parses a packet from a buffer. Read more

Auto Trait Implementations§

§

impl<B> Freeze for TcpSegment<B>
where B: Freeze,

§

impl<B> RefUnwindSafe for TcpSegment<B>
where B: RefUnwindSafe,

§

impl<B> Send for TcpSegment<B>
where B: Send,

§

impl<B> Sync for TcpSegment<B>
where B: Sync,

§

impl<B> Unpin for TcpSegment<B>
where B: Unpin,

§

impl<B> UnwindSafe for TcpSegment<B>
where B: UnwindSafe,

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

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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