pub struct HttpConnector<R = GaiResolver> { /* private fields */ }
client
and client-legacy
and tokio
only.Expand description
Implementations§
Source§impl HttpConnector
impl HttpConnector
Sourcepub fn new() -> HttpConnector
pub fn new() -> HttpConnector
Construct a new HttpConnector.
Source§impl<R> HttpConnector<R>
impl<R> HttpConnector<R>
Sourcepub fn new_with_resolver(resolver: R) -> HttpConnector<R>
pub fn new_with_resolver(resolver: R) -> HttpConnector<R>
Construct a new HttpConnector.
Takes a Resolver
to handle DNS lookups.
Sourcepub fn enforce_http(&mut self, is_enforced: bool)
pub fn enforce_http(&mut self, is_enforced: bool)
Option to enforce all Uri
s have the http
scheme.
Enabled by default.
Sourcepub fn set_keepalive(&mut self, time: Option<Duration>)
pub fn set_keepalive(&mut self, time: Option<Duration>)
Set that all sockets have SO_KEEPALIVE
set with the supplied duration
to remain idle before sending TCP keepalive probes.
If None
, keepalive is disabled.
Default is None
.
Sourcepub fn set_keepalive_interval(&mut self, interval: Option<Duration>)
pub fn set_keepalive_interval(&mut self, interval: Option<Duration>)
Set the duration between two successive TCP keepalive retransmissions, if acknowledgement to the previous keepalive transmission is not received.
Sourcepub fn set_keepalive_retries(&mut self, retries: Option<u32>)
pub fn set_keepalive_retries(&mut self, retries: Option<u32>)
Set the number of retransmissions to be carried out before declaring that remote end is not available.
Sourcepub fn set_nodelay(&mut self, nodelay: bool)
pub fn set_nodelay(&mut self, nodelay: bool)
Set that all sockets have SO_NODELAY
set to the supplied value nodelay
.
Default is false
.
Sourcepub fn set_send_buffer_size(&mut self, size: Option<usize>)
pub fn set_send_buffer_size(&mut self, size: Option<usize>)
Sets the value of the SO_SNDBUF option on the socket.
Sourcepub fn set_recv_buffer_size(&mut self, size: Option<usize>)
pub fn set_recv_buffer_size(&mut self, size: Option<usize>)
Sets the value of the SO_RCVBUF option on the socket.
Sourcepub fn set_local_address(&mut self, addr: Option<IpAddr>)
pub fn set_local_address(&mut self, addr: Option<IpAddr>)
Set that all sockets are bound to the configured address before connection.
If None
, the sockets will not be bound.
Default is None
.
Sourcepub fn set_local_addresses(&mut self, addr_ipv4: Ipv4Addr, addr_ipv6: Ipv6Addr)
pub fn set_local_addresses(&mut self, addr_ipv4: Ipv4Addr, addr_ipv6: Ipv6Addr)
Set that all sockets are bound to the configured IPv4 or IPv6 address (depending on host’s preferences) before connection.
Sourcepub fn set_connect_timeout(&mut self, dur: Option<Duration>)
pub fn set_connect_timeout(&mut self, dur: Option<Duration>)
Set the connect timeout.
If a domain resolves to multiple IP addresses, the timeout will be evenly divided across them.
Default is None
.
Sourcepub fn set_happy_eyeballs_timeout(&mut self, dur: Option<Duration>)
pub fn set_happy_eyeballs_timeout(&mut self, dur: Option<Duration>)
Set timeout for RFC 6555 (Happy Eyeballs) algorithm.
If hostname resolves to both IPv4 and IPv6 addresses and connection cannot be established using preferred address family before timeout elapses, then connector will in parallel attempt connection using other address family.
If None
, parallel connection attempts are disabled.
Default is 300 milliseconds.
Sourcepub fn set_reuse_address(&mut self, reuse_address: bool) -> &mut Self
pub fn set_reuse_address(&mut self, reuse_address: bool) -> &mut Self
Set that all socket have SO_REUSEADDR
set to the supplied value reuse_address
.
Default is false
.
Sourcepub fn set_interface<S: Into<String>>(&mut self, interface: S) -> &mut Self
Available on Android or Fuchsia or Linux only.
pub fn set_interface<S: Into<String>>(&mut self, interface: S) -> &mut Self
Sets the value for the SO_BINDTODEVICE
option on this socket.
If a socket is bound to an interface, only packets received from that particular interface are processed by the socket. Note that this only works for some socket types, particularly AF_INET sockets.
On Linux it can be used to specify a VRF, but the binary needs
to either have CAP_NET_RAW
or to be run as root.
This function is only available on Android、Fuchsia and Linux.
Sourcepub fn set_tcp_user_timeout(&mut self, time: Option<Duration>)
Available on Android or Fuchsia or Linux only.
pub fn set_tcp_user_timeout(&mut self, time: Option<Duration>)
Sets the value of the TCP_USER_TIMEOUT option on the socket.
Trait Implementations§
Source§impl<R: Clone> Clone for HttpConnector<R>
impl<R: Clone> Clone for HttpConnector<R>
Source§fn clone(&self) -> HttpConnector<R>
fn clone(&self) -> HttpConnector<R>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl<R: Debug> Debug for HttpConnector<R>
impl<R: Debug> Debug for HttpConnector<R>
Auto Trait Implementations§
impl<R> Freeze for HttpConnector<R>where
R: Freeze,
impl<R> RefUnwindSafe for HttpConnector<R>where
R: RefUnwindSafe,
impl<R> Send for HttpConnector<R>where
R: Send,
impl<R> Sync for HttpConnector<R>where
R: Sync,
impl<R> Unpin for HttpConnector<R>where
R: Unpin,
impl<R> UnwindSafe for HttpConnector<R>where
R: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.