ProxyV2TlvSource

Enum ProxyV2TlvSource 

Source
pub enum ProxyV2TlvSource<'zc, PAR: PP2TlvRestore<'zc>, EXT: PP2TlvRestore<'zc>> {
    Internal(PAR::TlvTblRes),
    External(EXT::TlvTblRes),
    Error(HaProxErr),
}
Expand description

An enum which is returned by the TLV iterator. It may contain either parsed TLV or error description which occured during parsing. Normally, in case of error, the parsing should be stopped and connection dropped.

Variants§

§

Internal(PAR::TlvTblRes)

A base implementation of the protocl.

§

External(EXT::TlvTblRes)

A user’s extension to the protocol.

§

Error(HaProxErr)

Error during parsing.

Implementations§

Source§

impl<'zc, PAR: PP2TlvRestore<'zc>, EXT: PP2TlvRestore<'zc>> ProxyV2TlvSource<'zc, PAR, EXT>

Source

pub fn take_internal(self) -> Option<PAR::TlvTblRes>

Consumes the instance returning the PP2Tlvs build-in TLV through Option. If instance os not Internal then instance will be lost.

Examples found in repository?
examples/example_custom_parser.rs (line 106)
71fn main() -> HaProxRes<()>
72{
73
74    let pkt_ssl = 
75b"\x0d\x0a\x0d\x0a\x00\x0d\x0a\x51\x55\x49\x54\x0a\x21\x11\x00\x29\
76\x7f\x00\x00\x01\x7f\x00\x00\x43\x9b\x4a\x2e\x6b\x20\x00\x0f\x01\
77\x00\x00\x00\x00\x21\x00\x07\x54\x4c\x53\x76\x31\x2e\x32\xE0\x00\
78\x08\x01\x02\x03\x04\x05\x06\x07\x08";
79
80        let dec = ProxyV2Parser::<PPV2ParserZeroCopy, ProxyV2Dummy2>::try_from_slice_custom(pkt_ssl.as_slice()).unwrap();
81
82        assert_eq!(dec.get_transport().is_ok(), true);
83        assert_eq!(dec.get_transport().unwrap(), ProxyTransportFam::STREAM);
84
85        assert_eq!(dec.get_proto_version(), ProtocolVersion::V2);
86        assert_eq!(dec.get_proto_command(), HdrV2Command::PROXY);
87
88        assert_eq!(dec.get_address_family().is_ok(), true);
89        assert_eq!(dec.get_address_family().unwrap(), ProxyV2AddrType::AfInet);
90        
91        let addr = dec.get_address().unwrap();
92
93        assert_eq!(addr.is_some(), true);
94
95        let addr = addr.unwrap();
96        let maddr = ProxyV2Addr::try_from(("127.0.0.1:39754", "127.0.0.67:11883")).unwrap();
97
98        assert_eq!(addr, maddr);
99
100        let tlv_iter = dec.get_tlvs_iter();
101
102        assert_eq!(tlv_iter.is_some(), true);
103
104        let mut tlv_iter = tlv_iter.unwrap();
105
106        let type_ssl = tlv_iter.next().unwrap().take_internal().unwrap();
107
108        assert_eq!(type_ssl.get_type(), PP2Tlvs::TYPE_SSL);
109        let PP2Tlvs::TypeSsl { client, verify } = type_ssl else {panic!("wrong")};
110
111        assert_eq!(client, PP2TlvClient::PP2_CLIENT_SSL);
112        assert_eq!(verify, 0);
113
114        // --
115        let type_ssl_version = tlv_iter.next().unwrap().take_internal().unwrap();
116
117        assert_eq!(type_ssl_version.get_type(), PP2Tlvs::TYPE_SUBTYPE_SSL_VERSION);
118
119        let PP2Tlvs::TypeSubtypeSslVersion(ssl_version) = type_ssl_version else { panic!("wrong") };
120
121        assert_eq!(ssl_version, "TLSv1.2");
122
123        // ---
124        let ext_type_e0 = tlv_iter.next().unwrap().take_external().unwrap();
125
126        assert_eq!(ext_type_e0.get_type(), 0xE0);
127
128        let ProxyV2Dummy2::SomeTlvName(arg0, arg1) = ext_type_e0 else {panic!("wrong")};
129
130        assert_eq!(arg0, 0x01020304);
131        assert_eq!(arg1, 0x05060708);
132
133
134    return Ok(());
135}
Source

pub fn take_external(self) -> Option<EXT::TlvTblRes>

Consumes the instance returning the PP2Tlvs build-in TLV through Option. If instance os not External then instance will be lost.

