mirror of
https://github.com/actix/actix-web.git
synced 2025-01-05 06:48:44 +00:00
Add ability to pass a custom TlsConnector (#491)
This commit is contained in:
parent
5906971b6d
commit
4bab50c861
1 changed files with 68 additions and 149 deletions
|
@ -17,14 +17,16 @@ use tokio_io::{AsyncRead, AsyncWrite};
|
||||||
use tokio_timer::Delay;
|
use tokio_timer::Delay;
|
||||||
|
|
||||||
#[cfg(feature = "alpn")]
|
#[cfg(feature = "alpn")]
|
||||||
use openssl::ssl::{Error as OpensslError, SslConnector, SslMethod};
|
use {
|
||||||
#[cfg(feature = "alpn")]
|
openssl::ssl::{Error as SslError, SslConnector, SslMethod},
|
||||||
use tokio_openssl::SslConnectorExt;
|
tokio_openssl::SslConnectorExt
|
||||||
|
};
|
||||||
|
|
||||||
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
||||||
use native_tls::{Error as TlsError, TlsConnector as NativeTlsConnector};
|
use {
|
||||||
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
native_tls::{Error as SslError, TlsConnector as NativeTlsConnector},
|
||||||
use tokio_tls::{TlsConnector};
|
tokio_tls::TlsConnector as SslConnector
|
||||||
|
};
|
||||||
|
|
||||||
#[cfg(
|
#[cfg(
|
||||||
all(
|
all(
|
||||||
|
@ -32,42 +34,25 @@ use tokio_tls::{TlsConnector};
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
not(any(feature = "alpn", feature = "tls"))
|
||||||
)
|
)
|
||||||
)]
|
)]
|
||||||
use rustls::ClientConfig;
|
use {
|
||||||
|
rustls::ClientConfig,
|
||||||
|
std::io::Error as SslError,
|
||||||
|
std::sync::Arc,
|
||||||
|
tokio_rustls::ClientConfigExt,
|
||||||
|
webpki::DNSNameRef,
|
||||||
|
webpki_roots,
|
||||||
|
};
|
||||||
|
|
||||||
#[cfg(
|
#[cfg(
|
||||||
all(
|
all(
|
||||||
feature = "rust-tls",
|
feature = "rust-tls",
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
not(any(feature = "alpn", feature = "tls"))
|
||||||
)
|
)
|
||||||
)]
|
)]
|
||||||
use std::io::Error as TLSError;
|
type SslConnector = Arc<ClientConfig>;
|
||||||
#[cfg(
|
|
||||||
all(
|
#[cfg(not(any(feature = "alpn", feature = "tls", feature = "rust-tls")))]
|
||||||
feature = "rust-tls",
|
type SslConnector = ();
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
use std::sync::Arc;
|
|
||||||
#[cfg(
|
|
||||||
all(
|
|
||||||
feature = "rust-tls",
|
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
use tokio_rustls::ClientConfigExt;
|
|
||||||
#[cfg(
|
|
||||||
all(
|
|
||||||
feature = "rust-tls",
|
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
use webpki::DNSNameRef;
|
|
||||||
#[cfg(
|
|
||||||
all(
|
|
||||||
feature = "rust-tls",
|
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
use webpki_roots;
|
|
||||||
|
|
||||||
use server::IoStream;
|
use server::IoStream;
|
||||||
use {HAS_OPENSSL, HAS_RUSTLS, HAS_TLS};
|
use {HAS_OPENSSL, HAS_RUSTLS, HAS_TLS};
|
||||||
|
@ -173,24 +158,9 @@ pub enum ClientConnectorError {
|
||||||
SslIsNotSupported,
|
SslIsNotSupported,
|
||||||
|
|
||||||
/// SSL error
|
/// SSL error
|
||||||
#[cfg(feature = "alpn")]
|
#[cfg(any(feature = "tls", feature = "alpn", feature = "rust-tls"))]
|
||||||
#[fail(display = "{}", _0)]
|
#[fail(display = "{}", _0)]
|
||||||
SslError(#[cause] OpensslError),
|
SslError(#[cause] SslError),
|
||||||
|
|
||||||
/// SSL error
|
|
||||||
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
|
||||||
#[fail(display = "{}", _0)]
|
|
||||||
SslError(#[cause] TlsError),
|
|
||||||
|
|
||||||
/// SSL error
|
|
||||||
#[cfg(
|
|
||||||
all(
|
|
||||||
feature = "rust-tls",
|
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
#[fail(display = "{}", _0)]
|
|
||||||
SslError(#[cause] TLSError),
|
|
||||||
|
|
||||||
/// Resolver error
|
/// Resolver error
|
||||||
#[fail(display = "{}", _0)]
|
#[fail(display = "{}", _0)]
|
||||||
|
@ -242,17 +212,7 @@ impl Paused {
|
||||||
/// `ClientConnector` type is responsible for transport layer of a
|
/// `ClientConnector` type is responsible for transport layer of a
|
||||||
/// client connection.
|
/// client connection.
|
||||||
pub struct ClientConnector {
|
pub struct ClientConnector {
|
||||||
#[cfg(all(feature = "alpn"))]
|
|
||||||
connector: SslConnector,
|
connector: SslConnector,
|
||||||
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
|
||||||
connector: TlsConnector,
|
|
||||||
#[cfg(
|
|
||||||
all(
|
|
||||||
feature = "rust-tls",
|
|
||||||
not(any(feature = "alpn", feature = "tls"))
|
|
||||||
)
|
|
||||||
)]
|
|
||||||
connector: Arc<ClientConfig>,
|
|
||||||
|
|
||||||
stats: ClientConnectorStats,
|
stats: ClientConnectorStats,
|
||||||
subscriber: Option<Recipient<ClientConnectorStats>>,
|
subscriber: Option<Recipient<ClientConnectorStats>>,
|
||||||
|
@ -293,35 +253,13 @@ impl SystemService for ClientConnector {}
|
||||||
|
|
||||||
impl Default for ClientConnector {
|
impl Default for ClientConnector {
|
||||||
fn default() -> ClientConnector {
|
fn default() -> ClientConnector {
|
||||||
|
let connector = {
|
||||||
#[cfg(all(feature = "alpn"))]
|
#[cfg(all(feature = "alpn"))]
|
||||||
{
|
{ SslConnector::builder(SslMethod::tls()).unwrap().build() }
|
||||||
let builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
||||||
ClientConnector::with_connector(builder.build())
|
|
||||||
}
|
|
||||||
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
#[cfg(all(feature = "tls", not(feature = "alpn")))]
|
||||||
{
|
{ NativeTlsConnector::builder().build().unwrap().into() }
|
||||||
let (tx, rx) = mpsc::unbounded();
|
|
||||||
let builder = NativeTlsConnector::builder();
|
|
||||||
ClientConnector {
|
|
||||||
stats: ClientConnectorStats::default(),
|
|
||||||
subscriber: None,
|
|
||||||
acq_tx: tx,
|
|
||||||
acq_rx: Some(rx),
|
|
||||||
resolver: None,
|
|
||||||
connector: builder.build().unwrap().into(),
|
|
||||||
conn_lifetime: Duration::from_secs(75),
|
|
||||||
conn_keep_alive: Duration::from_secs(15),
|
|
||||||
limit: 100,
|
|
||||||
limit_per_host: 0,
|
|
||||||
acquired: 0,
|
|
||||||
acquired_per_host: HashMap::new(),
|
|
||||||
available: HashMap::new(),
|
|
||||||
to_close: Vec::new(),
|
|
||||||
waiters: Some(HashMap::new()),
|
|
||||||
wait_timeout: None,
|
|
||||||
paused: Paused::No,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#[cfg(
|
#[cfg(
|
||||||
all(
|
all(
|
||||||
feature = "rust-tls",
|
feature = "rust-tls",
|
||||||
|
@ -333,31 +271,14 @@ impl Default for ClientConnector {
|
||||||
config
|
config
|
||||||
.root_store
|
.root_store
|
||||||
.add_server_trust_anchors(&webpki_roots::TLS_SERVER_ROOTS);
|
.add_server_trust_anchors(&webpki_roots::TLS_SERVER_ROOTS);
|
||||||
ClientConnector::with_connector(config)
|
Arc::new(config)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(any(feature = "alpn", feature = "tls", feature = "rust-tls")))]
|
#[cfg(not(any(feature = "alpn", feature = "tls", feature = "rust-tls")))]
|
||||||
{
|
{ () }
|
||||||
let (tx, rx) = mpsc::unbounded();
|
};
|
||||||
ClientConnector {
|
|
||||||
stats: ClientConnectorStats::default(),
|
ClientConnector::with_connector_impl(connector)
|
||||||
subscriber: None,
|
|
||||||
acq_tx: tx,
|
|
||||||
acq_rx: Some(rx),
|
|
||||||
resolver: None,
|
|
||||||
conn_lifetime: Duration::from_secs(75),
|
|
||||||
conn_keep_alive: Duration::from_secs(15),
|
|
||||||
limit: 100,
|
|
||||||
limit_per_host: 0,
|
|
||||||
acquired: 0,
|
|
||||||
acquired_per_host: HashMap::new(),
|
|
||||||
available: HashMap::new(),
|
|
||||||
to_close: Vec::new(),
|
|
||||||
waiters: Some(HashMap::new()),
|
|
||||||
wait_timeout: None,
|
|
||||||
paused: Paused::No,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -402,27 +323,8 @@ impl ClientConnector {
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn with_connector(connector: SslConnector) -> ClientConnector {
|
pub fn with_connector(connector: SslConnector) -> ClientConnector {
|
||||||
let (tx, rx) = mpsc::unbounded();
|
// keep level of indirection for docstrings matching featureflags
|
||||||
|
Self::with_connector_impl(connector)
|
||||||
ClientConnector {
|
|
||||||
connector,
|
|
||||||
stats: ClientConnectorStats::default(),
|
|
||||||
subscriber: None,
|
|
||||||
acq_tx: tx,
|
|
||||||
acq_rx: Some(rx),
|
|
||||||
resolver: None,
|
|
||||||
conn_lifetime: Duration::from_secs(75),
|
|
||||||
conn_keep_alive: Duration::from_secs(15),
|
|
||||||
limit: 100,
|
|
||||||
limit_per_host: 0,
|
|
||||||
acquired: 0,
|
|
||||||
acquired_per_host: HashMap::new(),
|
|
||||||
available: HashMap::new(),
|
|
||||||
to_close: Vec::new(),
|
|
||||||
waiters: Some(HashMap::new()),
|
|
||||||
wait_timeout: None,
|
|
||||||
paused: Paused::No,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(
|
#[cfg(
|
||||||
|
@ -476,10 +378,27 @@ impl ClientConnector {
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn with_connector(connector: ClientConfig) -> ClientConnector {
|
pub fn with_connector(connector: ClientConfig) -> ClientConnector {
|
||||||
|
// keep level of indirection for docstrings matching featureflags
|
||||||
|
Self::with_connector_impl(Arc::new(connector))
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(
|
||||||
|
all(
|
||||||
|
feature = "tls",
|
||||||
|
not(any(feature = "alpn", feature = "rust-tls"))
|
||||||
|
)
|
||||||
|
)]
|
||||||
|
pub fn with_connector(connector: SslConnector) -> ClientConnector {
|
||||||
|
// keep level of indirection for docstrings matching featureflags
|
||||||
|
Self::with_connector_impl(connector)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn with_connector_impl(connector: SslConnector) -> ClientConnector {
|
||||||
let (tx, rx) = mpsc::unbounded();
|
let (tx, rx) = mpsc::unbounded();
|
||||||
|
|
||||||
ClientConnector {
|
ClientConnector {
|
||||||
connector: Arc::new(connector),
|
connector,
|
||||||
stats: ClientConnectorStats::default(),
|
stats: ClientConnectorStats::default(),
|
||||||
subscriber: None,
|
subscriber: None,
|
||||||
acq_tx: tx,
|
acq_tx: tx,
|
||||||
|
|
Loading…
Reference in a new issue