pub struct SdkBody { /* private fields */ }Expand description
SdkBody type
This is the Body used for dispatching all HTTP Requests. For handling responses, the type of the body will be controlled by the HTTP stack.
Implementations§
Source§impl SdkBody
 
impl SdkBody
Sourcepub fn from_body_0_4<T, E>(body: T) -> SdkBody
 
pub fn from_body_0_4<T, E>(body: T) -> SdkBody
Construct an SdkBody from a type that implements http_body_0_4::Body<Data = Bytes>.
Note: This is only available with http-body-0-4-x enabled.
Source§impl SdkBody
 
impl SdkBody
Sourcepub fn retryable(f: impl Fn() -> SdkBody + Send + Sync + 'static) -> SdkBody
 
pub fn retryable(f: impl Fn() -> SdkBody + Send + Sync + 'static) -> SdkBody
Construct an explicitly retryable SDK body
Note: This is probably not what you want
All bodies constructed from in-memory data (String, Vec<u8>, Bytes, etc.) will be
retryable out of the box. If you want to read data from a file, you should use
ByteStream::from_path. This function
is only necessary when you need to enable retries for your own streaming container.
Sourcepub fn taken() -> SdkBody
 
pub fn taken() -> SdkBody
When an SdkBody is read, the inner data must be consumed. In order to do this, the SdkBody is swapped with a “taken” body. This “taken” body cannot be read but aids in debugging.
Sourcepub fn empty() -> SdkBody
 
pub fn empty() -> SdkBody
Create an empty SdkBody for requests and responses that don’t transfer any data in the body.
Sourcepub fn bytes(&self) -> Option<&[u8]>
 
pub fn bytes(&self) -> Option<&[u8]>
If possible, return a reference to this body as &[u8]
If this SdkBody is NOT streaming, this will return the byte slab
If this SdkBody is streaming, this will return None
Sourcepub fn try_clone(&self) -> Option<SdkBody>
 
pub fn try_clone(&self) -> Option<SdkBody>
Attempt to clone this SdkBody. This will fail if the inner data is not cloneable, such as when it is a single-use stream that can’t be recreated.
Sourcepub fn is_streaming(&self) -> bool
 
pub fn is_streaming(&self) -> bool
Return true if this SdkBody is streaming, false if it is in-memory.
Sourcepub fn content_length(&self) -> Option<u64>
 
pub fn content_length(&self) -> Option<u64>
Return the length, in bytes, of this SdkBody. If this returns None, then the body does not
have a known length.
Sourcepub fn map(
    self,
    f: impl Fn(SdkBody) -> SdkBody + Sync + Send + 'static,
) -> SdkBody
 
pub fn map( self, f: impl Fn(SdkBody) -> SdkBody + Sync + Send + 'static, ) -> SdkBody
Given a function to modify an SdkBody, run that function against this SdkBody before
returning the result.
Sourcepub fn map_preserve_contents(
    self,
    f: impl Fn(SdkBody) -> SdkBody + Sync + Send + 'static,
) -> SdkBody
 
pub fn map_preserve_contents( self, f: impl Fn(SdkBody) -> SdkBody + Sync + Send + 'static, ) -> SdkBody
Update this SdkBody with map. This function MUST NOT alter the data of the body.
This function is useful for adding metadata like progress tracking to an SdkBody that
does not alter the actual byte data. If your mapper alters the contents of the body, use SdkBody::map
instead.
Trait Implementations§
Source§impl Body for SdkBody
 
impl Body for SdkBody
Source§fn poll_data(
    self: Pin<&mut SdkBody>,
    cx: &mut Context<'_>,
) -> Poll<Option<Result<<SdkBody as Body>::Data, <SdkBody as Body>::Error>>>
 
fn poll_data( self: Pin<&mut SdkBody>, cx: &mut Context<'_>, ) -> Poll<Option<Result<<SdkBody as Body>::Data, <SdkBody as Body>::Error>>>
Source§fn poll_trailers(
    self: Pin<&mut SdkBody>,
    cx: &mut Context<'_>,
) -> Poll<Result<Option<HeaderMap>, <SdkBody as Body>::Error>>
 
fn poll_trailers( self: Pin<&mut SdkBody>, cx: &mut Context<'_>, ) -> Poll<Result<Option<HeaderMap>, <SdkBody as Body>::Error>>
HeaderMap of trailers. Read moreSource§fn is_end_stream(&self) -> bool
 
fn is_end_stream(&self) -> bool
true when the end of stream has been reached. Read moreSource§fn size_hint(&self) -> SizeHint
 
fn size_hint(&self) -> SizeHint
Source§fn trailers(&mut self) -> Trailers<'_, Self>
 
fn trailers(&mut self) -> Trailers<'_, Self>
Source§fn map_data<F, B>(self, f: F) -> MapData<Self, F>
 
fn map_data<F, B>(self, f: F) -> MapData<Self, F>
Source§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
 
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
Source§fn collect(self) -> Collect<Self>where
    Self: Sized,
 
fn collect(self) -> Collect<Self>where
    Self: Sized,
Collected body which will collect all the DATA frames
and trailers.Source§fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
 
fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
Source§impl Body for SdkBody
 
impl Body for SdkBody
Source§fn poll_frame(
    self: Pin<&mut SdkBody>,
    cx: &mut Context<'_>,
) -> Poll<Option<Result<Frame<<SdkBody as Body>::Data>, <SdkBody as Body>::Error>>>
 
fn poll_frame( self: Pin<&mut SdkBody>, cx: &mut Context<'_>, ) -> Poll<Option<Result<Frame<<SdkBody as Body>::Data>, <SdkBody as Body>::Error>>>
Source§fn is_end_stream(&self) -> bool
 
fn is_end_stream(&self) -> bool
true when the end of stream has been reached. Read moreSource§impl From<SdkBody> for ByteStream
 
impl From<SdkBody> for ByteStream
Source§fn from(inp: SdkBody) -> ByteStream
 
fn from(inp: SdkBody) -> ByteStream
impl<'__pin> Unpin for SdkBodywhere
    <PinnedFieldsOfHelperStruct<__Origin<'__pin>> as PinnedFieldsOfHelperTrait>::Actual: Unpin,
Auto Trait Implementations§
impl !Freeze for SdkBody
impl !RefUnwindSafe for SdkBody
impl Send for SdkBody
impl Sync for SdkBody
impl !UnwindSafe for SdkBody
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,
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>
Source§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
 
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
Source§fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
 
fn boxed_unsync(self) -> UnsyncBoxBody<Self::Data, Self::Error>
Source§fn collect(self) -> Collect<Self>where
    Self: Sized,
 
fn collect(self) -> Collect<Self>where
    Self: Sized,
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>
Source§fn into_data_stream(self) -> BodyDataStream<Self>where
    Self: Sized,
 
fn into_data_stream(self) -> BodyDataStream<Self>where
    Self: Sized,
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
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 moreSource§impl<T> Paint for Twhere
    T: ?Sized,
 
impl<T> Paint for Twhere
    T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
 
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
 
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
 
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
 
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
 
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
 
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
 
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
 
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
 
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
 
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
 
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
 
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
 
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
 
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
 
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
 
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
 
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
 
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
 
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
 
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
 
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
 
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
 
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
 👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.Source§fn whenever(&self, value: Condition) -> Painted<&T>
 
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);