Skip to main content

OvpnCodec

Struct OvpnCodec 

Source
pub struct OvpnCodec { /* private fields */ }
Expand description

Tokio codec for the OpenVPN management interface.

The encoder serializes typed OvpnCommand values into correct wire-format bytes, including proper escaping and multi-line block framing. The decoder uses command-tracking state to correctly distinguish single-line from multi-line responses, and accumulates multi-line >CLIENT: notifications into a single OvpnMessage before emitting them.

§Sequential usage

The OpenVPN management protocol is strictly sequential: each command produces exactly one response, and the server processes commands one at a time. This codec tracks which response type to expect from the last encoded command. You must fully drain [decode()] (until it returns Ok(None) or the expected response is received) before calling [encode()] again. Encoding a new command while a multi-line response or CLIENT notification is still being accumulated will overwrite the tracking state and corrupt decoding.

In debug builds, encode() asserts that no accumulation is in progress.

Implementations§

Source§

impl OvpnCodec

Source

pub fn new() -> Self

Create a new codec with default state, ready to encode commands and decode responses.

Source

pub fn with_max_multi_line_lines(self, limit: AccumulationLimit) -> Self

Set the maximum number of lines accumulated in a multi-line response before the decoder returns an error.

Source

pub fn with_max_client_env_entries(self, limit: AccumulationLimit) -> Self

Set the maximum number of ENV entries accumulated for >CLIENT: notifications before the decoder returns an error.

Trait Implementations§

Source§

impl Decoder for OvpnCodec

Source§

type Item = OvpnMessage

The type of decoded frames.
Source§

type Error = Error

The type of unrecoverable frame decoding errors. Read more
Source§

fn decode( &mut self, src: &mut BytesMut, ) -> Result<Option<Self::Item>, Self::Error>

Attempts to decode a frame from the provided buffer of bytes. Read more
Source§

fn decode_eof( &mut self, buf: &mut BytesMut, ) -> Result<Option<Self::Item>, Self::Error>

A default method available to be called when there are no more bytes available to be read from the underlying I/O. Read more
Source§

fn framed<T>(self, io: T) -> Framed<T, Self>
where T: AsyncRead + AsyncWrite, Self: Sized,

Provides a Stream and Sink interface for reading and writing to this Io object, using Decode and Encode to read and write the raw data. Read more
Source§

impl Default for OvpnCodec

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Encoder<OvpnCommand> for OvpnCodec

Source§

type Error = Error

The type of encoding errors. Read more
Source§

fn encode( &mut self, item: OvpnCommand, dst: &mut BytesMut, ) -> Result<(), Self::Error>

Encodes a frame into the buffer provided. Read more

Auto Trait Implementations§

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.