pub struct Connection<C, B>where
C: Connection<B>,
B: Buf,{
pub inner: ConnectionInner<C, B>,
/* private fields */
}Expand description
Server connection driver
The Connection struct manages a connection from the side of the HTTP/3 server
Create a new Instance with Connection::new().
Accept incoming requests with Connection::accept().
And shutdown a connection with Connection::shutdown().
Fields§
§inner: ConnectionInner<C, B>TODO: temporarily break encapsulation for WebTransportSession
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 new(conn: C) -> Result<Connection<C, B>, ConnectionError>
pub async fn new(conn: C) -> Result<Connection<C, B>, ConnectionError>
Create a new HTTP/3 server connection with default settings
Use a custom super::builder::Builder with super::builder::builder() to create a connection
with different settings.
Provide a Connection which implements quic::Connection.
Source§impl<C, B> Connection<C, B>where
C: Connection<B>,
B: Buf,
Impls for extension implementation which are not stable
impl<C, B> Connection<C, B>where
C: Connection<B>,
B: Buf,
Impls for extension implementation which are not stable
Sourcepub fn create_resolver(
&self,
stream: FrameStream<<C as OpenStreams<B>>::BidiStream, B>,
) -> RequestResolver<C, B>
pub fn create_resolver( &self, stream: FrameStream<<C as OpenStreams<B>>::BidiStream, B>, ) -> RequestResolver<C, B>
Create a RequestResolver to handle an incoming request.
Sourcepub fn poll_accept_request_stream(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<Option<<C as OpenStreams<B>>::BidiStream>, ConnectionError>>
pub fn poll_accept_request_stream( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<Option<<C as OpenStreams<B>>::BidiStream>, ConnectionError>>
Polls the Connection and accepts an incoming request_streams
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 accept(
&mut self,
) -> Result<Option<RequestResolver<C, B>>, ConnectionError>
pub async fn accept( &mut self, ) -> Result<Option<RequestResolver<C, B>>, ConnectionError>
Accept an incoming request.
This method returns a RequestResolver which can be used to read the request and send the response.
This method will return None when the connection receives a GOAWAY frame and all requests have been completed.
Sourcepub async fn shutdown(
&mut self,
max_requests: usize,
) -> Result<(), ConnectionError>
pub async fn shutdown( &mut self, max_requests: usize, ) -> Result<(), ConnectionError>
Initiate a graceful shutdown, accepting max_request potentially still in-flight
See connection shutdown for more information.
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<C, B> Drop for Connection<C, B>where
C: Connection<B>,
B: Buf,
impl<C, B> Drop for Connection<C, B>where
C: Connection<B>,
B: Buf,
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>
Get the datagram sender
Source§fn get_datagram_reader(
&self,
) -> DatagramReader<<C as DatagramConnectionExt<B>>::RecvDatagramHandler>
fn get_datagram_reader( &self, ) -> DatagramReader<<C as DatagramConnectionExt<B>>::RecvDatagramHandler>
Get the datagram reader