#![deny(missing_docs)]
#![doc(html_root_url = "https://docs.rs/lapin-futures-openssl/0.5.4/")]
extern crate futures;
extern crate lapin_futures_tls_internal;
extern crate openssl;
extern crate tokio_openssl;
pub mod lapin;
pub mod uri;
pub type AMQPStream = lapin_futures_tls_internal::AMQPStream<SslStream<TcpStream>>;
use std::io;
use futures::future::Future;
use lapin_futures_tls_internal::{AMQPConnectionTlsExt, TcpStream};
use openssl::ssl::{SslConnector, SslMethod};
use tokio_openssl::{SslConnectorExt, SslStream};
use uri::AMQPUri;
fn connector(host: String, stream: TcpStream) -> Box<Future<Item = Box<SslStream<TcpStream>>, Error = io::Error> + Send + 'static> {
Box::new(futures::future::result(SslConnector::builder(SslMethod::tls()).map_err(|_| io::Error::new(io::ErrorKind::Other, "Failed to create connector"))).and_then(move |connector| {
connector.build().connect_async(&host, stream).map_err(|_| io::Error::new(io::ErrorKind::Other, "Failed to connect")).map(Box::new)
}))
}
pub trait AMQPConnectionOpensslExt<F: FnOnce(io::Error) + Send + 'static> : AMQPConnectionTlsExt<SslStream<TcpStream>, F> where Self: Sized {
fn connect(self, heartbeat_error_handler: F) -> Box<Future<Item = lapin::client::Client<AMQPStream>, Error = io::Error> + Send + 'static> {
AMQPConnectionTlsExt::connect(self, heartbeat_error_handler, connector)
}
fn connect_cancellable(self, heartbeat_error_handler: F) -> Box<Future<Item = (lapin::client::Client<AMQPStream>, lapin::client::HeartbeatHandle), Error = io::Error> + Send + 'static> {
AMQPConnectionTlsExt::connect_cancellable(self, heartbeat_error_handler, connector)
}
}
impl<F: FnOnce(io::Error) + Send + 'static> AMQPConnectionOpensslExt<F> for AMQPUri {}
impl<'a, F: FnOnce(io::Error) + Send + 'static> AMQPConnectionOpensslExt<F> for &'a str {}