Skip to main content

ClientBuilder

Struct ClientBuilder 

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

Builder for Client.

Configures transport: TLS, timeouts, socket options. Protocol configuration (host, headers, base path) lives on RequestWriter.

Implementations§

Source§

impl ClientBuilder

Source

pub fn new() -> Self

Create a new builder with defaults.

Source

pub fn tls(self, config: &TlsConfig) -> Self

Set a custom TLS configuration.

If not set, https:// URLs use TlsConfig::new() (system defaults).

Source

pub fn disable_nagle(self) -> Self

Set TCP_NODELAY (disable Nagle’s algorithm).

Source

pub fn connect_timeout(self, d: Duration) -> Self

TCP connect timeout.

Source

pub fn read_timeout(self, d: Duration) -> Self

Socket read timeout.

Source

pub fn connect( self, url: &str, ) -> Result<Client<MaybeTls<TcpStream>>, RestError>

Connect to an HTTP(S) endpoint (blocking).

TLS is auto-detected from the URL scheme. When the tls feature is enabled, returns Client<MaybeTls<TcpStream>>https:// uses MaybeTls::Tls, http:// uses MaybeTls::Plain. Without the tls feature, returns Client<TcpStream> and errors on https://.

Source

pub fn connect_with<S: Read + Write>( self, stream: S, url: &str, ) -> Result<Client<S>, RestError>

Connect using a pre-connected socket.

The stream must already handle TLS if connecting to https://. For example, pass a TlsStream<TcpStream> or MaybeTls<TcpStream>.

Source

pub fn writer_for(url: &str) -> Result<RequestWriter, RestError>

Create a RequestWriter configured for this URL.

Convenience: extracts host and path from the URL to create a writer with the correct Host header and base path.

Trait Implementations§

Source§

impl Default for ClientBuilder

Source§

fn default() -> Self

Returns the “default value” for a type. 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> Same for T

Source§

type Output = T

Should always be Self
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V