1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
//! Contains the asynchronous websocket client. //! //! The async client is simply a `Stream + Sink` of `OwnedMessage` structs. //! This definition means that you don't have to learn any new APIs other than //! futures-rs. //! The client simply wraps around an `AsyncRead + AsyncWrite` stream and uses //! a `MessageCodec` to chop up the bytes into websocket messages. //! See the `codec` module for all the cool codecs this crate has. //! //! Since this is all asynchronous, you will not create a client from `ClientBuilder` //! but instead you will create a `ClientNew` struct, which is a Future that //! will eventually evaluate to a `Client`. //! //! # Example with Type Annotations //! //! ```rust,no_run //! # extern crate tokio; //! # extern crate futures; //! # extern crate websocket; //! use websocket::ClientBuilder; //! use websocket::async::client::{Client, ClientNew}; //! use websocket::async::TcpStream; //! use websocket::futures::{Future, Stream, Sink}; //! use websocket::Message; //! use tokio::runtime::Builder; //! # fn main() { //! //! let mut runtime = Builder::new().build().unwrap(); //! //! // create a Future of a client //! let client_future: ClientNew<TcpStream> = //! ClientBuilder::new("ws://echo.websocket.org").unwrap() //! .async_connect_insecure(); //! //! // send a message //! let send_future = client_future //! .and_then(|(client, headers)| { //! // just to make it clear what type this is //! let client: Client<TcpStream> = client; //! client.send(Message::text("hallo").into()) //! }); //! //! runtime.block_on(send_future).unwrap(); //! # } //! ``` pub use futures::Future; use hyper::header::Headers; pub use tokio_codec::Framed; pub use tokio_reactor::Handle; pub use tokio_tcp::TcpStream; use codec::ws::MessageCodec; use message::OwnedMessage; use result::WebSocketError; #[cfg(feature = "async-ssl")] pub use tokio_tls::TlsStream; /// An asynchronous websocket client. /// /// This is simply a `Stream` and `Sink` of `OwnedMessage`s. /// See the docs for `Stream` and `Sink` to learn more about how to use /// these futures. pub type Client<S> = Framed<S, MessageCodec<OwnedMessage>>; /// A future which will evaluate to a `Client` and a set of hyper `Headers`. /// /// The `Client` can send and receive websocket messages, and the Headers are /// the headers that came back from the server handshake. /// If the user used a protocol or attached some other headers check these response /// headers to see if the server accepted the protocol or other custom header. /// This crate will not automatically close the connection if the server refused /// to use the user protocols given to it, you must check that the server accepted. pub type ClientNew<S> = Box<Future<Item = (Client<S>, Headers), Error = WebSocketError> + Send>;