pub trait ConfigExt: Sealed {
    // Required methods
    fn base_uri_layer(&self) -> BaseUriLayer;
    fn auth_layer(&self) -> Result<Option<AuthLayer>>;
    fn extra_headers_layer(&self) -> Result<ExtraHeadersLayer>;
    fn rustls_https_connector(&self) -> Result<HttpsConnector<HttpConnector>>;
    fn rustls_https_connector_with_connector(
        &self,
        connector: HttpConnector
    ) -> Result<HttpsConnector<HttpConnector>>;
    fn rustls_client_config(&self) -> Result<ClientConfig>;
    fn openssl_https_connector(&self) -> Result<HttpsConnector<HttpConnector>>;
    fn openssl_https_connector_with_connector(
        &self,
        connector: HttpConnector
    ) -> Result<HttpsConnector<HttpConnector>>;
    fn openssl_ssl_connector_builder(&self) -> Result<SslConnectorBuilder>;
}
Available on crate feature client only.
Expand description

Extensions to Config for custom Client.

See Client::new for an example.

This trait is sealed and cannot be implemented.

Required Methods§

source

fn base_uri_layer(&self) -> BaseUriLayer

Layer to set the base URI of requests to the configured server.

source

fn auth_layer(&self) -> Result<Option<AuthLayer>>

Optional layer to set up Authorization header depending on the config.

source

fn extra_headers_layer(&self) -> Result<ExtraHeadersLayer>

Layer to add non-authn HTTP headers depending on the config.

source

fn rustls_https_connector(&self) -> Result<HttpsConnector<HttpConnector>>

Available on crate feature rustls-tls only.

Create hyper_rustls::HttpsConnector based on config.

Example
let config = Config::infer().await?;
let https = config.rustls_https_connector()?;
let hyper_client: hyper::Client<_, hyper::Body> = hyper::Client::builder().build(https);
source

fn rustls_https_connector_with_connector( &self, connector: HttpConnector ) -> Result<HttpsConnector<HttpConnector>>

Available on crate feature rustls-tls only.

Create hyper_rustls::HttpsConnector based on config and connector.

Example
let config = Config::infer().await?;
let mut connector = HttpConnector::new();
connector.enforce_http(false);
let https = config.rustls_https_connector_with_connector(connector)?;
let hyper_client: hyper::Client<_, hyper::Body> = hyper::Client::builder().build(https);
source

fn rustls_client_config(&self) -> Result<ClientConfig>

Available on crate feature rustls-tls only.

Create rustls::ClientConfig based on config.

Example
let config = Config::infer().await?;
let https = {
    let rustls_config = std::sync::Arc::new(config.rustls_client_config()?);
    let mut http = HttpConnector::new();
    http.enforce_http(false);
    hyper_rustls::HttpsConnector::from((http, rustls_config))
};
source

fn openssl_https_connector(&self) -> Result<HttpsConnector<HttpConnector>>

Available on crate feature openssl-tls only.

Create hyper_openssl::HttpsConnector based on config.

Example
let config = Config::infer().await?;
let https = config.openssl_https_connector()?;
source

fn openssl_https_connector_with_connector( &self, connector: HttpConnector ) -> Result<HttpsConnector<HttpConnector>>

Available on crate feature openssl-tls only.

Create hyper_openssl::HttpsConnector based on config and connector.

Example
let mut http = HttpConnector::new();
http.enforce_http(false);
let config = Config::infer().await?;
let https = config.openssl_https_connector_with_connector(http)?;
source

fn openssl_ssl_connector_builder(&self) -> Result<SslConnectorBuilder>

Available on crate feature openssl-tls only.

Create openssl::ssl::SslConnectorBuilder based on config.

Example
let config = Config::infer().await?;
let https = {
    let mut http = HttpConnector::new();
    http.enforce_http(false);
    let ssl = config.openssl_ssl_connector_builder()?;
    hyper_openssl::HttpsConnector::with_connector(http, ssl)?
};

Implementors§