1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::delete_public_access_block::_delete_public_access_block_output::DeletePublicAccessBlockOutputBuilder;
34pub use crate::operation::delete_public_access_block::_delete_public_access_block_input::DeletePublicAccessBlockInputBuilder;
56impl crate::operation::delete_public_access_block::builders::DeletePublicAccessBlockInputBuilder {
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_public_access_block::DeletePublicAccessBlockOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14crate::operation::delete_public_access_block::DeletePublicAccessBlockError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18let mut fluent_builder = client.delete_public_access_block();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21}
22}
23/// Fluent builder constructing a request to `DeletePublicAccessBlock`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>Removes the <code>PublicAccessBlock</code> configuration for an Amazon S3 bucket. To use this operation, you must have the <code>s3:PutBucketPublicAccessBlock</code> permission. 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>
29/// <p>The following operations are related to <code>DeletePublicAccessBlock</code>:</p>
30/// <ul>
31/// <li>
32/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/access-control-block-public-access.html">Using Amazon S3 Block Public Access</a></p></li>
33/// <li>
34/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetPublicAccessBlock.html">GetPublicAccessBlock</a></p></li>
35/// <li>
36/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutPublicAccessBlock.html">PutPublicAccessBlock</a></p></li>
37/// <li>
38/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetBucketPolicyStatus.html">GetBucketPolicyStatus</a></p></li>
39/// </ul>
40#[derive(::std::clone::Clone, ::std::fmt::Debug)]
41pub struct DeletePublicAccessBlockFluentBuilder {
42 handle: ::std::sync::Arc<crate::client::Handle>,
43 inner: crate::operation::delete_public_access_block::builders::DeletePublicAccessBlockInputBuilder,
44 config_override: ::std::option::Option<crate::config::Builder>,
45}
46impl
47crate::client::customize::internal::CustomizableSend<
48crate::operation::delete_public_access_block::DeletePublicAccessBlockOutput,
49crate::operation::delete_public_access_block::DeletePublicAccessBlockError,
50 > for DeletePublicAccessBlockFluentBuilder
51{
52fn send(
53self,
54 config_override: crate::config::Builder,
55 ) -> crate::client::customize::internal::BoxFuture<
56crate::client::customize::internal::SendResult<
57crate::operation::delete_public_access_block::DeletePublicAccessBlockOutput,
58crate::operation::delete_public_access_block::DeletePublicAccessBlockError,
59 >,
60 > {
61 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
62 }
63}
64impl DeletePublicAccessBlockFluentBuilder {
65/// Creates a new `DeletePublicAccessBlockFluentBuilder`.
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 DeletePublicAccessBlock as a reference.
74pub fn as_input(&self) -> &crate::operation::delete_public_access_block::builders::DeletePublicAccessBlockInputBuilder {
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_public_access_block::DeletePublicAccessBlockOutput,
89 ::aws_smithy_runtime_api::client::result::SdkError<
90crate::operation::delete_public_access_block::DeletePublicAccessBlockError,
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_public_access_block::DeletePublicAccessBlock::operation_runtime_plugins(
99self.handle.runtime_plugins.clone(),
100&self.handle.conf,
101self.config_override,
102 );
103crate::operation::delete_public_access_block::DeletePublicAccessBlock::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_public_access_block::DeletePublicAccessBlockOutput,
111crate::operation::delete_public_access_block::DeletePublicAccessBlockError,
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 Amazon S3 bucket whose <code>PublicAccessBlock</code> configuration you want to delete.</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 Amazon S3 bucket whose <code>PublicAccessBlock</code> configuration you want to delete.</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 Amazon S3 bucket whose <code>PublicAccessBlock</code> configuration you want to delete.</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}