mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-05 13:57:39 +03:00
proper handling for openssl ZERO_RETURN error
This commit is contained in:
parent
d23bb69fff
commit
7751e944f4
8 changed files with 21 additions and 7 deletions
|
@ -1,6 +1,6 @@
|
||||||
# Changes
|
# Changes
|
||||||
|
|
||||||
## [0.3.0] - 2021-12-xx
|
## [0.3.0] - 2021-12-24
|
||||||
|
|
||||||
* Service takes request type as a type parameter instead of an associated type
|
* Service takes request type as a type parameter instead of an associated type
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,10 @@
|
||||||
|
|
||||||
## [0.1.0-b.5] - 2021-12-28
|
## [0.1.0-b.5] - 2021-12-28
|
||||||
|
|
||||||
|
* Proper handling for openssl ZERO_RETURN error
|
||||||
|
|
||||||
|
## [0.1.0-b.5] - 2021-12-28
|
||||||
|
|
||||||
* Add query support for peer cert and peer cert chain
|
* Add query support for peer cert and peer cert chain
|
||||||
|
|
||||||
## [0.1.0-b.4] - 2021-12-27
|
## [0.1.0-b.4] - 2021-12-27
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "ntex-tls"
|
name = "ntex-tls"
|
||||||
version = "0.1.0-b.5"
|
version = "0.1.0-b.6"
|
||||||
authors = ["ntex contributors <team@ntex.rs>"]
|
authors = ["ntex contributors <team@ntex.rs>"]
|
||||||
description = "An implementation of SSL streams for ntex backed by OpenSSL"
|
description = "An implementation of SSL streams for ntex backed by OpenSSL"
|
||||||
keywords = ["network", "framework", "async", "futures"]
|
keywords = ["network", "framework", "async", "futures"]
|
||||||
|
|
|
@ -112,7 +112,9 @@ impl<F: Filter> Filter for SslFilter<F> {
|
||||||
Ok(ssl::ShutdownResult::Received) => {
|
Ok(ssl::ShutdownResult::Received) => {
|
||||||
self.inner.borrow().get_ref().inner.poll_shutdown()
|
self.inner.borrow().get_ref().inner.poll_shutdown()
|
||||||
}
|
}
|
||||||
Err(ref e) if e.code() == ssl::ErrorCode::ZERO_RETURN => Poll::Ready(Ok(())),
|
Err(ref e) if e.code() == ssl::ErrorCode::ZERO_RETURN => {
|
||||||
|
self.inner.borrow().get_ref().inner.poll_shutdown()
|
||||||
|
}
|
||||||
Err(ref e)
|
Err(ref e)
|
||||||
if e.code() == ssl::ErrorCode::WANT_READ
|
if e.code() == ssl::ErrorCode::WANT_READ
|
||||||
|| e.code() == ssl::ErrorCode::WANT_WRITE =>
|
|| e.code() == ssl::ErrorCode::WANT_WRITE =>
|
||||||
|
@ -230,6 +232,10 @@ impl<F: Filter> Filter for SslFilter<F> {
|
||||||
}
|
}
|
||||||
Ok(new_bytes)
|
Ok(new_bytes)
|
||||||
}
|
}
|
||||||
|
Err(ref e) if e.code() == ssl::ErrorCode::ZERO_RETURN => {
|
||||||
|
self.want_shutdown(None);
|
||||||
|
Ok(new_bytes)
|
||||||
|
}
|
||||||
Err(e) => Err(map_to_ioerr(e)),
|
Err(e) => Err(map_to_ioerr(e)),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -252,6 +258,10 @@ impl<F: Filter> Filter for SslFilter<F> {
|
||||||
}
|
}
|
||||||
return match e.code() {
|
return match e.code() {
|
||||||
ssl::ErrorCode::WANT_READ | ssl::ErrorCode::WANT_WRITE => Ok(()),
|
ssl::ErrorCode::WANT_READ | ssl::ErrorCode::WANT_WRITE => Ok(()),
|
||||||
|
ssl::ErrorCode::ZERO_RETURN => {
|
||||||
|
self.want_shutdown(None);
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
_ => Err(map_to_ioerr(e)),
|
_ => Err(map_to_ioerr(e)),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# Changes
|
# Changes
|
||||||
|
|
||||||
## [0.5.0-b.5] - 2021-12-xx
|
## [0.5.0-b.5] - 2021-12-28
|
||||||
|
|
||||||
* http: proper send payload, if request payload is not consumed
|
* http: proper send payload, if request payload is not consumed
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,7 @@ ntex-service = "0.3.0-b.0"
|
||||||
ntex-macros = "0.1.3"
|
ntex-macros = "0.1.3"
|
||||||
ntex-util = "0.1.5"
|
ntex-util = "0.1.5"
|
||||||
ntex-bytes = "0.1.8"
|
ntex-bytes = "0.1.8"
|
||||||
ntex-tls = "0.1.0-b.5"
|
ntex-tls = "0.1.0-b.6"
|
||||||
ntex-io = "0.1.0-b.8"
|
ntex-io = "0.1.0-b.8"
|
||||||
ntex-rt = { version = "0.4.0-b.2", default-features = false, features = ["tokio"] }
|
ntex-rt = { version = "0.4.0-b.2", default-features = false, features = ["tokio"] }
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<div align="center">
|
<div align="center">
|
||||||
<p><h1>ntex</h1> </p>
|
<p><h1>ntex</h1> </p>
|
||||||
<p><strong>Framework for composable network services. This is personal project. This project uses *unsafe*!</strong> </p>
|
<p><strong>Framework for composable network services. This project uses *unsafe*!</strong> </p>
|
||||||
<p>
|
<p>
|
||||||
|
|
||||||
[](https://github.com/ntex-rs/ntex/actions?query=workflow%3A"CI+(Linux)")
|
[](https://github.com/ntex-rs/ntex/actions?query=workflow%3A"CI+(Linux)")
|
||||||
|
|
|
@ -84,7 +84,7 @@ async fn test_openssl_read_before_error() {
|
||||||
let io = conn.call(addr.into()).await.unwrap();
|
let io = conn.call(addr.into()).await.unwrap();
|
||||||
let item = io.recv(&BytesCodec).await.unwrap().unwrap();
|
let item = io.recv(&BytesCodec).await.unwrap().unwrap();
|
||||||
assert_eq!(item, Bytes::from_static(b"test"));
|
assert_eq!(item, Bytes::from_static(b"test"));
|
||||||
assert!(io.recv(&BytesCodec).await.is_err());
|
assert!(io.recv(&BytesCodec).await.unwrap().is_none());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "rustls")]
|
#[cfg(feature = "rustls")]
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue