Replace redundant `Request` structure

Let's reuse the corresponding structure from tungstenite.
pull/1/head
Daniel Abramov 8 years ago
parent 760a840392
commit f9c3948c51
  1. 6
      Cargo.toml
  2. 44
      src/lib.rs

@ -19,10 +19,10 @@ stream = ["bytes"]
[dependencies] [dependencies]
futures = "0.1.14" futures = "0.1.14"
tokio-io = "0.1.2" tokio-io = "0.1.2"
url = "1.5.1"
[dependencies.tungstenite] [dependencies.tungstenite]
version = "0.4.0" git = "https://github.com/snapview/tungstenite-rs.git"
branch = "request_minor"
default-features = false default-features = false
[dependencies.bytes] [dependencies.bytes]
@ -47,4 +47,4 @@ version = "0.1.3"
[dev-dependencies] [dev-dependencies]
tokio-core = "0.1.9" tokio-core = "0.1.9"
url = "1.5.1"

@ -18,7 +18,6 @@
extern crate futures; extern crate futures;
extern crate tokio_io; extern crate tokio_io;
extern crate tungstenite; extern crate tungstenite;
extern crate url;
#[cfg(feature="connect")] #[cfg(feature="connect")]
mod connect; mod connect;
@ -31,9 +30,7 @@ use std::io::ErrorKind;
use futures::{Poll, Future, Async, AsyncSink, Stream, Sink, StartSend}; use futures::{Poll, Future, Async, AsyncSink, Stream, Sink, StartSend};
use tokio_io::{AsyncRead, AsyncWrite}; use tokio_io::{AsyncRead, AsyncWrite};
use url::Url; use tungstenite::handshake::client::{ClientHandshake, Response, Request};
use tungstenite::handshake::client::{ClientHandshake, Response};
use tungstenite::handshake::server::{ServerHandshake, Callback}; use tungstenite::handshake::server::{ServerHandshake, Callback};
use tungstenite::handshake::{HandshakeRole, HandshakeError}; use tungstenite::handshake::{HandshakeRole, HandshakeError};
use tungstenite::protocol::{WebSocket, Message}; use tungstenite::protocol::{WebSocket, Message};
@ -43,37 +40,6 @@ use tungstenite::server;
#[cfg(feature="connect")] #[cfg(feature="connect")]
pub use connect::connect_async; pub use connect::connect_async;
/// A WebSocket request
pub struct Request<'a> {
/// URL of the request.
pub url: Url,
/// Extra headers, if any.
pub headers: Vec<(&'a str, &'a str)>,
}
impl<'a> Request<'a> {
/// Constructs a new WebSocket request with a URL or URL string
pub fn new<U: Into<Url>>(url: U) -> Self {
Request{url: url.into(), headers: vec![]}
}
/// Adds a WebSocket protocol to the request
pub fn add_protocol(&mut self, protocol: &'a str) {
self.headers.push(("Sec-WebSocket-Protocol", protocol));
}
/// Adds a custom header to the request
pub fn add_header(&mut self, name: &'a str, value: &'a str) {
self.headers.push((name, value));
}
}
impl<'a, U: Into<Url>> From<U> for Request<'a> {
fn from(u: U) -> Request<'a> {
Request::new(u)
}
}
/// Creates a WebSocket handshake from a request and a stream. /// Creates a WebSocket handshake from a request and a stream.
/// For convenience, the user may call this with a url string, a URL, /// For convenience, the user may call this with a url string, a URL,
/// or a `Request`. Calling with `Request` allows the user to add /// or a `Request`. Calling with `Request` allows the user to add
@ -91,15 +57,9 @@ where
R: Into<Request<'a>>, R: Into<Request<'a>>,
S: AsyncRead + AsyncWrite S: AsyncRead + AsyncWrite
{ {
let Request{ url, headers } = request.into();
let tungstenite_request = {
tungstenite::handshake::client::Request { url, extra_headers: Some(&headers) }
};
let handshake = ClientHandshake::start(stream, tungstenite_request).handshake();
ConnectAsync { ConnectAsync {
inner: MidHandshake { inner: MidHandshake {
inner: Some(handshake) inner: Some(ClientHandshake::start(stream, request.into()).handshake())
} }
} }
} }

Loading…
Cancel
Save