aws_sdk_s3control/operation/describe_multi_region_access_point_operation/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::describe_multi_region_access_point_operation::_describe_multi_region_access_point_operation_output::DescribeMultiRegionAccessPointOperationOutputBuilder;
3
4pub use crate::operation::describe_multi_region_access_point_operation::_describe_multi_region_access_point_operation_input::DescribeMultiRegionAccessPointOperationInputBuilder;
5
6impl crate::operation::describe_multi_region_access_point_operation::builders::DescribeMultiRegionAccessPointOperationInputBuilder {
7    /// Sends a request with this input using the given client.
8    pub async fn send_with(
9        self,
10        client: &crate::Client,
11    ) -> ::std::result::Result<
12        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.describe_multi_region_access_point_operation();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `DescribeMultiRegionAccessPointOperation`.
24///
25/// <note>
26/// <p>This operation is not supported by directory buckets.</p>
27/// </note>
28/// <p>Retrieves the status of an asynchronous request to manage a Multi-Region Access Point. For more information about managing Multi-Region Access Points and how asynchronous requests work, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/MrapOperations.html">Using Multi-Region Access Points</a> in the <i>Amazon S3 User Guide</i>.</p>
29/// <p>The following actions are related to <code>GetMultiRegionAccessPoint</code>:</p>
30/// <ul>
31/// <li>
32/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_CreateMultiRegionAccessPoint.html">CreateMultiRegionAccessPoint</a></p></li>
33/// <li>
34/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_DeleteMultiRegionAccessPoint.html">DeleteMultiRegionAccessPoint</a></p></li>
35/// <li>
36/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_GetMultiRegionAccessPoint.html">GetMultiRegionAccessPoint</a></p></li>
37/// <li>
38/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_ListMultiRegionAccessPoints.html">ListMultiRegionAccessPoints</a></p></li>
39/// </ul><important>
40/// <p>You must URL encode any signed header values that contain spaces. For example, if your header value is <code>my file.txt</code>, containing two spaces after <code>my</code>, you must URL encode this value to <code>my%20%20file.txt</code>.</p>
41/// </important>
42#[derive(::std::clone::Clone, ::std::fmt::Debug)]
43pub struct DescribeMultiRegionAccessPointOperationFluentBuilder {
44    handle: ::std::sync::Arc<crate::client::Handle>,
45    inner: crate::operation::describe_multi_region_access_point_operation::builders::DescribeMultiRegionAccessPointOperationInputBuilder,
46    config_override: ::std::option::Option<crate::config::Builder>,
47}
48impl
49    crate::client::customize::internal::CustomizableSend<
50        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationOutput,
51        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationError,
52    > for DescribeMultiRegionAccessPointOperationFluentBuilder
53{
54    fn send(
55        self,
56        config_override: crate::config::Builder,
57    ) -> crate::client::customize::internal::BoxFuture<
58        crate::client::customize::internal::SendResult<
59            crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationOutput,
60            crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationError,
61        >,
62    > {
63        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
64    }
65}
66impl DescribeMultiRegionAccessPointOperationFluentBuilder {
67    /// Creates a new `DescribeMultiRegionAccessPointOperationFluentBuilder`.
68    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
69        Self {
70            handle,
71            inner: ::std::default::Default::default(),
72            config_override: ::std::option::Option::None,
73        }
74    }
75    /// Access the DescribeMultiRegionAccessPointOperation as a reference.
76    pub fn as_input(
77        &self,
78    ) -> &crate::operation::describe_multi_region_access_point_operation::builders::DescribeMultiRegionAccessPointOperationInputBuilder {
79        &self.inner
80    }
81    /// Sends the request and returns the response.
82    ///
83    /// If an error occurs, an `SdkError` will be returned with additional details that
84    /// can be matched against.
85    ///
86    /// By default, any retryable failures will be retried twice. Retry behavior
87    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
88    /// set when configuring the client.
89    pub async fn send(
90        self,
91    ) -> ::std::result::Result<
92        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationOutput,
93        ::aws_smithy_runtime_api::client::result::SdkError<
94            crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationError,
95            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
96        >,
97    > {
98        let input = self
99            .inner
100            .build()
101            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
102        let runtime_plugins =
103            crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperation::operation_runtime_plugins(
104                self.handle.runtime_plugins.clone(),
105                &self.handle.conf,
106                self.config_override,
107            );
108        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperation::orchestrate(&runtime_plugins, input)
109            .await
110    }
111
112    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
113    pub fn customize(
114        self,
115    ) -> crate::client::customize::CustomizableOperation<
116        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationOutput,
117        crate::operation::describe_multi_region_access_point_operation::DescribeMultiRegionAccessPointOperationError,
118        Self,
119    > {
120        crate::client::customize::CustomizableOperation::new(self)
121    }
122    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
123        self.set_config_override(::std::option::Option::Some(config_override.into()));
124        self
125    }
126
127    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
128        self.config_override = config_override;
129        self
130    }
131    /// <p>The Amazon Web Services account ID for the owner of the Multi-Region Access Point.</p>
132    pub fn account_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
133        self.inner = self.inner.account_id(input.into());
134        self
135    }
136    /// <p>The Amazon Web Services account ID for the owner of the Multi-Region Access Point.</p>
137    pub fn set_account_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
138        self.inner = self.inner.set_account_id(input);
139        self
140    }
141    /// <p>The Amazon Web Services account ID for the owner of the Multi-Region Access Point.</p>
142    pub fn get_account_id(&self) -> &::std::option::Option<::std::string::String> {
143        self.inner.get_account_id()
144    }
145    /// <p>The request token associated with the request you want to know about. This request token is returned as part of the response when you make an asynchronous request. You provide this token to query about the status of the asynchronous action.</p>
146    pub fn request_token_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
147        self.inner = self.inner.request_token_arn(input.into());
148        self
149    }
150    /// <p>The request token associated with the request you want to know about. This request token is returned as part of the response when you make an asynchronous request. You provide this token to query about the status of the asynchronous action.</p>
151    pub fn set_request_token_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
152        self.inner = self.inner.set_request_token_arn(input);
153        self
154    }
155    /// <p>The request token associated with the request you want to know about. This request token is returned as part of the response when you make an asynchronous request. You provide this token to query about the status of the asynchronous action.</p>
156    pub fn get_request_token_arn(&self) -> &::std::option::Option<::std::string::String> {
157        self.inner.get_request_token_arn()
158    }
159}