mirror of
https://github.com/actix/actix-web.git
synced 2025-01-17 04:35:57 +00:00
update actix connect
This commit is contained in:
parent
1941aa0217
commit
033a8d890c
4 changed files with 30 additions and 28 deletions
|
@ -40,8 +40,7 @@ fail = ["failure"]
|
|||
[dependencies]
|
||||
actix-service = "0.3.4"
|
||||
actix-codec = "0.1.1"
|
||||
#actix-connector = "0.3.0"
|
||||
actix-connect = { path="../actix-net/actix-connect" }
|
||||
actix-connect = { git = "https://github.com/actix/actix-net.git" }
|
||||
actix-utils = "0.3.4"
|
||||
actix-server-config = "0.1.0"
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
use actix_connect::Address;
|
||||
use http::uri::Uri;
|
||||
use http::HttpTryFrom;
|
||||
|
||||
|
@ -53,12 +54,14 @@ impl Connect {
|
|||
Ok(())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub(crate) fn host(&self) -> &str {
|
||||
impl Address for Connect {
|
||||
fn host(&self) -> &str {
|
||||
&self.uri.host().unwrap()
|
||||
}
|
||||
|
||||
pub(crate) fn port(&self) -> u16 {
|
||||
fn port(&self) -> u16 {
|
||||
if let Some(port) = self.uri.port() {
|
||||
port
|
||||
} else if let Some(scheme) = self.uri.scheme_part() {
|
||||
|
|
|
@ -3,7 +3,9 @@ use std::marker::PhantomData;
|
|||
use std::time::Duration;
|
||||
|
||||
use actix_codec::{AsyncRead, AsyncWrite};
|
||||
use actix_connect::{default_connector, Stream};
|
||||
use actix_connect::{
|
||||
default_connector, Connect as TcpConnect, Connection as TcpConnection,
|
||||
};
|
||||
use actix_service::{apply_fn, Service, ServiceExt};
|
||||
use actix_utils::timeout::{TimeoutError, TimeoutService};
|
||||
use tokio_tcp::TcpStream;
|
||||
|
@ -36,8 +38,8 @@ pub struct Connector<T, U> {
|
|||
impl Connector<(), ()> {
|
||||
pub fn new() -> Connector<
|
||||
impl Service<
|
||||
Request = actix_connect::Connect,
|
||||
Response = Stream<TcpStream>,
|
||||
Request = TcpConnect<Connect>,
|
||||
Response = TcpConnection<Connect, TcpStream>,
|
||||
Error = actix_connect::ConnectError,
|
||||
> + Clone,
|
||||
TcpStream,
|
||||
|
@ -77,8 +79,8 @@ impl<T, U> Connector<T, U> {
|
|||
where
|
||||
U1: AsyncRead + AsyncWrite + fmt::Debug,
|
||||
T1: Service<
|
||||
Request = actix_connect::Connect,
|
||||
Response = Stream<U1>,
|
||||
Request = TcpConnect<Connect>,
|
||||
Response = TcpConnection<Connect, U1>,
|
||||
Error = actix_connect::ConnectError,
|
||||
> + Clone,
|
||||
{
|
||||
|
@ -99,8 +101,8 @@ impl<T, U> Connector<T, U>
|
|||
where
|
||||
U: AsyncRead + AsyncWrite + fmt::Debug + 'static,
|
||||
T: Service<
|
||||
Request = actix_connect::Connect,
|
||||
Response = Stream<U>,
|
||||
Request = TcpConnect<Connect>,
|
||||
Response = TcpConnection<Connect, U>,
|
||||
Error = actix_connect::ConnectError,
|
||||
> + Clone,
|
||||
{
|
||||
|
@ -170,8 +172,10 @@ where
|
|||
{
|
||||
let connector = TimeoutService::new(
|
||||
self.timeout,
|
||||
self.connector
|
||||
.map(|stream| (stream.into_parts().0, Protocol::Http1)),
|
||||
apply_fn(self.connector, |msg: Connect, srv| {
|
||||
srv.call(actix_connect::Connect::with_request(msg))
|
||||
})
|
||||
.map(|stream| (stream.into_parts().0, Protocol::Http1)),
|
||||
)
|
||||
.map_err(|e| match e {
|
||||
TimeoutError::Service(e) => e,
|
||||
|
@ -196,7 +200,7 @@ where
|
|||
let ssl_service = TimeoutService::new(
|
||||
self.timeout,
|
||||
apply_fn(self.connector.clone(), |msg: Connect, srv| {
|
||||
srv.call(actix_connect::Connect::new(msg.host(), msg.port()))
|
||||
srv.call(actix_connect::Connect::with_request(msg))
|
||||
})
|
||||
.map_err(ConnectError::from)
|
||||
.and_then(
|
||||
|
@ -226,7 +230,7 @@ where
|
|||
let tcp_service = TimeoutService::new(
|
||||
self.timeout,
|
||||
apply_fn(self.connector.clone(), |msg: Connect, srv| {
|
||||
srv.call(actix_connect::Connect::new(msg.host(), msg.port()))
|
||||
srv.call(actix_connect::Connect::with_request(msg))
|
||||
})
|
||||
.map_err(ConnectError::from)
|
||||
.map(|stream| (stream.into_parts().0, Protocol::Http1)),
|
||||
|
@ -267,11 +271,7 @@ mod connect_impl {
|
|||
pub(crate) struct InnerConnector<T, Io>
|
||||
where
|
||||
Io: AsyncRead + AsyncWrite + 'static,
|
||||
T: Service<
|
||||
Request = Connect,
|
||||
Response = (Connect, Io, Protocol),
|
||||
Error = ConnectorError,
|
||||
>,
|
||||
T: Service<Request = Connect, Response = (Io, Protocol), Error = ConnectorError>,
|
||||
{
|
||||
pub(crate) tcp_pool: ConnectionPool<T, Io>,
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
use std::marker::PhantomData;
|
||||
|
||||
use actix_codec::{AsyncRead, AsyncWrite, Framed};
|
||||
use actix_connect::{default_connector, Connect as TcpConnect, ConnectError};
|
||||
use actix_connect::{default_connector, Address, Connect as TcpConnect, ConnectError};
|
||||
use actix_service::{apply_fn, Service};
|
||||
use base64;
|
||||
use futures::future::{err, Either, FutureResult};
|
||||
|
@ -29,12 +29,12 @@ impl Client<()> {
|
|||
/// Create client with default connector.
|
||||
pub fn default() -> Client<
|
||||
impl Service<
|
||||
Request = TcpConnect,
|
||||
Request = TcpConnect<(String, u16)>,
|
||||
Response = impl AsyncRead + AsyncWrite,
|
||||
Error = ConnectError,
|
||||
> + Clone,
|
||||
> {
|
||||
Client::new(apply_fn(default_connector(), |msg: TcpConnect, srv| {
|
||||
Client::new(apply_fn(default_connector(), |msg: TcpConnect<_>, srv| {
|
||||
srv.call(msg).map(|stream| stream.into_parts().0)
|
||||
}))
|
||||
}
|
||||
|
@ -42,7 +42,7 @@ impl Client<()> {
|
|||
|
||||
impl<T> Client<T>
|
||||
where
|
||||
T: Service<Request = TcpConnect, Error = ConnectError>,
|
||||
T: Service<Request = TcpConnect<(String, u16)>, Error = ConnectError>,
|
||||
T::Response: AsyncRead + AsyncWrite,
|
||||
{
|
||||
/// Create new websocket's client factory
|
||||
|
@ -53,7 +53,7 @@ where
|
|||
|
||||
impl<T> Clone for Client<T>
|
||||
where
|
||||
T: Service<Request = TcpConnect, Error = ConnectError> + Clone,
|
||||
T: Service<Request = TcpConnect<(String, u16)>, Error = ConnectError> + Clone,
|
||||
T::Response: AsyncRead + AsyncWrite,
|
||||
{
|
||||
fn clone(&self) -> Self {
|
||||
|
@ -65,7 +65,7 @@ where
|
|||
|
||||
impl<T> Service for Client<T>
|
||||
where
|
||||
T: Service<Request = TcpConnect, Error = ConnectError>,
|
||||
T: Service<Request = TcpConnect<(String, u16)>, Error = ConnectError>,
|
||||
T::Response: AsyncRead + AsyncWrite + 'static,
|
||||
T::Future: 'static,
|
||||
{
|
||||
|
@ -130,8 +130,8 @@ where
|
|||
);
|
||||
|
||||
// prep connection
|
||||
let connect = TcpConnect::new(
|
||||
request.uri().host().unwrap(),
|
||||
let connect = TcpConnect::from_string(
|
||||
request.uri().host().unwrap().to_string(),
|
||||
request.uri().port().unwrap_or_else(|| proto.port()),
|
||||
);
|
||||
|
||||
|
|
Loading…
Reference in a new issue