NntpProxyBuilder

Struct NntpProxyBuilder 

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

Builder for constructing an NntpProxy with optional configuration overrides

§Examples

Basic usage with defaults:

let config = load_config("config.toml")?;
let proxy = NntpProxyBuilder::new(config)
    .with_routing_mode(RoutingMode::Hybrid)
    .build()?;

With custom buffer pool size:

let config = load_config("config.toml")?;
let proxy = NntpProxyBuilder::new(config)
    .with_routing_mode(RoutingMode::PerCommand)
    .with_buffer_pool_size(512 * 1024)  // 512KB buffers
    .with_buffer_pool_count(64)         // 64 buffers
    .build()?;

Implementations§

Source§

impl NntpProxyBuilder

Source

pub fn new(config: Config) -> Self

Create a new builder with the given configuration

The routing mode defaults to Standard (1:1) mode.

Source

pub fn with_routing_mode(self, mode: RoutingMode) -> Self

Set the routing mode

Available modes:

  • Standard: 1:1 client-to-backend mapping (default)
  • PerCommand: Each command routes to a different backend
  • Hybrid: Starts in per-command mode, switches to stateful when needed
Source

pub fn with_buffer_pool_size(self, size: usize) -> Self

Override the default buffer pool size (256KB)

This affects the size of each buffer in the pool. Larger buffers can improve throughput for large article transfers but use more memory.

Source

pub fn with_buffer_pool_count(self, count: usize) -> Self

Override the default buffer pool count (32)

This affects how many buffers are pre-allocated. Should roughly match the expected number of concurrent connections.

Source

pub fn build(self) -> Result<NntpProxy>

Build the NntpProxy instance

§Errors

Returns an error if:

  • No servers are configured
  • Connection providers cannot be created
  • Buffer size is zero

Trait Implementations§

Source§

impl Debug for NntpProxyBuilder

Source§

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

Formats the value using the given formatter. 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more