Examples found in repository?
examples/example_custom_parser.rs (line 124)
71fn main() -> HaProxRes<()>
72{
73
74    let pkt_ssl = 
75b"\x0d\x0a\x0d\x0a\x00\x0d\x0a\x51\x55\x49\x54\x0a\x21\x11\x00\x29\
76\x7f\x00\x00\x01\x7f\x00\x00\x43\x9b\x4a\x2e\x6b\x20\x00\x0f\x01\
77\x00\x00\x00\x00\x21\x00\x07\x54\x4c\x53\x76\x31\x2e\x32\xE0\x00\
78\x08\x01\x02\x03\x04\x05\x06\x07\x08";
79
80        let dec = ProxyV2Parser::<PPV2ParserZeroCopy, ProxyV2Dummy2>::try_from_slice_custom(pkt_ssl.as_slice()).unwrap();
81
82        assert_eq!(dec.get_transport().is_ok(), true);
83        assert_eq!(dec.get_transport().unwrap(), ProxyTransportFam::STREAM);
84
85        assert_eq!(dec.get_proto_version(), ProtocolVersion::V2);
86        assert_eq!(dec.get_proto_command(), HdrV2Command::PROXY);
87
88        assert_eq!(dec.get_address_family().is_ok(), true);
89        assert_eq!(dec.get_address_family().unwrap(), ProxyV2AddrType::AfInet);
90        
91        let addr = dec.get_address().unwrap();
92
93        assert_eq!(addr.is_some(), true);
94
95        let addr = addr.unwrap();
96        let maddr = ProxyV2Addr::try_from(("127.0.0.1:39754", "127.0.0.67:11883")).unwrap();
97
98        assert_eq!(addr, maddr);
99
100        let tlv_iter = dec.get_tlvs_iter();
101
102        assert_eq!(tlv_iter.is_some(), true);
103
104        let mut tlv_iter = tlv_iter.unwrap();
105
106        let type_ssl = tlv_iter.next().unwrap().take_internal().unwrap();
107
108        assert_eq!(type_ssl.get_type(), PP2Tlvs::TYPE_SSL);
109        let PP2Tlvs::TypeSsl { client, verify } = type_ssl else {panic!("wrong")};
110
111        assert_eq!(client, PP2TlvClient::PP2_CLIENT_SSL);
112        assert_eq!(verify, 0);
113
114        // --
115        let type_ssl_version = tlv_iter.next().unwrap().take_internal().unwrap();
116
117        assert_eq!(type_ssl_version.get_type(), PP2Tlvs::TYPE_SUBTYPE_SSL_VERSION);
118
119        let PP2Tlvs::TypeSubtypeSslVersion(ssl_version) = type_ssl_version else { panic!("wrong") };
120
121        assert_eq!(ssl_version, "TLSv1.2");
122
123        // ---
124        let ext_type_e0 = tlv_iter.next().unwrap().take_external().unwrap();
125
126        assert_eq!(ext_type_e0.get_type(), 0xE0);
127
128        let ProxyV2Dummy2::SomeTlvName(arg0, arg1) = ext_type_e0 else {panic!("wrong")};
129
130        assert_eq!(arg0, 0x01020304);
131        assert_eq!(arg1, 0x05060708);
132
133
134    return Ok(());
135}
Source

pub fn contains_subtype(&self) -> bool

Checks if current instance constains the subtype. For Error false is always returned.

Trait Implementations§

Source§

impl<'zc, PAR: Clone + PP2TlvRestore<'zc>, EXT: Clone + PP2TlvRestore<'zc>> Clone for ProxyV2TlvSource<'zc, PAR, EXT>
where PAR::TlvTblRes: Clone, EXT::TlvTblRes: Clone,

Source§

fn clone(&self) -> ProxyV2TlvSource<'zc, PAR, EXT>

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<'zc, PAR: Debug + PP2TlvRestore<'zc>, EXT: Debug + PP2TlvRestore<'zc>> Debug for ProxyV2TlvSource<'zc, PAR, EXT>
where PAR::TlvTblRes: Debug, EXT::TlvTblRes: Debug,

Source§

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

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

impl<'zc, PAR: PartialEq + PP2TlvRestore<'zc>, EXT: PartialEq + PP2TlvRestore<'zc>> PartialEq for ProxyV2TlvSource<'zc, PAR, EXT>

Source§

fn eq(&self, other: &ProxyV2TlvSource<'zc, PAR, EXT>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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<'zc, PAR: Eq + PP2TlvRestore<'zc>, EXT: Eq + PP2TlvRestore<'zc>> Eq for ProxyV2TlvSource<'zc, PAR, EXT>
where PAR::TlvTblRes: Eq, EXT::TlvTblRes: Eq,

Source§

impl<'zc, PAR: PP2TlvRestore<'zc>, EXT: PP2TlvRestore<'zc>> StructuralPartialEq for ProxyV2TlvSource<'zc, PAR, EXT>

Auto Trait Implementations§

§

impl<'zc, PAR, EXT> Freeze for ProxyV2TlvSource<'zc, PAR, EXT>
where <PAR as PP2TlvRestore<'zc>>::TlvTblRes: Freeze, <EXT as PP2TlvRestore<'zc>>::TlvTblRes: Freeze,

§

impl<'zc, PAR, EXT> RefUnwindSafe for ProxyV2TlvSource<'zc, PAR, EXT>

§

impl<'zc, PAR, EXT> Send for ProxyV2TlvSource<'zc, PAR, EXT>
where <PAR as PP2TlvRestore<'zc>>::TlvTblRes: Send, <EXT as PP2TlvRestore<'zc>>::TlvTblRes: Send,

§

impl<'zc, PAR, EXT> Sync for ProxyV2TlvSource<'zc, PAR, EXT>
where <PAR as PP2TlvRestore<'zc>>::TlvTblRes: Sync, <EXT as PP2TlvRestore<'zc>>::TlvTblRes: Sync,

§

impl<'zc, PAR, EXT> Unpin for ProxyV2TlvSource<'zc, PAR, EXT>
where <PAR as PP2TlvRestore<'zc>>::TlvTblRes: Unpin, <EXT as PP2TlvRestore<'zc>>::TlvTblRes: Unpin,

§

impl<'zc, PAR, EXT> UnwindSafe for ProxyV2TlvSource<'zc, PAR, EXT>
where <PAR as PP2TlvRestore<'zc>>::TlvTblRes: UnwindSafe, <EXT as PP2TlvRestore<'zc>>::TlvTblRes: 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> 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> 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.