pub struct PathChallengePacket<'p> { /* private fields */ }
Expand description
A structure enabling manipulation of on the wire packets
Implementations§
Source§impl<'a> PathChallengePacket<'a>
impl<'a> PathChallengePacket<'a>
Sourcepub fn new<'p>(packet: &'p [u8]) -> Option<PathChallengePacket<'p>>
pub fn new<'p>(packet: &'p [u8]) -> Option<PathChallengePacket<'p>>
Constructs a new #name. If the provided buffer is less than the minimum required packet size, this will return None.
Sourcepub fn owned(packet: Vec<u8>) -> Option<PathChallengePacket<'static>>
pub fn owned(packet: Vec<u8>) -> Option<PathChallengePacket<'static>>
Constructs a new #name. If the provided buffer is less than the minimum required packet size, this will return None. With this constructor the #name will own its own data and the underlying buffer will be dropped when the #name is.
Sourcepub fn to_immutable<'p>(&'p self) -> PathChallengePacket<'p>
pub fn to_immutable<'p>(&'p self) -> PathChallengePacket<'p>
Maps from a #name to a #imm_name
Sourcepub fn consume_to_immutable(self) -> PathChallengePacket<'a>
pub fn consume_to_immutable(self) -> PathChallengePacket<'a>
Maps from a #name to a #imm_name while consuming the source
Sourcepub const fn minimum_packet_size() -> usize
pub const fn minimum_packet_size() -> usize
The minimum size (in bytes) a packet of this type can be. It’s based on the total size of the fixed-size fields.
Sourcepub fn packet_size(_packet: &PathChallenge) -> usize
pub fn packet_size(_packet: &PathChallenge) -> usize
The size (in bytes) of a #base_name instance when converted into a byte-array
Sourcepub fn get_data_raw(&self) -> &[u8] ⓘ
pub fn get_data_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the {name} field, without copying
Sourcepub fn get_remaining_raw(&self) -> &[u8] ⓘ
pub fn get_remaining_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the {name} field, without copying
Sourcepub fn get_remaining(&self) -> Vec<u8>
pub fn get_remaining(&self) -> Vec<u8>
Get the value of the {name} field (copies contents)