pub enum StreamingBody<B> {
Buffered {
data: Option<Bytes>,
},
Streaming {
inner: B,
},
File {
file: File,
buf: Vec<u8>,
finished: bool,
},
}Available on crate feature
streaming only.Expand description
A body type that can represent either buffered data from cache, streaming body from upstream, or streaming from a file for file-based caching.
This enum allows the HTTP cache middleware to efficiently handle:
- Cached responses (buffered data)
- Cache misses (streaming from upstream)
- File-based cached responses (streaming from disk)
§Variants
Buffered: Contains cached response data that can be sent immediatelyStreaming: Wraps an upstream body for streaming responsesFile: Streams directly from a file for zero-copy caching
§Example
use http_cache::StreamingBody;
use bytes::Bytes;
use http_body_util::Full;
// Cached response - sent immediately from memory
let cached: StreamingBody<Full<Bytes>> = StreamingBody::buffered(Bytes::from("Hello from cache!"));
// Streaming response - passed through from upstream
let upstream_body = MyBody;
let streaming = StreamingBody::streaming(upstream_body);Variants§
Implementations§
Source§impl<B> StreamingBody<B>
impl<B> StreamingBody<B>
Sourcepub fn buffered(data: Bytes) -> StreamingBody<B>
pub fn buffered(data: Bytes) -> StreamingBody<B>
Create a new buffered body from bytes
Sourcepub fn streaming(body: B) -> StreamingBody<B>
pub fn streaming(body: B) -> StreamingBody<B>
Create a new streaming body from an upstream body
Sourcepub fn from_file(file: File) -> StreamingBody<B>
pub fn from_file(file: File) -> StreamingBody<B>
Create a new file-based streaming body
Source§impl<B> StreamingBody<B>
impl<B> StreamingBody<B>
Sourcepub fn into_bytes_stream(
self,
) -> impl Stream<Item = Result<Bytes, Box<dyn Error + Send + Sync>>> + Send
pub fn into_bytes_stream( self, ) -> impl Stream<Item = Result<Bytes, Box<dyn Error + Send + Sync>>> + Send
Convert this streaming body into a stream of Bytes.
This method allows for streaming without collecting the entire body into memory first. This is particularly useful for file-based cached responses which can stream directly from disk.
Trait Implementations§
Source§impl<B> Body for StreamingBody<B>
impl<B> Body for StreamingBody<B>
Source§type Error = StreamingError
type Error = StreamingError
The error type this
Body might generate.Source§fn poll_frame(
self: Pin<&mut StreamingBody<B>>,
cx: &mut Context<'_>,
) -> Poll<Option<Result<Frame<<StreamingBody<B> as Body>::Data>, <StreamingBody<B> as Body>::Error>>>
fn poll_frame( self: Pin<&mut StreamingBody<B>>, cx: &mut Context<'_>, ) -> Poll<Option<Result<Frame<<StreamingBody<B> as Body>::Data>, <StreamingBody<B> as Body>::Error>>>
Attempt to pull out the next data buffer of this stream.
Source§fn is_end_stream(&self) -> bool
fn is_end_stream(&self) -> bool
Returns
true when the end of stream has been reached. Read moreSource§impl<B> From<Bytes> for StreamingBody<B>
impl<B> From<Bytes> for StreamingBody<B>
Source§fn from(bytes: Bytes) -> StreamingBody<B>
fn from(bytes: Bytes) -> StreamingBody<B>
Converts to this type from the input type.
impl<'__pin, B> Unpin for StreamingBody<B>where
<PinnedFieldsOfHelperStruct<__Origin<'__pin, B>> as PinnedFieldsOfHelperTrait>::Actual: Unpin,
Auto Trait Implementations§
impl<B> !Freeze for StreamingBody<B>
impl<B> !RefUnwindSafe for StreamingBody<B>
impl<B> Send for StreamingBody<B>where
B: Send,
impl<B> Sync for StreamingBody<B>where
B: Sync,
impl<B> UnwindSafe for StreamingBody<B>where
B: UnwindSafe,
Blanket Implementations§
Source§impl<T> BodyExt for T
impl<T> BodyExt for T
Source§fn frame(&mut self) -> Frame<'_, Self>where
Self: Unpin,
fn frame(&mut self) -> Frame<'_, Self>where
Self: Unpin,
Returns a future that resolves to the next
Frame, if any.Source§fn map_frame<F, B>(self, f: F) -> MapFrame<Self, F>
fn map_frame<F, B>(self, f: F) -> MapFrame<Self, F>
Maps this body’s frame to a different kind.
Source§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
Maps this body’s error value to a different value.
Source§fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
Turn this body into a boxed trait object that is !Sync.
Source§fn collect(self) -> Collect<Self>where
Self: Sized,
fn collect(self) -> Collect<Self>where
Self: Sized,
Turn this body into
Collected body which will collect all the DATA frames
and trailers.Source§fn with_trailers<F>(self, trailers: F) -> WithTrailers<Self, F>
fn with_trailers<F>(self, trailers: F) -> WithTrailers<Self, F>
Add trailers to the body. Read more
Source§fn into_data_stream(self) -> BodyDataStream<Self>where
Self: Sized,
fn into_data_stream(self) -> BodyDataStream<Self>where
Self: Sized,
Turn this body into
BodyDataStream.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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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