Crate lapin_futures_openssl[][src]

lapin-futures-openssl

This library offers a nice integration of openssl with the lapin-futures library. It uses amq-protocol URI parsing feature and adds the connect and connect_cancellable methods to AMQPUri which will provide you with a lapin_futures::client::Client and optionally a lapin_futures::client::HeartbeatHandle wrapped in a Future.

It autodetects whether you're using amqp or amqps and opens either a raw TcpStream or a SslStream using openssl as the SSL engine.

Connecting and opening a channel

extern crate env_logger;
extern crate futures;
extern crate lapin_futures_openssl;
extern crate tokio;

use lapin_futures_openssl::lapin;

use futures::future::Future;
use lapin::channel::ConfirmSelectOptions;
use lapin_futures_openssl::AMQPConnectionOpensslExt;

fn main() {
    env_logger::init();

    tokio::run(
        "amqps://user:pass@host/vhost?heartbeat=10".connect_cancellable(|err| {
            eprintln!("heartbeat error: {:?}", err);
        }).and_then(|(client, heartbeat_handle)| {
            println!("Connected!");
            client.create_confirm_channel(ConfirmSelectOptions::default()).map(|channel| (channel, heartbeat_handle))
        }).and_then(|(channel, heartbeat_handle)| {
            println!("Stopping heartbeat.");
            heartbeat_handle.stop();
            println!("Closing channel.");
            channel.close(200, "Bye")
        }).map_err(|err| {
            eprintln!("amqp error: {:?}", err);
        })
    );
}

Modules

lapin

Reexport of the lapin_futures crate

uri

Reexport of the uri module from the amq_protocol crate

Enums

AMQPStream

Represents either a raw TcpStream or a SslStream backend by tokio-openssl. The SslStream is wrapped in a Box to keep the enum footprint minimal.

Traits

AMQPConnectionOpensslExt

Add a connect method providing a lapin_futures::client::Client wrapped in a Future.