#![deny(missing_docs)]
use amq_protocol_uri::{AMQPScheme, AMQPUri};
use std::time::Duration;
use tracing::trace;
pub use tcp_stream::{
HandshakeError, HandshakeResult, Identity, MidHandshakeTlsStream, OwnedIdentity,
OwnedTLSConfig, TLSConfig, TcpStream,
};
#[cfg(feature = "native-tls")]
pub use tcp_stream::NativeTlsConnector;
#[cfg(feature = "openssl")]
pub use tcp_stream::OpenSslConnector;
#[cfg(feature = "rustls-connector")]
pub use tcp_stream::{RustlsConnector, RustlsConnectorConfig};
pub trait AMQPUriTcpExt {
fn connect(&self) -> HandshakeResult
where
Self: Sized,
{
self.connect_with_config(TLSConfig::default())
}
fn connect_with_config(&self, config: TLSConfig<'_, '_, '_>) -> HandshakeResult;
}
impl AMQPUriTcpExt for AMQPUri {
fn connect_with_config(&self, config: TLSConfig<'_, '_, '_>) -> HandshakeResult {
let uri = format!("{}:{}", self.authority.host, self.authority.port);
trace!(uri = %uri, "Connecting.");
let stream = if let Some(timeout) = self.query.connection_timeout {
TcpStream::connect_timeout(uri, Duration::from_millis(timeout))
} else {
TcpStream::connect(uri)
}?;
let stream = match self.scheme {
AMQPScheme::AMQP => stream,
AMQPScheme::AMQPS => stream.into_tls(&self.authority.host, config)?,
};
stream.set_nonblocking(true)?;
Ok(stream)
}
}