pub struct Builder { /* private fields */ }Expand description
Builder for creating a Config.
Implementations§
Source§impl Builder
 
impl Builder
Sourcepub fn new() -> Self
 
pub fn new() -> Self
Constructs a config builder.
Sourcepub fn stalled_stream_protection(
    self,
    stalled_stream_protection_config: StalledStreamProtectionConfig,
) -> Self
 
pub fn stalled_stream_protection( self, stalled_stream_protection_config: StalledStreamProtectionConfig, ) -> Self
Set the StalledStreamProtectionConfig
to configure protection for stalled streams.
Sourcepub fn set_stalled_stream_protection(
    &mut self,
    stalled_stream_protection_config: Option<StalledStreamProtectionConfig>,
) -> &mut Self
 
pub fn set_stalled_stream_protection( &mut self, stalled_stream_protection_config: Option<StalledStreamProtectionConfig>, ) -> &mut Self
Set the StalledStreamProtectionConfig
to configure protection for stalled streams.
Sourcepub fn idempotency_token_provider(
    self,
    idempotency_token_provider: impl Into<IdempotencyTokenProvider>,
) -> Self
 
pub fn idempotency_token_provider( self, idempotency_token_provider: impl Into<IdempotencyTokenProvider>, ) -> Self
Sets the idempotency token provider to use for service calls that require tokens.
Sourcepub fn set_idempotency_token_provider(
    &mut self,
    idempotency_token_provider: Option<IdempotencyTokenProvider>,
) -> &mut Self
 
pub fn set_idempotency_token_provider( &mut self, idempotency_token_provider: Option<IdempotencyTokenProvider>, ) -> &mut Self
Sets the idempotency token provider to use for service calls that require tokens.
Sourcepub fn http_client(self, http_client: impl HttpClient + 'static) -> Self
 
pub fn http_client(self, http_client: impl HttpClient + 'static) -> Self
Sets the HTTP client to use when making requests.
§Examples
use std::time::Duration;
use aws_sdk_s3::config::Config;
use aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder;
let https_connector = hyper_rustls::HttpsConnectorBuilder::new()
    .with_webpki_roots()
    .https_only()
    .enable_http1()
    .enable_http2()
    .build();
let hyper_client = HyperClientBuilder::new().build(https_connector);
// This connector can then be given to a generated service Config
let config = my_service_client::Config::builder()
    .endpoint_url("https://example.com")
    .http_client(hyper_client)
    .build();
let client = my_service_client::Client::from_conf(config);Sourcepub fn set_http_client(
    &mut self,
    http_client: Option<SharedHttpClient>,
) -> &mut Self
 
pub fn set_http_client( &mut self, http_client: Option<SharedHttpClient>, ) -> &mut Self
Sets the HTTP client to use when making requests.
§Examples
use std::time::Duration;
use aws_sdk_s3::config::{Builder, Config};
use aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder;
fn override_http_client(builder: &mut Builder) {
    let https_connector = hyper_rustls::HttpsConnectorBuilder::new()
        .with_webpki_roots()
        .https_only()
        .enable_http1()
        .enable_http2()
        .build();
    let hyper_client = HyperClientBuilder::new().build(https_connector);
    builder.set_http_client(Some(hyper_client));
}
let mut builder = aws_sdk_s3::Config::builder();
override_http_client(&mut builder);
let config = builder.build();Sourcepub fn push_auth_scheme(self, auth_scheme: impl AuthScheme + 'static) -> Self
 
pub fn push_auth_scheme(self, auth_scheme: impl AuthScheme + 'static) -> Self
Adds an auth scheme to the builder
If auth_scheme has an existing AuthSchemeId in the runtime, the current identity
resolver and signer for that scheme will be replaced by those from auth_scheme.
Important: When introducing a custom auth scheme, ensure you override either
Self::auth_scheme_resolver or Self::set_auth_scheme_resolver
so that the custom auth scheme is included in the list of resolved auth scheme options.
The default auth scheme resolver will not recognize your custom auth scheme.
§Examples
// Auth scheme with customer identity resolver and signer
#[derive(Debug)]
struct CustomAuthScheme {
    id: AuthSchemeId,
    identity_resolver: SharedIdentityResolver,
    signer: CustomSigner,
}
impl Default for CustomAuthScheme {
    fn default() -> Self {
        Self {
            id: AuthSchemeId::new("custom"),
            identity_resolver: CustomIdentityResolver.into_shared(),
            signer: CustomSigner,
        }
    }
}
impl AuthScheme for CustomAuthScheme {
    fn scheme_id(&self) -> AuthSchemeId {
        self.id.clone()
    }
    fn identity_resolver(
        &self,
        _identity_resolvers: &dyn GetIdentityResolver,
    ) -> Option<SharedIdentityResolver> {
        Some(self.identity_resolver.clone())
    }
    fn signer(&self) -> &dyn Sign {
        &self.signer
    }
}
#[derive(Debug, Default)]
struct CustomSigner;
impl Sign for CustomSigner {
    fn sign_http_request(
        &self,
        _request: &mut HttpRequest,
        _identity: &Identity,
        _auth_scheme_endpoint_config: AuthSchemeEndpointConfig<'_>,
        _runtime_components: &RuntimeComponents,
        _config_bag: &ConfigBag,
    ) -> Result<(), BoxError> {
        // --snip--
    }
}
#[derive(Debug)]
struct CustomIdentityResolver;
impl ResolveIdentity for CustomIdentityResolver {
    fn resolve_identity<'a>(
        &'a self,
        _runtime_components: &'a RuntimeComponents,
        _config_bag: &'a ConfigBag,
    ) -> IdentityFuture<'a> {
        // --snip--
    }
}
// Auth scheme resolver that favors `CustomAuthScheme`
#[derive(Debug)]
struct CustomAuthSchemeResolver;
impl aws_sdk_s3::config::auth::ResolveAuthScheme for CustomAuthSchemeResolver {
    fn resolve_auth_scheme<'a>(
        &'a self,
        _params: &'a aws_sdk_s3::config::auth::Params,
        _cfg: &'a ConfigBag,
        _runtime_components: &'a RuntimeComponents,
    ) -> AuthSchemeOptionsFuture<'a> {
        AuthSchemeOptionsFuture::ready(Ok(vec![AuthSchemeOption::from(AuthSchemeId::new(
            "custom",
        ))]))
    }
}
let config = aws_sdk_s3::Config::builder()
    .push_auth_scheme(CustomAuthScheme::default())
    .auth_scheme_resolver(CustomAuthSchemeResolver)
    // other configurations
    .build();Sourcepub fn auth_scheme_resolver(
    self,
    auth_scheme_resolver: impl ResolveAuthScheme + 'static,
) -> Self
 
