1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::get_bucket_analytics_configuration::_get_bucket_analytics_configuration_output::GetBucketAnalyticsConfigurationOutputBuilder;
34pub use crate::operation::get_bucket_analytics_configuration::_get_bucket_analytics_configuration_input::GetBucketAnalyticsConfigurationInputBuilder;
56impl crate::operation::get_bucket_analytics_configuration::builders::GetBucketAnalyticsConfigurationInputBuilder {
7/// Sends a request with this input using the given client.
8pub async fn send_with(
9self,
10 client: &crate::Client,
11 ) -> ::std::result::Result<
12crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18let mut fluent_builder = client.get_bucket_analytics_configuration();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21}
22}
23/// Fluent builder constructing a request to `GetBucketAnalyticsConfiguration`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>This implementation of the GET action returns an analytics configuration (identified by the analytics configuration ID) from the bucket.</p>
29/// <p>To use this operation, you must have permissions to perform the <code>s3:GetAnalyticsConfiguration</code> action. The bucket owner has this permission by default. The bucket owner can grant this permission to others. For more information about permissions, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/using-with-s3-actions.html#using-with-s3-actions-related-to-bucket-subresources"> Permissions Related to Bucket Subresource Operations</a> and <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/s3-access-control.html">Managing Access Permissions to Your Amazon S3 Resources</a> in the <i>Amazon S3 User Guide</i>.</p>
30/// <p>For information about Amazon S3 analytics feature, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/analytics-storage-class.html">Amazon S3 Analytics – Storage Class Analysis</a> in the <i>Amazon S3 User Guide</i>.</p>
31/// <p>The following operations are related to <code>GetBucketAnalyticsConfiguration</code>:</p>
32/// <ul>
33/// <li>
34/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteBucketAnalyticsConfiguration.html">DeleteBucketAnalyticsConfiguration</a></p></li>
35/// <li>
36/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListBucketAnalyticsConfigurations.html">ListBucketAnalyticsConfigurations</a></p></li>
37/// <li>
38/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketAnalyticsConfiguration.html">PutBucketAnalyticsConfiguration</a></p></li>
39/// </ul>
40#[derive(::std::clone::Clone, ::std::fmt::Debug)]
41pub struct GetBucketAnalyticsConfigurationFluentBuilder {
42 handle: ::std::sync::Arc<crate::client::Handle>,
43 inner: crate::operation::get_bucket_analytics_configuration::builders::GetBucketAnalyticsConfigurationInputBuilder,
44 config_override: ::std::option::Option<crate::config::Builder>,
45}
46impl
47crate::client::customize::internal::CustomizableSend<
48crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationOutput,
49crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationError,
50 > for GetBucketAnalyticsConfigurationFluentBuilder
51{
52fn send(
53self,
54 config_override: crate::config::Builder,
55 ) -> crate::client::customize::internal::BoxFuture<
56crate::client::customize::internal::SendResult<
57crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationOutput,
58crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationError,
59 >,
60 > {
61 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
62 }
63}
64impl GetBucketAnalyticsConfigurationFluentBuilder {
65/// Creates a new `GetBucketAnalyticsConfigurationFluentBuilder`.
66pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
67Self {
68 handle,
69 inner: ::std::default::Default::default(),
70 config_override: ::std::option::Option::None,
71 }
72 }
73/// Access the GetBucketAnalyticsConfiguration as a reference.
74pub fn as_input(&self) -> &crate::operation::get_bucket_analytics_configuration::builders::GetBucketAnalyticsConfigurationInputBuilder {
75&self.inner
76 }
77/// Sends the request and returns the response.
78 ///
79 /// If an error occurs, an `SdkError` will be returned with additional details that
80 /// can be matched against.
81 ///
82 /// By default, any retryable failures will be retried twice. Retry behavior
83 /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
84 /// set when configuring the client.
85pub async fn send(
86self,
87 ) -> ::std::result::Result<
88crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationOutput,
89 ::aws_smithy_runtime_api::client::result::SdkError<
90crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationError,
91 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
92 >,
93 > {
94let input = self
95.inner
96 .build()
97 .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
98let runtime_plugins = crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfiguration::operation_runtime_plugins(
99self.handle.runtime_plugins.clone(),
100&self.handle.conf,
101self.config_override,
102 );
103crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfiguration::orchestrate(&runtime_plugins, input).await
104}
105106/// Consumes this builder, creating a customizable operation that can be modified before being sent.
107pub fn customize(
108self,
109 ) -> crate::client::customize::CustomizableOperation<
110crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationOutput,
111crate::operation::get_bucket_analytics_configuration::GetBucketAnalyticsConfigurationError,
112Self,
113 > {
114crate::client::customize::CustomizableOperation::new(self)
115 }
116pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
117self.set_config_override(::std::option::Option::Some(config_override.into()));
118self
119}
120121pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
122self.config_override = config_override;
123self
124}
125/// <p>The name of the bucket from which an analytics configuration is retrieved.</p>
126pub fn bucket(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
127self.inner = self.inner.bucket(input.into());
128self
129}
130/// <p>The name of the bucket from which an analytics configuration is retrieved.</p>
131pub fn set_bucket(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
132self.inner = self.inner.set_bucket(input);
133self
134}
135/// <p>The name of the bucket from which an analytics configuration is retrieved.</p>
136pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
137self.inner.get_bucket()
138 }
139/// <p>The ID that identifies the analytics configuration.</p>
140pub fn id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
141self.inner = self.inner.id(input.into());
142self
143}
144/// <p>The ID that identifies the analytics configuration.</p>
145pub fn set_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
146self.inner = self.inner.set_id(input);
147self
148}
149/// <p>The ID that identifies the analytics configuration.</p>
150pub fn get_id(&self) -> &::std::option::Option<::std::string::String> {
151self.inner.get_id()
152 }
153/// <p>The account ID of the expected bucket owner. If the account ID that you provide does not match the actual owner of the bucket, the request fails with the HTTP status code <code>403 Forbidden</code> (access denied).</p>
154pub fn expected_bucket_owner(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
155self.inner = self.inner.expected_bucket_owner(input.into());
156self
157}
158/// <p>The account ID of the expected bucket owner. If the account ID that you provide does not match the actual owner of the bucket, the request fails with the HTTP status code <code>403 Forbidden</code> (access denied).</p>
159pub fn set_expected_bucket_owner(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
160self.inner = self.inner.set_expected_bucket_owner(input);
161self
162}
163/// <p>The account ID of the expected bucket owner. If the account ID that you provide does not match the actual owner of the bucket, the request fails with the HTTP status code <code>403 Forbidden</code> (access denied).</p>
164pub fn get_expected_bucket_owner(&self) -> &::std::option::Option<::std::string::String> {
165self.inner.get_expected_bucket_owner()
166 }
167}