mirror of
https://github.com/actix/actix-web.git
synced 2025-01-02 05:18:44 +00:00
Connector::Response returns addr and tcp stream
This commit is contained in:
parent
3dbaef3ec1
commit
c69d675113
4 changed files with 27 additions and 25 deletions
|
@ -43,7 +43,7 @@ fn main() {
|
|||
.unwrap();
|
||||
|
||||
let num = Arc::new(AtomicUsize::new(0));
|
||||
let openssl = ssl::OpensslService::new(builder);
|
||||
let openssl = ssl::OpensslAcceptor::new(builder);
|
||||
|
||||
// server start mutiple workers, it runs supplied `Fn` in each worker.
|
||||
Server::default()
|
||||
|
@ -51,7 +51,10 @@ fn main() {
|
|||
let num = num.clone();
|
||||
|
||||
// configure service
|
||||
openssl.clone().and_then((service, move || {
|
||||
openssl
|
||||
.clone()
|
||||
.map_err(|e| io::Error::new(io::ErrorKind::Other, e))
|
||||
.and_then((service, move || {
|
||||
Ok::<_, io::Error>(ServiceState { num: num.clone() })
|
||||
}))
|
||||
}).unwrap()
|
||||
|
|
|
@ -235,7 +235,7 @@ where
|
|||
pub struct AndThenNewConfigurableService<A, B, C>
|
||||
where
|
||||
A: NewConfigurableService<C>,
|
||||
B: NewConfigurableService<C>
|
||||
B: NewConfigurableService<C>,
|
||||
{
|
||||
a: A,
|
||||
b: B,
|
||||
|
@ -259,11 +259,7 @@ where
|
|||
|
||||
impl<A, B, C> NewConfigurableService<C> for AndThenNewConfigurableService<A, B, C>
|
||||
where
|
||||
A: NewConfigurableService<
|
||||
C,
|
||||
Response = B::Request,
|
||||
InitError = B::InitError,
|
||||
>,
|
||||
A: NewConfigurableService<C, Response = B::Request, InitError = B::InitError>,
|
||||
A::Error: Into<B::Error>,
|
||||
B: NewConfigurableService<C>,
|
||||
C: Clone,
|
||||
|
@ -359,7 +355,7 @@ where
|
|||
/// `MapErrNewService` new service combinator
|
||||
pub struct MapErrNewConfigurableService<A, F, E, C>
|
||||
where
|
||||
A: NewConfigurableService<C>
|
||||
A: NewConfigurableService<C>,
|
||||
{
|
||||
a: A,
|
||||
f: F,
|
||||
|
@ -455,7 +451,7 @@ where
|
|||
/// `MapInitErr` service combinator
|
||||
pub struct MapInitErr<A, F, E, C>
|
||||
where
|
||||
A: NewConfigurableService<C>
|
||||
A: NewConfigurableService<C>,
|
||||
{
|
||||
a: A,
|
||||
f: F,
|
||||
|
|
|
@ -51,7 +51,7 @@ impl Connector {
|
|||
|
||||
impl Service for Connector {
|
||||
type Request = String;
|
||||
type Response = TcpStream;
|
||||
type Response = (String, TcpStream);
|
||||
type Error = ConnectorError;
|
||||
type Future = ConnectorFuture;
|
||||
|
||||
|
@ -60,25 +60,32 @@ impl Service for Connector {
|
|||
}
|
||||
|
||||
fn call(&mut self, addr: String) -> Self::Future {
|
||||
let fut = ResolveFut::new(&addr, 0, &self.resolver);
|
||||
|
||||
ConnectorFuture {
|
||||
fut: ResolveFut::new(addr, 0, &self.resolver),
|
||||
fut,
|
||||
addr: Some(addr),
|
||||
fut2: None,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub struct ConnectorFuture {
|
||||
addr: Option<String>,
|
||||
fut: ResolveFut,
|
||||
fut2: Option<TcpConnector>,
|
||||
}
|
||||
|
||||
impl Future for ConnectorFuture {
|
||||
type Item = TcpStream;
|
||||
type Item = (String, TcpStream);
|
||||
type Error = ConnectorError;
|
||||
|
||||
fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
|
||||
if let Some(ref mut fut) = self.fut2 {
|
||||
return fut.poll();
|
||||
return match fut.poll()? {
|
||||
Async::Ready(stream) => Ok(Async::Ready((self.addr.take().unwrap(), stream))),
|
||||
Async::NotReady => Ok(Async::NotReady),
|
||||
};
|
||||
}
|
||||
match self.fut.poll()? {
|
||||
Async::Ready(addrs) => {
|
||||
|
@ -100,7 +107,7 @@ struct ResolveFut {
|
|||
}
|
||||
|
||||
impl ResolveFut {
|
||||
pub fn new(addr: String, port: u16, resolver: &AsyncResolver) -> Self {
|
||||
pub fn new(addr: &str, port: u16, resolver: &AsyncResolver) -> Self {
|
||||
// we need to do dns resolution
|
||||
match ResolveFut::parse(addr.as_ref(), port) {
|
||||
Ok((host, port)) => ResolveFut {
|
||||
|
|
|
@ -115,7 +115,7 @@ impl<T> Clone for OpensslConnector<T> {
|
|||
}
|
||||
|
||||
impl<T: AsyncRead + AsyncWrite> NewService for OpensslConnector<T> {
|
||||
type Request = T;
|
||||
type Request = (String, T);
|
||||
type Response = SslStream<T>;
|
||||
type Error = Error;
|
||||
type Service = OpensslConnectorService<T>;
|
||||
|
@ -130,17 +130,13 @@ impl<T: AsyncRead + AsyncWrite> NewService for OpensslConnector<T> {
|
|||
}
|
||||
}
|
||||
|
||||
pub trait OpensslDomain {
|
||||
fn domain(&self) -> &str;
|
||||
}
|
||||
|
||||
pub struct OpensslConnectorService<T> {
|
||||
connector: SslConnector,
|
||||
io: PhantomData<T>,
|
||||
}
|
||||
|
||||
impl<T: AsyncRead + AsyncWrite> Service for OpensslConnectorService<T> {
|
||||
type Request = T;
|
||||
type Request = (String, T);
|
||||
type Response = SslStream<T>;
|
||||
type Error = Error;
|
||||
type Future = ConnectAsync<T>;
|
||||
|
@ -149,7 +145,7 @@ impl<T: AsyncRead + AsyncWrite> Service for OpensslConnectorService<T> {
|
|||
Ok(Async::Ready(()))
|
||||
}
|
||||
|
||||
fn call(&mut self, req: Self::Request) -> Self::Future {
|
||||
SslConnectorExt::connect_async(&self.connector, "", req)
|
||||
fn call(&mut self, (host, stream): Self::Request) -> Self::Future {
|
||||
SslConnectorExt::connect_async(&self.connector, &host, stream)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue