hickory_proto/rustls/
tls_client_stream.rsuse std::future::Future;
use std::io;
use std::net::SocketAddr;
use std::pin::Pin;
use std::sync::Arc;
use futures_util::TryFutureExt;
use rustls::ClientConfig;
use crate::error::ProtoError;
use crate::runtime::iocompat::{AsyncIoStdAsTokio, AsyncIoTokioAsStd};
use crate::runtime::RuntimeProvider;
use crate::rustls::tls_stream::{tls_connect_with_bind_addr, tls_connect_with_future};
use crate::tcp::{DnsTcpStream, TcpClientStream};
use crate::xfer::BufDnsStreamHandle;
pub type TlsClientStream<S> =
TcpClientStream<AsyncIoTokioAsStd<tokio_rustls::client::TlsStream<AsyncIoStdAsTokio<S>>>>;
#[allow(clippy::type_complexity)]
pub fn tls_client_connect<P: RuntimeProvider>(
name_server: SocketAddr,
dns_name: String,
client_config: Arc<ClientConfig>,
provider: P,
) -> (
Pin<Box<dyn Future<Output = Result<TlsClientStream<P::Tcp>, ProtoError>> + Send + Unpin>>,
BufDnsStreamHandle,
) {
tls_client_connect_with_bind_addr(name_server, None, dns_name, client_config, provider)
}
#[allow(clippy::type_complexity)]
pub fn tls_client_connect_with_bind_addr<P: RuntimeProvider>(
name_server: SocketAddr,
bind_addr: Option<SocketAddr>,
dns_name: String,
client_config: Arc<ClientConfig>,
provider: P,
) -> (
Pin<Box<dyn Future<Output = Result<TlsClientStream<P::Tcp>, ProtoError>> + Send + Unpin>>,
BufDnsStreamHandle,
) {
let (stream_future, sender) =
tls_connect_with_bind_addr(name_server, bind_addr, dns_name, client_config, provider);
let new_future = Box::pin(
stream_future
.map_ok(TcpClientStream::from_stream)
.map_err(ProtoError::from),
);
(new_future, sender)
}
#[allow(clippy::type_complexity)]
pub fn tls_client_connect_with_future<S, F>(
future: F,
socket_addr: SocketAddr,
dns_name: String,
client_config: Arc<ClientConfig>,
) -> (
Pin<Box<dyn Future<Output = Result<TlsClientStream<S>, ProtoError>> + Send + Unpin>>,
BufDnsStreamHandle,
)
where
S: DnsTcpStream,
F: Future<Output = io::Result<S>> + Send + Unpin + 'static,
{
let (stream_future, sender) =
tls_connect_with_future(future, socket_addr, dns_name, client_config);
let new_future = Box::pin(
stream_future
.map_ok(TcpClientStream::from_stream)
.map_err(ProtoError::from),
);
(new_future, sender)
}