mirror of
https://github.com/fafhrd91/actix-web
synced 2025-07-01 08:45:10 +02:00
Fix poll_ready call for WebSockets upgrade (#1219)
* Fix poll_ready call for WebSockets upgrade * Poll upgrade service from H1ServiceHandler too
This commit is contained in:
committed by
Nikolay Kim
parent
29ac6463e1
commit
3b860ebdc7
@ -66,7 +66,6 @@ where
|
||||
U::Error: fmt::Display,
|
||||
{
|
||||
Normal(InnerDispatcher<T, S, B, X, U>),
|
||||
UpgradeReadiness(InnerDispatcher<T, S, B, X, U>, Request),
|
||||
Upgrade(U::Future),
|
||||
None,
|
||||
}
|
||||
@ -764,8 +763,16 @@ where
|
||||
if let DispatcherState::Normal(inner) =
|
||||
std::mem::replace(&mut self.inner, DispatcherState::None)
|
||||
{
|
||||
self.inner =
|
||||
DispatcherState::UpgradeReadiness(inner, req);
|
||||
let mut parts = FramedParts::with_read_buf(
|
||||
inner.io,
|
||||
inner.codec,
|
||||
inner.read_buf,
|
||||
);
|
||||
parts.write_buf = inner.write_buf;
|
||||
let framed = Framed::from_parts(parts);
|
||||
self.inner = DispatcherState::Upgrade(
|
||||
inner.upgrade.unwrap().call((req, framed)),
|
||||
);
|
||||
return self.poll(cx);
|
||||
} else {
|
||||
panic!()
|
||||
@ -815,35 +822,6 @@ where
|
||||
}
|
||||
}
|
||||
}
|
||||
DispatcherState::UpgradeReadiness(ref mut inner, _) => {
|
||||
let upgrade = inner.upgrade.as_mut().unwrap();
|
||||
match upgrade.poll_ready(cx) {
|
||||
Poll::Ready(Ok(_)) => {
|
||||
if let DispatcherState::UpgradeReadiness(inner, req) =
|
||||
std::mem::replace(&mut self.inner, DispatcherState::None)
|
||||
{
|
||||
let mut parts = FramedParts::with_read_buf(
|
||||
inner.io,
|
||||
inner.codec,
|
||||
inner.read_buf,
|
||||
);
|
||||
parts.write_buf = inner.write_buf;
|
||||
let framed = Framed::from_parts(parts);
|
||||
self.inner = DispatcherState::Upgrade(
|
||||
inner.upgrade.unwrap().call((req, framed)),
|
||||
);
|
||||
self.poll(cx)
|
||||
} else {
|
||||
panic!()
|
||||
}
|
||||
}
|
||||
Poll::Pending => Poll::Pending,
|
||||
Poll::Ready(Err(e)) => {
|
||||
error!("Upgrade handler readiness check error: {}", e);
|
||||
Poll::Ready(Err(DispatchError::Upgrade))
|
||||
}
|
||||
}
|
||||
}
|
||||
DispatcherState::Upgrade(ref mut fut) => {
|
||||
unsafe { Pin::new_unchecked(fut) }.poll(cx).map_err(|e| {
|
||||
error!("Upgrade handler error: {}", e);
|
||||
|
Reference in New Issue
Block a user