packet_formats::ipv6

Struct Ipv6PacketRaw

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

A partially parsed and not yet validated IPv6 packet.

Ipv6PacketRaw provides minimal parsing of an IPv6 packet, namely it only requires that the fixed header part ([HeaderPrefix]) be retrieved, all the other parts of the packet may be missing when attempting to create it.

Ipv6Packet provides a [FromRaw] implementation that can be used to validate an Ipv6PacketRaw.

Implementations§

Source§

impl<B: SplitByteSlice> Ipv6PacketRaw<B>

Source

pub fn body_proto( &self, ) -> Result<(MaybeParsed<&[u8], &[u8]>, Ipv6Proto), ExtHdrParseError>

Returns the body and upper-layer Protocol Number.

If extension headers failed to parse, body_proto returns Err(ExtHdrParseError). Extension headers must be parsed in order to find the bounds of the upper-layer payload and to find that last extension header’s Next Header field, which is the Protocol Number of the upper-layer payload.

The returned body will be [MaybeParsed::Complete] if all the body bytes were consumed (as stated by the header’s payload length value) or [MaybeParsed::Incomplete] containing the bytes that were present otherwise.

Source

pub fn body(&self) -> Result<MaybeParsed<&[u8], &[u8]>, ExtHdrParseError>

Returns the body.

If extension headers failed to parse, body returns Err(ExtHdrParseError). Extension headers must be parsed in order to find the bounds of the upper-layer payload.

The returned body will be [MaybeParsed::Complete] if all the body bytes were consumed (as stated by the header’s payload length value) or [MaybeParsed::Incomplete] containing the bytes that were present otherwise.

Source

pub fn proto(&self) -> Result<Ipv6Proto, ExtHdrParseError>

Returns the upper-layer Protocol Number.

If extension headers failed to parse, body_proto returns Err(ExtHdrParseError). Extension headers must be parsed in order to find the last extension header’s Next Header field, which is the Protocol Number of the upper-layer payload.

Source§

impl<B: SplitByteSliceMut> Ipv6PacketRaw<B>

Source

pub fn set_src_ip(&mut self, addr: Ipv6Addr)

Set the source IP address.

Source

pub fn set_dst_ip(&mut self, addr: Ipv6Addr)

Set the destination IP address.

Trait Implementations§

Source§

impl<B: SplitByteSlice> FromRaw<Ipv6PacketRaw<B>, ()> for Ipv6Packet<B>

Source§

type Error = IpParseError<Ipv6>

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

fn try_from_raw_with( raw: Ipv6PacketRaw<B>, _args: (), ) -> Result<Self, Self::Error>

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

fn try_from_raw(raw: R) -> Result<Self, Self::Error>
where Self: FromRaw<R, (), Error = Self::Error>,

Attempts to create Self from the raw form in raw.
Source§

impl<B: SplitByteSlice> Ipv6Header for Ipv6PacketRaw<B>

Source§

fn get_fixed_header(&self) -> &FixedHeader

Gets a reference to the IPv6 FixedHeader.
Source§

fn hop_limit(&self) -> u8

The Hop Limit.
Source§

fn next_header(&self) -> u8

The Next Header.
Source§

fn src_ip(&self) -> Ipv6Addr

The source IP address.
Source§

fn dst_ip(&self) -> Ipv6Addr

The destination IP address.
Source§

fn dscp_and_ecn(&self) -> DscpAndEcn

The Differentiated Services Code Point (DSCP) and the Explicit Congestion Notification (ECN).
Source§

impl<B: SplitByteSlice> ParsablePacket<B, ()> for Ipv6PacketRaw<B>

Source§

type Error = IpParseError<Ipv6>

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

fn parse<BV: BufferView<B>>(buffer: BV, _args: ()) -> Result<Self, Self::Error>

Parses a packet from a buffer. Read more
Source§

fn parse_metadata(&self) -> ParseMetadata

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

fn parse_mut<BV>(buffer: BV, args: ParseArgs) -> Result<Self, Self::Error>
where BV: BufferViewMut<B>, B: SplitByteSliceMut,

Parses a packet from a mutable buffer. Read more

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

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

§

impl<B> UnwindSafe for Ipv6PacketRaw<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.

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

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.