1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::get_bucket_inventory_configuration::_get_bucket_inventory_configuration_output::GetBucketInventoryConfigurationOutputBuilder;
34pub use crate::operation::get_bucket_inventory_configuration::_get_bucket_inventory_configuration_input::GetBucketInventoryConfigurationInputBuilder;
56impl crate::operation::get_bucket_inventory_configuration::builders::GetBucketInventoryConfigurationInputBuilder {
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_inventory_configuration::GetBucketInventoryConfigurationOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18let mut fluent_builder = client.get_bucket_inventory_configuration();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21}
22}
23/// Fluent builder constructing a request to `GetBucketInventoryConfiguration`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>Returns an inventory configuration (identified by the inventory configuration ID) from the bucket.</p>
29/// <p>To use this operation, you must have permissions to perform the <code>s3:GetInventoryConfiguration</code> action. The bucket owner has this permission by default and 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>.</p>
30/// <p>For information about the Amazon S3 inventory feature, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/storage-inventory.html">Amazon S3 Inventory</a>.</p>
31/// <p>The following operations are related to <code>GetBucketInventoryConfiguration</code>:</p>
32/// <ul>
33/// <li>
34/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteBucketInventoryConfiguration.html">DeleteBucketInventoryConfiguration</a></p></li>
35/// <li>
36/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListBucketInventoryConfigurations.html">ListBucketInventoryConfigurations</a></p></li>
37/// <li>
38/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketInventoryConfiguration.html">PutBucketInventoryConfiguration</a></p></li>
39/// </ul>
40#[derive(::std::clone::Clone, ::std::fmt::Debug)]
41pub struct GetBucketInventoryConfigurationFluentBuilder {
42 handle: ::std::sync::Arc<crate::client::Handle>,
43 inner: crate::operation::get_bucket_inventory_configuration::builders::GetBucketInventoryConfigurationInputBuilder,
44 config_override: ::std::option::Option<crate::config::Builder>,
45}
46impl
47crate::client::customize::internal::CustomizableSend<
48crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationOutput,
49crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationError,
50 > for GetBucketInventoryConfigurationFluentBuilder
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_inventory_configuration::GetBucketInventoryConfigurationOutput,
58crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationError,
59 >,
60 > {
61 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
62 }
63}
64impl GetBucketInventoryConfigurationFluentBuilder {
65/// Creates a new `GetBucketInventoryConfigurationFluentBuilder`.
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 GetBucketInventoryConfiguration as a reference.
74pub fn as_input(&self) -> &crate::operation::get_bucket_inventory_configuration::builders::GetBucketInventoryConfigurationInputBuilder {
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_inventory_configuration::GetBucketInventoryConfigurationOutput,
89 ::aws_smithy_runtime_api::client::result::SdkError<
90crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationError,
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_inventory_configuration::GetBucketInventoryConfiguration::operation_runtime_plugins(
99self.handle.runtime_plugins.clone(),
100&self.handle.conf,
101self.config_override,
102 );
103crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfiguration::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_inventory_configuration::GetBucketInventoryConfigurationOutput,
111crate::operation::get_bucket_inventory_configuration::GetBucketInventoryConfigurationError,
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 containing the inventory configuration to retrieve.</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 containing the inventory configuration to retrieve.</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 containing the inventory configuration to retrieve.</p>
136pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
137self.inner.get_bucket()
138 }
139/// <p>The ID used to identify the inventory 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 used to identify the inventory 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 used to identify the inventory 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}