pub fn auth_scheme_resolver( self, auth_scheme_resolver: impl ResolveAuthScheme + 'static, ) -> Self
Set the auth scheme resolver for the builder
§Examples
#[derive(Debug)]
struct CustomAuthSchemeResolver;
impl aws_sdk_s3::config::auth::ResolveAuthScheme for CustomAuthSchemeResolver {
    fn resolve_auth_scheme<'a>(
        &'a self,
        _params: &'a aws_sdk_s3::config::auth::Params,
        _cfg: &'a ConfigBag,
        _runtime_components: &'a RuntimeComponents,
    ) -> AuthSchemeOptionsFuture<'a> {
        // --snip--
    }
}
let config = aws_sdk_s3::Config::builder()
    .auth_scheme_resolver(CustomAuthSchemeResolver)
    // other configurations
    .build();Sourcepub fn set_auth_scheme_resolver(
    &mut self,
    auth_scheme_resolver: impl ResolveAuthScheme + 'static,
) -> &mut Self
 
pub fn set_auth_scheme_resolver( &mut self, auth_scheme_resolver: impl ResolveAuthScheme + 'static, ) -> &mut Self
Set the auth scheme resolver for the builder
§Examples
See an example for Self::auth_scheme_resolver.
Sourcepub fn auth_scheme_preference(
    self,
    preference: impl Into<AuthSchemePreference>,
) -> Self
 
pub fn auth_scheme_preference( self, preference: impl Into<AuthSchemePreference>, ) -> Self
Set the auth scheme preference for an auth scheme resolver (typically the default auth scheme resolver).
Each operation has a predefined order of auth schemes, as determined by the service, for auth scheme resolution. By using the auth scheme preference, customers can reorder the schemes resolved by the auth scheme resolver.
The preference list is intended as a hint rather than a strict override. Any schemes not present in the originally resolved auth schemes will be ignored.
§Examples
let config = aws_sdk_s3::Config::builder()
    .auth_scheme_preference([AuthSchemeId::from("scheme1"), AuthSchemeId::from("scheme2")])
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn set_auth_scheme_preference(
    &mut self,
    preference: Option<AuthSchemePreference>,
) -> &mut Self
 
pub fn set_auth_scheme_preference( &mut self, preference: Option<AuthSchemePreference>, ) -> &mut Self
Set the auth scheme preference for an auth scheme resolver (typically the default auth scheme resolver).
Each operation has a predefined order of auth schemes, as determined by the service, for auth scheme resolution. By using the auth scheme preference, customers can reorder the schemes resolved by the auth scheme resolver.
The preference list is intended as a hint rather than a strict override. Any schemes not present in the originally resolved auth schemes will be ignored.
§Examples
let config = aws_sdk_s3::Config::builder()
    .auth_scheme_preference([AuthSchemeId::from("scheme1"), AuthSchemeId::from("scheme2")])
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn force_path_style(self, force_path_style: impl Into<bool>) -> Self
 
pub fn force_path_style(self, force_path_style: impl Into<bool>) -> Self
Forces this client to use path-style addressing for buckets.
Sourcepub fn set_force_path_style(
    &mut self,
    force_path_style: Option<bool>,
) -> &mut Self
 
pub fn set_force_path_style( &mut self, force_path_style: Option<bool>, ) -> &mut Self
Forces this client to use path-style addressing for buckets.
Sourcepub fn use_arn_region(self, use_arn_region: impl Into<bool>) -> Self
 
pub fn use_arn_region(self, use_arn_region: impl Into<bool>) -> Self
Enables this client to use an ARN’s region when constructing an endpoint instead of the client’s configured region.
Sourcepub fn set_use_arn_region(&mut self, use_arn_region: Option<bool>) -> &mut Self
 
pub fn set_use_arn_region(&mut self, use_arn_region: Option<bool>) -> &mut Self
Enables this client to use an ARN’s region when constructing an endpoint instead of the client’s configured region.
Sourcepub fn disable_multi_region_access_points(
    self,
    disable_multi_region_access_points: impl Into<bool>,
) -> Self
 
pub fn disable_multi_region_access_points( self, disable_multi_region_access_points: impl Into<bool>, ) -> Self
Disables this client’s usage of Multi-Region Access Points.
Sourcepub fn set_disable_multi_region_access_points(
    &mut self,
    disable_multi_region_access_points: Option<bool>,
) -> &mut Self
 
pub fn set_disable_multi_region_access_points( &mut self, disable_multi_region_access_points: Option<bool>, ) -> &mut Self
Disables this client’s usage of Multi-Region Access Points.
Sourcepub fn accelerate(self, accelerate: impl Into<bool>) -> Self
 
pub fn accelerate(self, accelerate: impl Into<bool>) -> Self
Enables this client to use S3 Transfer Acceleration endpoints.
Sourcepub fn set_accelerate(&mut self, accelerate: Option<bool>) -> &mut Self
 
pub fn set_accelerate(&mut self, accelerate: Option<bool>) -> &mut Self
Enables this client to use S3 Transfer Acceleration endpoints.
Sourcepub fn disable_s3_express_session_auth(
    self,
    disable_s3_express_session_auth: impl Into<bool>,
) -> Self
 
pub fn disable_s3_express_session_auth( self, disable_s3_express_session_auth: impl Into<bool>, ) -> Self
Disables this client’s usage of Session Auth for S3Express buckets and reverts to using conventional SigV4 for those.
Sourcepub fn set_disable_s3_express_session_auth(
    &mut self,
    disable_s3_express_session_auth: Option<bool>,
) -> &mut Self
 
pub fn set_disable_s3_express_session_auth( &mut self, disable_s3_express_session_auth: Option<bool>, ) -> &mut Self
Disables this client’s usage of Session Auth for S3Express buckets and reverts to using conventional SigV4 for those.
Sourcepub fn endpoint_resolver(
    self,
    endpoint_resolver: impl ResolveEndpoint + 'static,
) -> Self
 
pub fn endpoint_resolver( self, endpoint_resolver: impl ResolveEndpoint + 'static, ) -> Self
Sets the endpoint resolver to use when making requests.
When unset, the client will used a generated endpoint resolver based on the endpoint resolution
rules for aws_sdk_s3.
Note: setting an endpoint resolver will replace any endpoint URL that has been set.
This method accepts an endpoint resolver specific to this service. If you want to
provide a shared endpoint resolver, use Self::set_endpoint_resolver.
§Examples
Create a custom endpoint resolver that resolves a different endpoing per-stage, e.g. staging vs. production.
use aws_sdk_s3::config::endpoint::{ResolveEndpoint, EndpointFuture, Params, Endpoint};
#[derive(Debug)]
struct StageResolver { stage: String }
impl ResolveEndpoint for StageResolver {
    fn resolve_endpoint(&self, params: &Params) -> EndpointFuture<'_> {
        let stage = &self.stage;
        EndpointFuture::ready(Ok(Endpoint::builder().url(format!("{stage}.myservice.com")).build()))
    }
}
let resolver = StageResolver { stage: std::env::var("STAGE").unwrap() };
let config = aws_sdk_s3::Config::builder().endpoint_resolver(resolver).build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn set_endpoint_resolver(
    &mut self,
    endpoint_resolver: Option<SharedEndpointResolver>,
) -> &mut Self
 
pub fn set_endpoint_resolver( &mut self, endpoint_resolver: Option<SharedEndpointResolver>, ) -> &mut Self
Sets the endpoint resolver to use when making requests.
When unset, the client will used a generated endpoint resolver based on the endpoint resolution
rules for aws_sdk_s3.
Sourcepub fn retry_config(self, retry_config: RetryConfig) -> Self
 
pub fn retry_config(self, retry_config: RetryConfig) -> Self
Set the retry_config for the builder
§Examples
use aws_sdk_s3::config::Config;
use aws_sdk_s3::config::retry::RetryConfig;
let retry_config = RetryConfig::standard().with_max_attempts(5);
let config = Config::builder().retry_config(retry_config).build();Sourcepub fn set_retry_config(
    &mut self,
    retry_config: Option<RetryConfig>,
) -> &mut Self
 
pub fn set_retry_config( &mut self, retry_config: Option<RetryConfig>, ) -> &mut Self
Set the retry_config for the builder
§Examples
use aws_sdk_s3::config::{Builder, Config};
use aws_sdk_s3::config::retry::RetryConfig;
fn disable_retries(builder: &mut Builder) {
    let retry_config = RetryConfig::standard().with_max_attempts(1);
    builder.set_retry_config(Some(retry_config));
}
let mut builder = Config::builder();
disable_retries(&mut builder);
let config = builder.build();Sourcepub fn sleep_impl(self, sleep_impl: impl AsyncSleep + 'static) -> Self
 
pub fn sleep_impl(self, sleep_impl: impl AsyncSleep + 'static) -> Self
Set the sleep_impl for the builder
§Examples
use aws_sdk_s3::config::{AsyncSleep, Config, SharedAsyncSleep, Sleep};
#[derive(Debug)]
pub struct ForeverSleep;
impl AsyncSleep for ForeverSleep {
    fn sleep(&self, duration: std::time::Duration) -> Sleep {
        Sleep::new(std::future::pending())
    }
}
let sleep_impl = SharedAsyncSleep::new(ForeverSleep);
let config = Config::builder().sleep_impl(sleep_impl).build();Sourcepub fn set_sleep_impl(
    &mut self,
    sleep_impl: Option<SharedAsyncSleep>,
) -> &mut Self
 
pub fn set_sleep_impl( &mut self, sleep_impl: Option<SharedAsyncSleep>, ) -> &mut Self
Set the sleep_impl for the builder
§Examples
use aws_sdk_s3::config::{AsyncSleep, Builder, Config, SharedAsyncSleep, Sleep};
#[derive(Debug)]
pub struct ForeverSleep;
impl AsyncSleep for ForeverSleep {
    fn sleep(&self, duration: std::time::Duration) -> Sleep {
        Sleep::new(std::future::pending())
    }
}
fn set_never_ending_sleep_impl(builder: &mut Builder) {
    let sleep_impl = SharedAsyncSleep::new(ForeverSleep);
    builder.set_sleep_impl(Some(sleep_impl));
}
let mut builder = Config::builder();
set_never_ending_sleep_impl(&mut builder);
let config = builder.build();Sourcepub fn timeout_config(self, timeout_config: TimeoutConfig) -> Self
 
pub fn timeout_config(self, timeout_config: TimeoutConfig) -> Self
Set the timeout_config for the builder
§Examples
use aws_sdk_s3::config::Config;
use aws_sdk_s3::config::timeout::TimeoutConfig;
let timeout_config = TimeoutConfig::builder()
    .operation_attempt_timeout(Duration::from_secs(1))
    .build();
let config = Config::builder().timeout_config(timeout_config).build();Sourcepub fn set_timeout_config(
    &mut self,
    timeout_config: Option<TimeoutConfig>,
) -> &mut Self
 
pub fn set_timeout_config( &mut self, timeout_config: Option<TimeoutConfig>, ) -> &mut Self
Set the timeout_config for the builder.
Setting this to None has no effect if another source of configuration has set timeouts. If you
are attempting to disable timeouts, use TimeoutConfig::disabled
§Examples
use aws_sdk_s3::config::{Builder, Config};
use aws_sdk_s3::config::timeout::TimeoutConfig;
fn set_request_timeout(builder: &mut Builder) {
    let timeout_config = TimeoutConfig::builder()
        .operation_attempt_timeout(Duration::from_secs(1))
        .build();
    builder.set_timeout_config(Some(timeout_config));
}
let mut builder = Config::builder();
set_request_timeout(&mut builder);
let config = builder.build();Sourcepub fn retry_partition(self, retry_partition: RetryPartition) -> Self
 
pub fn retry_partition(self, retry_partition: RetryPartition) -> Self
Set the partition for retry-related state. When clients share a retry partition, they will also share things like token buckets and client rate limiters. By default, all clients for the same service will share a partition.
Sourcepub fn set_retry_partition(
    &mut self,
    retry_partition: Option<RetryPartition>,
) -> &mut Self
 
pub fn set_retry_partition( &mut self, retry_partition: Option<RetryPartition>, ) -> &mut Self
Set the partition for retry-related state. When clients share a retry partition, they will also share things like token buckets and client rate limiters. By default, all clients for the same service will share a partition.
Sourcepub fn identity_cache(
    self,
    identity_cache: impl ResolveCachedIdentity + 'static,
) -> Self
 
pub fn identity_cache( self, identity_cache: impl ResolveCachedIdentity + 'static, ) -> Self
Set the identity cache for auth.
The identity cache defaults to a lazy caching implementation that will resolve an identity when it is requested, and place it in the cache thereafter. Subsequent requests will take the value from the cache while it is still valid. Once it expires, the next request will result in refreshing the identity.
This configuration allows you to disable or change the default caching mechanism.
To use a custom caching mechanism, implement the ResolveCachedIdentity
trait and pass that implementation into this function.
§Examples
Disabling identity caching:
use aws_sdk_s3::config::IdentityCache;
let config = aws_sdk_s3::Config::builder()
    .identity_cache(IdentityCache::no_cache())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Customizing lazy caching:
use aws_sdk_s3::config::IdentityCache;
use std::time::Duration;
let config = aws_sdk_s3::Config::builder()
    .identity_cache(
        IdentityCache::lazy()
            // change the load timeout to 10 seconds
            .load_timeout(Duration::from_secs(10))
            .build()
    )
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn set_identity_cache(
    &mut self,
    identity_cache: impl ResolveCachedIdentity + 'static,
) -> &mut Self
 
pub fn set_identity_cache( &mut self, identity_cache: impl ResolveCachedIdentity + 'static, ) -> &mut Self
Set the identity cache for auth.
The identity cache defaults to a lazy caching implementation that will resolve an identity when it is requested, and place it in the cache thereafter. Subsequent requests will take the value from the cache while it is still valid. Once it expires, the next request will result in refreshing the identity.
This configuration allows you to disable or change the default caching mechanism.
To use a custom caching mechanism, implement the ResolveCachedIdentity
trait and pass that implementation into this function.
§Examples
Disabling identity caching:
use aws_sdk_s3::config::IdentityCache;
let config = aws_sdk_s3::Config::builder()
    .identity_cache(IdentityCache::no_cache())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Customizing lazy caching:
use aws_sdk_s3::config::IdentityCache;
use std::time::Duration;
let config = aws_sdk_s3::Config::builder()
    .identity_cache(
        IdentityCache::lazy()
            // change the load timeout to 10 seconds
            .load_timeout(Duration::from_secs(10))
            .build()
    )
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn interceptor(self, interceptor: impl Intercept + 'static) -> Self
 
pub fn interceptor(self, interceptor: impl Intercept + 'static) -> Self
Add an interceptor that runs at specific stages of the request execution pipeline.
Interceptors targeted at a certain stage are executed according to the pre-defined priority. The SDK provides a default set of interceptors. An interceptor configured by this method will run after those default interceptors.
§Examples
use aws_smithy_runtime_api::box_error::BoxError;
use aws_smithy_runtime_api::client::interceptors::context::BeforeTransmitInterceptorContextMut;
use aws_smithy_runtime_api::client::interceptors::Intercept;
use aws_smithy_runtime_api::client::runtime_components::RuntimeComponents;
use aws_smithy_types::config_bag::ConfigBag;
use aws_sdk_s3::config::Config;
use ::http::uri::Uri;
fn base_url() -> String {
    // ...
}
#[derive(Debug)]
pub struct UriModifierInterceptor;
impl Intercept for UriModifierInterceptor {
    fn name(&self) -> &'static str {
        "UriModifierInterceptor"
    }
    fn modify_before_signing(
        &self,
        context: &mut BeforeTransmitInterceptorContextMut<'_>,
        _runtime_components: &RuntimeComponents,
        _cfg: &mut ConfigBag,
    ) -> Result<(), BoxError> {
        let request = context.request_mut();
        let uri = format!("{}{}", base_url(), request.uri());
        *request.uri_mut() = uri.parse::<Uri>()?.into();
        Ok(())
    }
}
let config = Config::builder()
    .interceptor(UriModifierInterceptor)
    .build();Sourcepub fn push_interceptor(&mut self, interceptor: SharedInterceptor) -> &mut Self
 
pub fn push_interceptor(&mut self, interceptor: SharedInterceptor) -> &mut Self
Like Self::interceptor, but takes a SharedInterceptor.
Sourcepub fn set_interceptors(
    &mut self,
    interceptors: impl IntoIterator<Item = SharedInterceptor>,
) -> &mut Self
 
pub fn set_interceptors( &mut self, interceptors: impl IntoIterator<Item = SharedInterceptor>, ) -> &mut Self
Set SharedInterceptors for the builder.
Sourcepub fn time_source(self, time_source: impl TimeSource + 'static) -> Self
 
pub fn time_source(self, time_source: impl TimeSource + 'static) -> Self
Sets the time source used for this service
Sourcepub fn set_time_source(
    &mut self,
    time_source: Option<SharedTimeSource>,
) -> &mut Self
 
pub fn set_time_source( &mut self, time_source: Option<SharedTimeSource>, ) -> &mut Self
Sets the time source used for this service
Sourcepub fn retry_classifier(
    self,
    retry_classifier: impl ClassifyRetry + 'static,
) -> Self
 
pub fn retry_classifier( self, retry_classifier: impl ClassifyRetry + 'static, ) -> Self
Add type implementing ClassifyRetry that will be used by the
RetryStrategy to determine what responses should be retried.
A retry classifier configured by this method will run according to its priority.
§Examples
use aws_smithy_runtime_api::client::interceptors::context::InterceptorContext;
use aws_smithy_runtime_api::client::orchestrator::OrchestratorError;
use aws_smithy_runtime_api::client::retries::classifiers::{
    ClassifyRetry, RetryAction, RetryClassifierPriority,
};
use aws_smithy_types::error::metadata::ProvideErrorMetadata;
use aws_smithy_types::retry::ErrorKind;
use std::error::Error as StdError;
use std::marker::PhantomData;
use std::fmt;
use aws_sdk_s3::config::Config;
const RETRYABLE_ERROR_CODES: &[&str] = &[
    // List error codes to be retried here...
];
// When classifying at an operation's error type, classifiers require a generic parameter.
// When classifying the HTTP response alone, no generic is needed.
#[derive(Debug, Default)]
pub struct ExampleErrorCodeClassifier<E> {
    _inner: PhantomData<E>,
}
impl<E> ExampleErrorCodeClassifier<E> {
    pub fn new() -> Self {
        Self {
            _inner: PhantomData,
        }
    }
}
impl<E> ClassifyRetry for ExampleErrorCodeClassifier<E>
where
    // Adding a trait bound for ProvideErrorMetadata allows us to inspect the error code.
    E: StdError + ProvideErrorMetadata + Send + Sync + 'static,
{
    fn classify_retry(&self, ctx: &InterceptorContext) -> RetryAction {
        // Check for a result
        let output_or_error = ctx.output_or_error();
        // Check for an error
        let error = match output_or_error {
            Some(Ok(_)) | None => return RetryAction::NoActionIndicated,
              Some(Err(err)) => err,
        };
        // Downcast the generic error and extract the code
        let error_code = OrchestratorError::as_operation_error(error)
            .and_then(|err| err.downcast_ref::<E>())
            .and_then(|err| err.code());
        // If this error's code is in our list, return an action that tells the RetryStrategy to retry this request.
        if let Some(error_code) = error_code {
            if RETRYABLE_ERROR_CODES.contains(&error_code) {
                return RetryAction::transient_error();
            }
        }
        // Otherwise, return that no action is indicated i.e. that this classifier doesn't require a retry.
        // Another classifier may still classify this response as retryable.
        RetryAction::NoActionIndicated
    }
    fn name(&self) -> &'static str { "Example Error Code Classifier" }
}
let config = Config::builder()
    .retry_classifier(ExampleErrorCodeClassifier::<SomeOperationError>::new())
    .build();Sourcepub fn push_retry_classifier(
    &mut self,
    retry_classifier: SharedRetryClassifier,
) -> &mut Self
 
pub fn push_retry_classifier( &mut self, retry_classifier: SharedRetryClassifier, ) -> &mut Self
Like Self::retry_classifier, but takes a SharedRetryClassifier.
Sourcepub fn set_retry_classifiers(
    &mut self,
    retry_classifiers: impl IntoIterator<Item = SharedRetryClassifier>,
) -> &mut Self
 
pub fn set_retry_classifiers( &mut self, retry_classifiers: impl IntoIterator<Item = SharedRetryClassifier>, ) -> &mut Self
Set SharedRetryClassifiers for the builder, replacing any that
were previously set.
Sourcepub fn app_name(self, app_name: AppName) -> Self
 
pub fn app_name(self, app_name: AppName) -> Self
Sets the name of the app that is using the client.
This optional name is used to identify the application in the user agent that gets sent along with requests.
Sourcepub fn set_app_name(&mut self, app_name: Option<AppName>) -> &mut Self
 
pub fn set_app_name(&mut self, app_name: Option<AppName>) -> &mut Self
Sets the name of the app that is using the client.
This optional name is used to identify the application in the user agent that gets sent along with requests.
Sourcepub fn express_credentials_provider(
    self,
    credentials_provider: impl ProvideCredentials + 'static,
) -> Self
 
pub fn express_credentials_provider( self, credentials_provider: impl ProvideCredentials + 'static, ) -> Self
Sets the credentials provider for S3 Express One Zone
Sourcepub fn set_express_credentials_provider(
    &mut self,
    credentials_provider: Option<SharedCredentialsProvider>,
) -> &mut Self
 
pub fn set_express_credentials_provider( &mut self, credentials_provider: Option<SharedCredentialsProvider>, ) -> &mut Self
Sets the credentials provider for S3 Express One Zone
Sourcepub fn invocation_id_generator(
    self,
    gen: impl InvocationIdGenerator + 'static,
) -> Self
 
pub fn invocation_id_generator( self, gen: impl InvocationIdGenerator + 'static, ) -> Self
Overrides the default invocation ID generator.
The invocation ID generator generates ID values for the amz-sdk-invocation-id header. By default, this will be a random UUID. Overriding it may be useful in tests that examine the HTTP request and need to be deterministic.
Sourcepub fn set_invocation_id_generator(
    &mut self,
    gen: Option<SharedInvocationIdGenerator>,
) -> &mut Self
 
pub fn set_invocation_id_generator( &mut self, gen: Option<SharedInvocationIdGenerator>, ) -> &mut Self
Overrides the default invocation ID generator.
The invocation ID generator generates ID values for the amz-sdk-invocation-id header. By default, this will be a random UUID. Overriding it may be useful in tests that examine the HTTP request and need to be deterministic.
Sourcepub fn endpoint_url(self, endpoint_url: impl Into<String>) -> Self
 
pub fn endpoint_url(self, endpoint_url: impl Into<String>) -> Self
Sets the endpoint URL used to communicate with this service.
Note: this is used in combination with other endpoint rules, e.g. an API that applies a host-label prefix
will be prefixed onto this URL. To fully override the endpoint resolver, use
Builder::endpoint_resolver.
Sourcepub fn set_endpoint_url(&mut self, endpoint_url: Option<String>) -> &mut Self
 
pub fn set_endpoint_url(&mut self, endpoint_url: Option<String>) -> &mut Self
Sets the endpoint URL used to communicate with this service.
Note: this is used in combination with other endpoint rules, e.g. an API that applies a host-label prefix
will be prefixed onto this URL. To fully override the endpoint resolver, use
Builder::endpoint_resolver.
Sourcepub fn use_dual_stack(self, use_dual_stack: impl Into<bool>) -> Self
 
pub fn use_dual_stack(self, use_dual_stack: impl Into<bool>) -> Self
When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
Sourcepub fn set_use_dual_stack(&mut self, use_dual_stack: Option<bool>) -> &mut Self
 
pub fn set_use_dual_stack(&mut self, use_dual_stack: Option<bool>) -> &mut Self
When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
Sourcepub fn use_fips(self, use_fips: impl Into<bool>) -> Self
 
pub fn use_fips(self, use_fips: impl Into<bool>) -> Self
When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
Sourcepub fn set_use_fips(&mut self, use_fips: Option<bool>) -> &mut Self
 
pub fn set_use_fips(&mut self, use_fips: Option<bool>) -> &mut Self
When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
Sourcepub fn response_checksum_validation(
    self,
    response_checksum_validation: ResponseChecksumValidation,
) -> Self
 
pub fn response_checksum_validation( self, response_checksum_validation: ResponseChecksumValidation, ) -> Self
Set the ResponseChecksumValidation
to determine when checksum validation will be performed on response payloads.
Sourcepub fn set_response_checksum_validation(
    &mut self,
    response_checksum_validation: Option<ResponseChecksumValidation>,
) -> &mut Self
 
pub fn set_response_checksum_validation( &mut self, response_checksum_validation: Option<ResponseChecksumValidation>, ) -> &mut Self
Set the ResponseChecksumValidation
to determine when checksum validation will be performed on response payloads.
Sourcepub fn request_checksum_calculation(
    self,
    request_checksum_calculation: RequestChecksumCalculation,
) -> Self
 
pub fn request_checksum_calculation( self, request_checksum_calculation: RequestChecksumCalculation, ) -> Self
Set the RequestChecksumCalculation
to determine when a checksum will be calculated for request payloads.
Sourcepub fn set_request_checksum_calculation(
    &mut self,
    request_checksum_calculation: Option<RequestChecksumCalculation>,
) -> &mut Self
 
pub fn set_request_checksum_calculation( &mut self, request_checksum_calculation: Option<RequestChecksumCalculation>, ) -> &mut Self
Set the RequestChecksumCalculation
to determine when a checksum will be calculated for request payloads.
Sourcepub fn region(self, region: impl Into<Option<Region>>) -> Self
 
pub fn region(self, region: impl Into<Option<Region>>) -> Self
Sets the AWS region to use when making requests.
§Examples
use aws_types::region::Region;
use aws_sdk_s3::config::{Builder, Config};
let config = aws_sdk_s3::Config::builder()
    .region(Region::new("us-east-1"))
    .build();Sourcepub fn set_region(&mut self, region: Option<Region>) -> &mut Self
 
pub fn set_region(&mut self, region: Option<Region>) -> &mut Self
Sets the AWS region to use when making requests.
Sourcepub fn credentials_provider(
    self,
    credentials_provider: impl ProvideCredentials + 'static,
) -> Self
 
pub fn credentials_provider( self, credentials_provider: impl ProvideCredentials + 'static, ) -> Self
Sets the credentials provider for this service
Sourcepub fn set_credentials_provider(
    &mut self,
    credentials_provider: Option<SharedCredentialsProvider>,
) -> &mut Self
 
pub fn set_credentials_provider( &mut self, credentials_provider: Option<SharedCredentialsProvider>, ) -> &mut Self
Sets the credentials provider for this service
Sourcepub fn behavior_version(self, behavior_version: BehaviorVersion) -> Self
 
pub fn behavior_version(self, behavior_version: BehaviorVersion) -> Self
Sets the behavior major version.
Over time, new best-practice behaviors are introduced. However, these behaviors might not be backwards compatible. For example, a change which introduces new default timeouts or a new retry-mode for all operations might be the ideal behavior but could break existing applications.
§Examples
Set the behavior major version to latest. This is equivalent to enabling the behavior-version-latest cargo feature.
use aws_sdk_s3::config::BehaviorVersion;
let config = aws_sdk_s3::Config::builder()
    .behavior_version(BehaviorVersion::latest())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Customizing behavior major version:
use aws_sdk_s3::config::BehaviorVersion;
let config = aws_sdk_s3::Config::builder()
    .behavior_version(BehaviorVersion::v2023_11_09())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn set_behavior_version(
    &mut self,
    behavior_version: Option<BehaviorVersion>,
) -> &mut Self
 
pub fn set_behavior_version( &mut self, behavior_version: Option<BehaviorVersion>, ) -> &mut Self
Sets the behavior major version.
Over time, new best-practice behaviors are introduced. However, these behaviors might not be backwards compatible. For example, a change which introduces new default timeouts or a new retry-mode for all operations might be the ideal behavior but could break existing applications.
§Examples
Set the behavior major version to latest. This is equivalent to enabling the behavior-version-latest cargo feature.
use aws_sdk_s3::config::BehaviorVersion;
let config = aws_sdk_s3::Config::builder()
    .behavior_version(BehaviorVersion::latest())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Customizing behavior major version:
use aws_sdk_s3::config::BehaviorVersion;
let config = aws_sdk_s3::Config::builder()
    .behavior_version(BehaviorVersion::v2023_11_09())
    // ...
    .build();
let client = aws_sdk_s3::Client::from_conf(config);Sourcepub fn behavior_version_latest(self) -> Self
 
pub fn behavior_version_latest(self) -> Self
Convenience method to set the latest behavior major version
This is equivalent to enabling the behavior-version-latest Cargo feature
Sourcepub fn apply_test_defaults(&mut self) -> &mut Self
 Available on crate feature test-util only.
pub fn apply_test_defaults(&mut self) -> &mut Self
test-util only.Apply test defaults to the builder
Sourcepub fn with_test_defaults(self) -> Self
 Available on crate feature test-util only.
pub fn with_test_defaults(self) -> Self
test-util only.Apply test defaults to the builder
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Builder
impl !RefUnwindSafe for Builder
impl Send for Builder
impl Sync for Builder
impl Unpin for Builder
impl !UnwindSafe for Builder
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> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
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);