aws_sdk_accessanalyzer/operation/create_access_preview/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::create_access_preview::_create_access_preview_output::CreateAccessPreviewOutputBuilder;
3
4pub use crate::operation::create_access_preview::_create_access_preview_input::CreateAccessPreviewInputBuilder;
5
6impl crate::operation::create_access_preview::builders::CreateAccessPreviewInputBuilder {
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::create_access_preview::CreateAccessPreviewOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::create_access_preview::CreateAccessPreviewError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.create_access_preview();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `CreateAccessPreview`.
24///
25/// <p>Creates an access preview that allows you to preview IAM Access Analyzer findings for your resource before deploying resource permissions.</p>
26#[derive(::std::clone::Clone, ::std::fmt::Debug)]
27pub struct CreateAccessPreviewFluentBuilder {
28    handle: ::std::sync::Arc<crate::client::Handle>,
29    inner: crate::operation::create_access_preview::builders::CreateAccessPreviewInputBuilder,
30    config_override: ::std::option::Option<crate::config::Builder>,
31}
32impl
33    crate::client::customize::internal::CustomizableSend<
34        crate::operation::create_access_preview::CreateAccessPreviewOutput,
35        crate::operation::create_access_preview::CreateAccessPreviewError,
36    > for CreateAccessPreviewFluentBuilder
37{
38    fn send(
39        self,
40        config_override: crate::config::Builder,
41    ) -> crate::client::customize::internal::BoxFuture<
42        crate::client::customize::internal::SendResult<
43            crate::operation::create_access_preview::CreateAccessPreviewOutput,
44            crate::operation::create_access_preview::CreateAccessPreviewError,
45        >,
46    > {
47        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
48    }
49}
50impl CreateAccessPreviewFluentBuilder {
51    /// Creates a new `CreateAccessPreviewFluentBuilder`.
52    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
53        Self {
54            handle,
55            inner: ::std::default::Default::default(),
56            config_override: ::std::option::Option::None,
57        }
58    }
59    /// Access the CreateAccessPreview as a reference.
60    pub fn as_input(&self) -> &crate::operation::create_access_preview::builders::CreateAccessPreviewInputBuilder {
61        &self.inner
62    }
63    /// Sends the request and returns the response.
64    ///
65    /// If an error occurs, an `SdkError` will be returned with additional details that
66    /// can be matched against.
67    ///
68    /// By default, any retryable failures will be retried twice. Retry behavior
69    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
70    /// set when configuring the client.
71    pub async fn send(
72        self,
73    ) -> ::std::result::Result<
74        crate::operation::create_access_preview::CreateAccessPreviewOutput,
75        ::aws_smithy_runtime_api::client::result::SdkError<
76            crate::operation::create_access_preview::CreateAccessPreviewError,
77            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
78        >,
79    > {
80        let input = self
81            .inner
82            .build()
83            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
84        let runtime_plugins = crate::operation::create_access_preview::CreateAccessPreview::operation_runtime_plugins(
85            self.handle.runtime_plugins.clone(),
86            &self.handle.conf,
87            self.config_override,
88        );
89        crate::operation::create_access_preview::CreateAccessPreview::orchestrate(&runtime_plugins, input).await
90    }
91
92    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
93    pub fn customize(
94        self,
95    ) -> crate::client::customize::CustomizableOperation<
96        crate::operation::create_access_preview::CreateAccessPreviewOutput,
97        crate::operation::create_access_preview::CreateAccessPreviewError,
98        Self,
99    > {
100        crate::client::customize::CustomizableOperation::new(self)
101    }
102    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
103        self.set_config_override(::std::option::Option::Some(config_override.into()));
104        self
105    }
106
107    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
108        self.config_override = config_override;
109        self
110    }
111    /// <p>The <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources">ARN of the account analyzer</a> used to generate the access preview. You can only create an access preview for analyzers with an <code>Account</code> type and <code>Active</code> status.</p>
112    pub fn analyzer_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
113        self.inner = self.inner.analyzer_arn(input.into());
114        self
115    }
116    /// <p>The <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources">ARN of the account analyzer</a> used to generate the access preview. You can only create an access preview for analyzers with an <code>Account</code> type and <code>Active</code> status.</p>
117    pub fn set_analyzer_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
118        self.inner = self.inner.set_analyzer_arn(input);
119        self
120    }
121    /// <p>The <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources">ARN of the account analyzer</a> used to generate the access preview. You can only create an access preview for analyzers with an <code>Account</code> type and <code>Active</code> status.</p>
122    pub fn get_analyzer_arn(&self) -> &::std::option::Option<::std::string::String> {
123        self.inner.get_analyzer_arn()
124    }
125    ///
126    /// Adds a key-value pair to `configurations`.
127    ///
128    /// To override the contents of this collection use [`set_configurations`](Self::set_configurations).
129    ///
130    /// <p>Access control configuration for your resource that is used to generate the access preview. The access preview includes findings for external access allowed to the resource with the proposed access control configuration. The configuration must contain exactly one element.</p>
131    pub fn configurations(mut self, k: impl ::std::convert::Into<::std::string::String>, v: crate::types::Configuration) -> Self {
132        self.inner = self.inner.configurations(k.into(), v);
133        self
134    }
135    /// <p>Access control configuration for your resource that is used to generate the access preview. The access preview includes findings for external access allowed to the resource with the proposed access control configuration. The configuration must contain exactly one element.</p>
136    pub fn set_configurations(
137        mut self,
138        input: ::std::option::Option<::std::collections::HashMap<::std::string::String, crate::types::Configuration>>,
139    ) -> Self {
140        self.inner = self.inner.set_configurations(input);
141        self
142    }
143    /// <p>Access control configuration for your resource that is used to generate the access preview. The access preview includes findings for external access allowed to the resource with the proposed access control configuration. The configuration must contain exactly one element.</p>
144    pub fn get_configurations(&self) -> &::std::option::Option<::std::collections::HashMap<::std::string::String, crate::types::Configuration>> {
145        self.inner.get_configurations()
146    }
147    /// <p>A client token.</p>
148    pub fn client_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
149        self.inner = self.inner.client_token(input.into());
150        self
151    }
152    /// <p>A client token.</p>
153    pub fn set_client_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
154        self.inner = self.inner.set_client_token(input);
155        self
156    }
157    /// <p>A client token.</p>
158    pub fn get_client_token(&self) -> &::std::option::Option<::std::string::String> {
159        self.inner.get_client_token()
160    }
161}