pub struct Connection<C, B>where
C: Connection<B>,
B: Buf,{
pub inner: ConnectionInner<C, B>,
/* private fields */
}h3 only.Expand description
Client connection driver
Maintains the internal state of an HTTP/3 connection, including control and QPACK.
It needs to be polled continuously via poll_close(). On connection closure, this
will resolve to Ok(()) if the peer sent HTTP_NO_ERROR, or Err() if a connection-level
error occurred.
shutdown() initiates a graceful shutdown of this connection. After calling it, no request
initiation will be further allowed. Then poll_close() will resolve when all ongoing requests
and push streams complete. Finally, a connection closure with HTTP_NO_ERROR code will be
sent to the server.
§Examples
§Drive a connection concurrently
// Run the driver on a different task
tokio::spawn(async move {
future::poll_fn(|cx| connection.poll_close(cx)).await;
Ok::<(), Box<dyn std::error::Error + Send + Sync>>(())
})§Shutdown a connection gracefully
// Prepare a channel to stop the driver thread
let (shutdown_tx, shutdown_rx) = oneshot::channel();
// Run the driver on a different task
let driver = tokio::spawn(async move {
tokio::select! {
// Drive the connection
closed = future::poll_fn(|cx| connection.poll_close(cx)) => closed,
// Listen for shutdown condition
max_streams = shutdown_rx => {
// Initiate shutdown
connection.shutdown(max_streams?);
// Wait for ongoing work to complete
future::poll_fn(|cx| connection.poll_close(cx)).await
}
};
Ok::<(), Box<dyn std::error::Error + Send + Sync>>(())
});
// Do client things, wait for close condition...
// Initiate shutdown
shutdown_tx.send(2);
// Wait for the connection to be closed
driver.await?Fields§
§inner: ConnectionInner<C, B>TODO: breaking encapsulation for RFC9298.
Implementations§
Source§impl<C, B> Connection<C, B>where
C: Connection<B>,
B: Buf,
impl<C, B> Connection<C, B>where
C: Connection<B>,
B: Buf,
Sourcepub async fn shutdown(
&mut self,
_max_push: usize,
) -> Result<(), ConnectionError>
pub async fn shutdown( &mut self, _max_push: usize, ) -> Result<(), ConnectionError>
Initiate a graceful shutdown, accepting max_push potentially in-flight server pushes
Sourcepub async fn wait_idle(&mut self) -> ConnectionError
pub async fn wait_idle(&mut self) -> ConnectionError
Wait until the connection is closed
Sourcepub fn poll_close(&mut self, cx: &mut Context<'_>) -> Poll<ConnectionError>
pub fn poll_close(&mut self, cx: &mut Context<'_>) -> Poll<ConnectionError>
Maintain the connection state until it is closed
Trait Implementations§
Source§impl<C, B> ConnectionState for Connection<C, B>where
C: Connection<B>,
B: Buf,
impl<C, B> ConnectionState for Connection<C, B>where
C: Connection<B>,
B: Buf,
Source§fn get_conn_error(&self) -> Option<ErrorOrigin>
fn get_conn_error(&self) -> Option<ErrorOrigin>
Source§fn set_conn_error(&self, error: ErrorOrigin) -> ErrorOrigin
fn set_conn_error(&self, error: ErrorOrigin) -> ErrorOrigin
Source§fn set_conn_error_and_wake<T>(&self, error: T) -> ErrorOriginwhere
T: Into<ErrorOrigin>,
fn set_conn_error_and_wake<T>(&self, error: T) -> ErrorOriginwhere
T: Into<ErrorOrigin>,
Source§fn set_closing(&self)
fn set_closing(&self)
Source§fn is_closing(&self) -> bool
fn is_closing(&self) -> bool
Source§fn set_settings(&self, settings: Settings)
fn set_settings(&self, settings: Settings)
Source§fn waker(&self) -> &AtomicWaker
fn waker(&self) -> &AtomicWaker
Source§impl<B, C> HandleDatagramsExt<C, B> for Connection<C, B>
impl<B, C> HandleDatagramsExt<C, B> for Connection<C, B>
Source§fn get_datagram_sender(
&self,
stream_id: StreamId,
) -> DatagramSender<<C as DatagramConnectionExt<B>>::SendDatagramHandler, B>
fn get_datagram_sender( &self, stream_id: StreamId, ) -> DatagramSender<<C as DatagramConnectionExt<B>>::SendDatagramHandler, B>
Source§fn get_datagram_reader(
&self,
) -> DatagramReader<<C as DatagramConnectionExt<B>>::RecvDatagramHandler>
fn get_datagram_reader( &self, ) -> DatagramReader<<C as DatagramConnectionExt<B>>::RecvDatagramHandler>
Auto Trait Implementations§
impl<C, B> Freeze for Connection<C, B>where
C: Freeze,
<C as OpenStreams<B>>::SendStream: Freeze,
<C as Connection<B>>::RecvStream: Freeze,
impl<C, B> !RefUnwindSafe for Connection<C, B>
impl<C, B> Send for Connection<C, B>where
C: Send,
<C as OpenStreams<B>>::SendStream: Send,
B: Send,
<C as Connection<B>>::RecvStream: Send,
impl<C, B> Sync for Connection<C, B>where
C: Sync,
<C as OpenStreams<B>>::SendStream: Sync,
B: Sync,
<C as Connection<B>>::RecvStream: Sync,
impl<C, B> Unpin for Connection<C, B>
impl<C, B> !UnwindSafe for Connection<C, B>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more