1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::get_bucket_website::_get_bucket_website_output::GetBucketWebsiteOutputBuilder;
34pub use crate::operation::get_bucket_website::_get_bucket_website_input::GetBucketWebsiteInputBuilder;
56impl crate::operation::get_bucket_website::builders::GetBucketWebsiteInputBuilder {
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_website::GetBucketWebsiteOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14crate::operation::get_bucket_website::GetBucketWebsiteError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18let mut fluent_builder = client.get_bucket_website();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21}
22}
23/// Fluent builder constructing a request to `GetBucketWebsite`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>Returns the website configuration for a bucket. To host website on Amazon S3, you can configure a bucket as website by adding a website configuration. For more information about hosting websites, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/WebsiteHosting.html">Hosting Websites on Amazon S3</a>.</p>
29/// <p>This GET action requires the <code>S3:GetBucketWebsite</code> permission. By default, only the bucket owner can read the bucket website configuration. However, bucket owners can allow other users to read the website configuration by writing a bucket policy granting them the <code>S3:GetBucketWebsite</code> permission.</p>
30/// <p>The following operations are related to <code>GetBucketWebsite</code>:</p>
31/// <ul>
32/// <li>
33/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteBucketWebsite.html">DeleteBucketWebsite</a></p></li>
34/// <li>
35/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketWebsite.html">PutBucketWebsite</a></p></li>
36/// </ul>
37#[derive(::std::clone::Clone, ::std::fmt::Debug)]
38pub struct GetBucketWebsiteFluentBuilder {
39 handle: ::std::sync::Arc<crate::client::Handle>,
40 inner: crate::operation::get_bucket_website::builders::GetBucketWebsiteInputBuilder,
41 config_override: ::std::option::Option<crate::config::Builder>,
42}
43impl
44crate::client::customize::internal::CustomizableSend<
45crate::operation::get_bucket_website::GetBucketWebsiteOutput,
46crate::operation::get_bucket_website::GetBucketWebsiteError,
47 > for GetBucketWebsiteFluentBuilder
48{
49fn send(
50self,
51 config_override: crate::config::Builder,
52 ) -> crate::client::customize::internal::BoxFuture<
53crate::client::customize::internal::SendResult<
54crate::operation::get_bucket_website::GetBucketWebsiteOutput,
55crate::operation::get_bucket_website::GetBucketWebsiteError,
56 >,
57 > {
58 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
59 }
60}
61impl GetBucketWebsiteFluentBuilder {
62/// Creates a new `GetBucketWebsiteFluentBuilder`.
63pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
64Self {
65 handle,
66 inner: ::std::default::Default::default(),
67 config_override: ::std::option::Option::None,
68 }
69 }
70/// Access the GetBucketWebsite as a reference.
71pub fn as_input(&self) -> &crate::operation::get_bucket_website::builders::GetBucketWebsiteInputBuilder {
72&self.inner
73 }
74/// Sends the request and returns the response.
75 ///
76 /// If an error occurs, an `SdkError` will be returned with additional details that
77 /// can be matched against.
78 ///
79 /// By default, any retryable failures will be retried twice. Retry behavior
80 /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
81 /// set when configuring the client.
82pub async fn send(
83self,
84 ) -> ::std::result::Result<
85crate::operation::get_bucket_website::GetBucketWebsiteOutput,
86 ::aws_smithy_runtime_api::client::result::SdkError<
87crate::operation::get_bucket_website::GetBucketWebsiteError,
88 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
89 >,
90 > {
91let input = self
92.inner
93 .build()
94 .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
95let runtime_plugins = crate::operation::get_bucket_website::GetBucketWebsite::operation_runtime_plugins(
96self.handle.runtime_plugins.clone(),
97&self.handle.conf,
98self.config_override,
99 );
100crate::operation::get_bucket_website::GetBucketWebsite::orchestrate(&runtime_plugins, input).await
101}
102103/// Consumes this builder, creating a customizable operation that can be modified before being sent.
104pub fn customize(
105self,
106 ) -> crate::client::customize::CustomizableOperation<
107crate::operation::get_bucket_website::GetBucketWebsiteOutput,
108crate::operation::get_bucket_website::GetBucketWebsiteError,
109Self,
110 > {
111crate::client::customize::CustomizableOperation::new(self)
112 }
113pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
114self.set_config_override(::std::option::Option::Some(config_override.into()));
115self
116}
117118pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
119self.config_override = config_override;
120self
121}
122/// <p>The bucket name for which to get the website configuration.</p>
123pub fn bucket(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
124self.inner = self.inner.bucket(input.into());
125self
126}
127/// <p>The bucket name for which to get the website configuration.</p>
128pub fn set_bucket(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
129self.inner = self.inner.set_bucket(input);
130self
131}
132/// <p>The bucket name for which to get the website configuration.</p>
133pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
134self.inner.get_bucket()
135 }
136/// <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>
137pub fn expected_bucket_owner(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
138self.inner = self.inner.expected_bucket_owner(input.into());
139self
140}
141/// <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>
142pub fn set_expected_bucket_owner(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
143self.inner = self.inner.set_expected_bucket_owner(input);
144self
145}
146/// <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>
147pub fn get_expected_bucket_owner(&self) -> &::std::option::Option<::std::string::String> {
148self.inner.get_expected_bucket_owner()
149 }
150}