pub struct RequestStream<S, B> { /* private fields */ }h3 only.Expand description
Manage request bodies transfer, response and trailers.
Once a request has been sent via crate::client::SendRequest::send_request(), a response can be awaited by calling
RequestStream::recv_response(). A body for this request can be sent with RequestStream::send_data(), then the request
shall be completed by either sending trailers with RequestStream::finish().
After receiving the response’s headers, it’s body can be read by RequestStream::recv_data() until it returns
None. Then the trailers will eventually be available via RequestStream::recv_trailers().
TODO: If data is polled before the response has been received, an error will be thrown.
TODO: If trailers are polled but the body hasn’t been fully received, an UNEXPECT_FRAME error will be thrown
Whenever the client wants to cancel this request, it can call RequestStream::stop_sending(), which will
put an end to any transfer concerning it.
§Examples
// Prepare the HTTP request to send to the server
let request = Request::get("https://www.example.com/").body(())?;
// Receive the response
let response = req_stream.recv_response().await?;
// Receive the body
while let Some(mut chunk) = req_stream.recv_data().await? {
let mut out = tokio::io::stdout();
out.write_all_buf(&mut chunk).await?;
out.flush().await?;
}Implementations§
Source§impl<S, B> RequestStream<S, B>where
S: RecvStream,
impl<S, B> RequestStream<S, B>where
S: RecvStream,
Sourcepub async fn recv_response(&mut self) -> Result<Response<()>, StreamError>
pub async fn recv_response(&mut self) -> Result<Response<()>, StreamError>
Receive the HTTP/3 response
This should be called before trying to receive any data with recv_data().
Sourcepub async fn recv_data(&mut self) -> Result<Option<impl Buf>, StreamError>
pub async fn recv_data(&mut self) -> Result<Option<impl Buf>, StreamError>
Receive some of the request body.
Sourcepub fn poll_recv_data(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<Option<impl Buf>, StreamError>>
pub fn poll_recv_data( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<Option<impl Buf>, StreamError>>
Receive request body
Sourcepub async fn recv_trailers(&mut self) -> Result<Option<HeaderMap>, StreamError>
pub async fn recv_trailers(&mut self) -> Result<Option<HeaderMap>, StreamError>
Receive an optional set of trailers for the response.
Sourcepub fn poll_recv_trailers(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<Option<HeaderMap>, StreamError>>
pub fn poll_recv_trailers( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<Option<HeaderMap>, StreamError>>
Poll receive an optional set of trailers for the response.
Sourcepub fn stop_sending(&mut self, error_code: Code)
pub fn stop_sending(&mut self, error_code: Code)
Tell the peer to stop sending into the underlying QUIC stream
Source§impl<S, B> RequestStream<S, B>where
S: SendStream<B>,
B: Buf,
impl<S, B> RequestStream<S, B>where
S: SendStream<B>,
B: Buf,
Sourcepub async fn send_data(&mut self, buf: B) -> Result<(), StreamError>
pub async fn send_data(&mut self, buf: B) -> Result<(), StreamError>
Send some data on the request body.
Sourcepub fn stop_stream(&mut self, error_code: Code)
pub fn stop_stream(&mut self, error_code: Code)
Stop a stream with an error code
The code can be Code::H3_NO_ERROR.
Sourcepub async fn send_trailers(
&mut self,
trailers: HeaderMap,
) -> Result<(), StreamError>
pub async fn send_trailers( &mut self, trailers: HeaderMap, ) -> Result<(), StreamError>
Send a set of trailers to end the request.
RequestStream::finish() must be called to finalize a request.
Sourcepub async fn finish(&mut self) -> Result<(), StreamError>
pub async fn finish(&mut self) -> Result<(), StreamError>
End the request without trailers.
RequestStream::finish() must be called to finalize a request.
Source§impl<S, B> RequestStream<S, B>where
S: BidiStream<B>,
B: Buf,
impl<S, B> RequestStream<S, B>where
S: BidiStream<B>,
B: Buf,
Sourcepub fn split(
self,
) -> (RequestStream<<S as BidiStream<B>>::SendStream, B>, RequestStream<<S as BidiStream<B>>::RecvStream, B>)
pub fn split( self, ) -> (RequestStream<<S as BidiStream<B>>::SendStream, B>, RequestStream<<S as BidiStream<B>>::RecvStream, B>)
Split this stream into two halves that can be driven independently.
Trait Implementations§
Source§impl<S, B> CloseStream for RequestStream<S, B>
impl<S, B> CloseStream for RequestStream<S, B>
Source§fn handle_connection_error_on_stream(
&mut self,
internal_error: InternalConnectionError,
) -> StreamError
fn handle_connection_error_on_stream( &mut self, internal_error: InternalConnectionError, ) -> StreamError
Source§fn handle_quic_stream_error(&self, error: StreamErrorIncoming) -> StreamError
fn handle_quic_stream_error(&self, error: StreamErrorIncoming) -> StreamError
Source§fn check_peer_connection_closing(&self) -> Option<StreamError>
fn check_peer_connection_closing(&self) -> Option<StreamError>
Source§impl<S, B> ConnectionState for RequestStream<S, B>
impl<S, B> ConnectionState for RequestStream<S, B>
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
Auto Trait Implementations§
impl<S, B> !Freeze for RequestStream<S, B>
impl<S, B> !RefUnwindSafe for RequestStream<S, B>
impl<S, B> Send for RequestStream<S, B>
impl<S, B> Sync for RequestStream<S, B>
impl<S, B> Unpin for RequestStream<S, B>
impl<S, B> !UnwindSafe for RequestStream<S, 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