1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::delete_bucket_replication::_delete_bucket_replication_output::DeleteBucketReplicationOutputBuilder;
34pub use crate::operation::delete_bucket_replication::_delete_bucket_replication_input::DeleteBucketReplicationInputBuilder;
56impl crate::operation::delete_bucket_replication::builders::DeleteBucketReplicationInputBuilder {
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::delete_bucket_replication::DeleteBucketReplicationOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14crate::operation::delete_bucket_replication::DeleteBucketReplicationError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18let mut fluent_builder = client.delete_bucket_replication();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21}
22}
23/// Fluent builder constructing a request to `DeleteBucketReplication`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>Deletes the replication configuration from the bucket.</p>
29/// <p>To use this operation, you must have permissions to perform the <code>s3:PutReplicationConfiguration</code> action. The bucket owner has these permissions by default and can grant it 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><note>
30/// <p>It can take a while for the deletion of a replication configuration to fully propagate.</p>
31/// </note>
32/// <p>For information about replication configuration, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/replication.html">Replication</a> in the <i>Amazon S3 User Guide</i>.</p>
33/// <p>The following operations are related to <code>DeleteBucketReplication</code>:</p>
34/// <ul>
35/// <li>
36/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketReplication.html">PutBucketReplication</a></p></li>
37/// <li>
38/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetBucketReplication.html">GetBucketReplication</a></p></li>
39/// </ul>
40#[derive(::std::clone::Clone, ::std::fmt::Debug)]
41pub struct DeleteBucketReplicationFluentBuilder {
42 handle: ::std::sync::Arc<crate::client::Handle>,
43 inner: crate::operation::delete_bucket_replication::builders::DeleteBucketReplicationInputBuilder,
44 config_override: ::std::option::Option<crate::config::Builder>,
45}
46impl
47crate::client::customize::internal::CustomizableSend<
48crate::operation::delete_bucket_replication::DeleteBucketReplicationOutput,
49crate::operation::delete_bucket_replication::DeleteBucketReplicationError,
50 > for DeleteBucketReplicationFluentBuilder
51{
52fn send(
53self,
54 config_override: crate::config::Builder,
55 ) -> crate::client::customize::internal::BoxFuture<
56crate::client::customize::internal::SendResult<
57crate::operation::delete_bucket_replication::DeleteBucketReplicationOutput,
58crate::operation::delete_bucket_replication::DeleteBucketReplicationError,
59 >,
60 > {
61 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
62 }
63}
64impl DeleteBucketReplicationFluentBuilder {
65/// Creates a new `DeleteBucketReplicationFluentBuilder`.
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 DeleteBucketReplication as a reference.
74pub fn as_input(&self) -> &crate::operation::delete_bucket_replication::builders::DeleteBucketReplicationInputBuilder {
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::delete_bucket_replication::DeleteBucketReplicationOutput,
89 ::aws_smithy_runtime_api::client::result::SdkError<
90crate::operation::delete_bucket_replication::DeleteBucketReplicationError,
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::delete_bucket_replication::DeleteBucketReplication::operation_runtime_plugins(
99self.handle.runtime_plugins.clone(),
100&self.handle.conf,
101self.config_override,
102 );
103crate::operation::delete_bucket_replication::DeleteBucketReplication::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::delete_bucket_replication::DeleteBucketReplicationOutput,
111crate::operation::delete_bucket_replication::DeleteBucketReplicationError,
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 bucket name.</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 bucket name.</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 bucket name.</p>
136pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
137self.inner.get_bucket()
138 }
139/// <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>
140pub fn expected_bucket_owner(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
141self.inner = self.inner.expected_bucket_owner(input.into());
142self
143}
144/// <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>
145pub fn set_expected_bucket_owner(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
146self.inner = self.inner.set_expected_bucket_owner(input);
147self
148}
149/// <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>
150pub fn get_expected_bucket_owner(&self) -> &::std::option::Option<::std::string::String> {
151self.inner.get_expected_bucket_owner()
152 }
153}