Struct ppp::v2::Builder[][src]

pub struct Builder { /* fields omitted */ }
Expand description

Implementation of the builder pattern for PROXY protocol v2 headers. Supports both valid and invalid headers via the write_payload and write_payloads functions.

Examples

use ppp::v2::{Addresses, AddressFamily, Builder, Command, IPv4, Protocol, PROTOCOL_PREFIX, Type, Version};
let mut expected = Vec::from(PROTOCOL_PREFIX);
expected.extend([
   0x21, 0x12, 0, 16, 127, 0, 0, 1, 192, 168, 1, 1, 0, 80, 1, 187, 4, 0, 1, 42
]);

let addresses: Addresses = IPv4::new([127, 0, 0, 1], [192, 168, 1, 1], 80, 443).into();
let header = Builder::with_addresses(
    Version::Two | Command::Proxy,
    Protocol::Datagram,
    addresses
)
.write_tlv(Type::NoOp, [42].as_slice())
.unwrap()
.build()
.unwrap();

assert_eq!(header, expected);

Implementations

Creates an instance of a Builder with the given header bytes. No guarantee is made that any address bytes written as a payload will match the header’s address family. The length is determined on build unless set_length is called to set an explicit value.

Creates an instance of a Builder with the given header bytes and Addresses. The address family is determined from the variant of the Addresses given. The length is determined on build unless set_length is called to set an explicit value.

Reserves the requested additional capacity in the underlying buffer. Helps to prevent resizing the underlying buffer when called before write_payload, write_payloads. When called after write_payload, write_payloads, useful as a hint on how to resize the buffer.

Overrides the length in the header. When set to Some value, the length may be smaller or larger than the actual payload in the buffer.

Writes a iterable set of payloads in order to the buffer. No bytes are added by this Builder as a delimiter.

Writes a single payload to the buffer. No surrounding bytes (terminal or otherwise) are added by this Builder.

Writes a Type-Length-Value as a payload. No surrounding bytes (terminal or otherwise) are added by this Builder. The length is determined by the length of the slice. An error is returned when the length of the slice exceeds u16::MAX.

Builds the header and returns the underlying buffer. If no length was explicitly set, returns an error when the length of the payload portion exceeds u16::MAX.

Trait Implementations

Formats the value using the given formatter. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Performs the conversion.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.