Struct tokio_rustls::LazyConfigAcceptor
source · [−]pub struct LazyConfigAcceptor<IO> { /* private fields */ }
Implementations
sourceimpl<IO> LazyConfigAcceptor<IO>where
IO: AsyncRead + AsyncWrite + Unpin,
impl<IO> LazyConfigAcceptor<IO>where
IO: AsyncRead + AsyncWrite + Unpin,
pub fn new(acceptor: Acceptor, io: IO) -> Self
sourcepub fn take_io(&mut self) -> Option<IO>
pub fn take_io(&mut self) -> Option<IO>
Takes back the client connection. Will return None
if called more than once or if the
connection has been accepted.
Example
use tokio::io::AsyncWriteExt;
let listener = tokio::net::TcpListener::bind("127.0.0.1:4443").await.unwrap();
let (stream, _) = listener.accept().await.unwrap();
let acceptor = tokio_rustls::LazyConfigAcceptor::new(rustls::server::Acceptor::default(), stream);
futures_util::pin_mut!(acceptor);
match acceptor.as_mut().await {
Ok(start) => {
let clientHello = start.client_hello();
let config = choose_server_config(clientHello);
let stream = start.into_stream(config).await.unwrap();
// Proceed with handling the ServerConnection...
}
Err(err) => {
if let Some(mut stream) = acceptor.take_io() {
stream
.write_all(
format!("HTTP/1.1 400 Invalid Input\r\n\r\n\r\n{:?}\n", err)
.as_bytes()
)
.await
.unwrap();
}
}
}
Trait Implementations
sourceimpl<IO> Future for LazyConfigAcceptor<IO>where
IO: AsyncRead + AsyncWrite + Unpin,
impl<IO> Future for LazyConfigAcceptor<IO>where
IO: AsyncRead + AsyncWrite + Unpin,
Auto Trait Implementations
impl<IO> !RefUnwindSafe for LazyConfigAcceptor<IO>
impl<IO> Send for LazyConfigAcceptor<IO>where
IO: Send,
impl<IO> Sync for LazyConfigAcceptor<IO>where
IO: Sync,
impl<IO> Unpin for LazyConfigAcceptor<IO>where
IO: Unpin,
impl<IO> !UnwindSafe for LazyConfigAcceptor<IO>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
type IntoFuture = F
type IntoFuture = F
Which kind of future are we turning this into?
sourcefn into_future(self) -> <F as IntoFuture>::IntoFuture
fn into_future(self) -> <F as IntoFuture>::IntoFuture
Creates a future from a value. Read more