aws_sdk_ec2/operation/describe_vpc_encryption_controls/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::describe_vpc_encryption_controls::_describe_vpc_encryption_controls_output::DescribeVpcEncryptionControlsOutputBuilder;
3
4pub use crate::operation::describe_vpc_encryption_controls::_describe_vpc_encryption_controls_input::DescribeVpcEncryptionControlsInputBuilder;
5
6impl crate::operation::describe_vpc_encryption_controls::builders::DescribeVpcEncryptionControlsInputBuilder {
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_vpc_encryption_controls::DescribeVpcEncryptionControlsOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.describe_vpc_encryption_controls();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `DescribeVpcEncryptionControls`.
24///
25/// <p>Describes one or more VPC Encryption Control configurations. VPC Encryption Control enables you to enforce encryption for all data in transit within and between VPCs to meet compliance requirements You can filter the results to return information about specific encryption controls or VPCs.</p>
26/// <p>For more information, see <a href="https://docs.aws.amazon.com/vpc/latest/userguide/vpc-encryption-controls.html">Enforce VPC encryption in transit</a> in the <i>Amazon VPC User Guide</i>.</p>
27#[derive(::std::clone::Clone, ::std::fmt::Debug)]
28pub struct DescribeVpcEncryptionControlsFluentBuilder {
29    handle: ::std::sync::Arc<crate::client::Handle>,
30    inner: crate::operation::describe_vpc_encryption_controls::builders::DescribeVpcEncryptionControlsInputBuilder,
31    config_override: ::std::option::Option<crate::config::Builder>,
32}
33impl
34    crate::client::customize::internal::CustomizableSend<
35        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsOutput,
36        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsError,
37    > for DescribeVpcEncryptionControlsFluentBuilder
38{
39    fn send(
40        self,
41        config_override: crate::config::Builder,
42    ) -> crate::client::customize::internal::BoxFuture<
43        crate::client::customize::internal::SendResult<
44            crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsOutput,
45            crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsError,
46        >,
47    > {
48        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
49    }
50}
51impl DescribeVpcEncryptionControlsFluentBuilder {
52    /// Creates a new `DescribeVpcEncryptionControlsFluentBuilder`.
53    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
54        Self {
55            handle,
56            inner: ::std::default::Default::default(),
57            config_override: ::std::option::Option::None,
58        }
59    }
60    /// Access the DescribeVpcEncryptionControls as a reference.
61    pub fn as_input(&self) -> &crate::operation::describe_vpc_encryption_controls::builders::DescribeVpcEncryptionControlsInputBuilder {
62        &self.inner
63    }
64    /// Sends the request and returns the response.
65    ///
66    /// If an error occurs, an `SdkError` will be returned with additional details that
67    /// can be matched against.
68    ///
69    /// By default, any retryable failures will be retried twice. Retry behavior
70    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
71    /// set when configuring the client.
72    pub async fn send(
73        self,
74    ) -> ::std::result::Result<
75        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsOutput,
76        ::aws_smithy_runtime_api::client::result::SdkError<
77            crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsError,
78            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
79        >,
80    > {
81        let input = self
82            .inner
83            .build()
84            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
85        let runtime_plugins = crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControls::operation_runtime_plugins(
86            self.handle.runtime_plugins.clone(),
87            &self.handle.conf,
88            self.config_override,
89        );
90        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControls::orchestrate(&runtime_plugins, input).await
91    }
92
93    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
94    pub fn customize(
95        self,
96    ) -> crate::client::customize::CustomizableOperation<
97        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsOutput,
98        crate::operation::describe_vpc_encryption_controls::DescribeVpcEncryptionControlsError,
99        Self,
100    > {
101        crate::client::customize::CustomizableOperation::new(self)
102    }
103    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
104        self.set_config_override(::std::option::Option::Some(config_override.into()));
105        self
106    }
107
108    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
109        self.config_override = config_override;
110        self
111    }
112    /// <p>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is <code>DryRunOperation</code>. Otherwise, it is <code>UnauthorizedOperation</code>.</p>
113    pub fn dry_run(mut self, input: bool) -> Self {
114        self.inner = self.inner.dry_run(input);
115        self
116    }
117    /// <p>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is <code>DryRunOperation</code>. Otherwise, it is <code>UnauthorizedOperation</code>.</p>
118    pub fn set_dry_run(mut self, input: ::std::option::Option<bool>) -> Self {
119        self.inner = self.inner.set_dry_run(input);
120        self
121    }
122    /// <p>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is <code>DryRunOperation</code>. Otherwise, it is <code>UnauthorizedOperation</code>.</p>
123    pub fn get_dry_run(&self) -> &::std::option::Option<bool> {
124        self.inner.get_dry_run()
125    }
126    ///
127    /// Appends an item to `Filters`.
128    ///
129    /// To override the contents of this collection use [`set_filters`](Self::set_filters).
130    ///
131    /// <p>The filters to apply to the request.</p>
132    pub fn filters(mut self, input: crate::types::Filter) -> Self {
133        self.inner = self.inner.filters(input);
134        self
135    }
136    /// <p>The filters to apply to the request.</p>
137    pub fn set_filters(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Filter>>) -> Self {
138        self.inner = self.inner.set_filters(input);
139        self
140    }
141    /// <p>The filters to apply to the request.</p>
142    pub fn get_filters(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Filter>> {
143        self.inner.get_filters()
144    }
145    ///
146    /// Appends an item to `VpcEncryptionControlIds`.
147    ///
148    /// To override the contents of this collection use [`set_vpc_encryption_control_ids`](Self::set_vpc_encryption_control_ids).
149    ///
150    /// <p>The IDs of the VPC Encryption Control configurations to describe.</p>
151    pub fn vpc_encryption_control_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
152        self.inner = self.inner.vpc_encryption_control_ids(input.into());
153        self
154    }
155    /// <p>The IDs of the VPC Encryption Control configurations to describe.</p>
156    pub fn set_vpc_encryption_control_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
157        self.inner = self.inner.set_vpc_encryption_control_ids(input);
158        self
159    }
160    /// <p>The IDs of the VPC Encryption Control configurations to describe.</p>
161    pub fn get_vpc_encryption_control_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
162        self.inner.get_vpc_encryption_control_ids()
163    }
164    ///
165    /// Appends an item to `VpcIds`.
166    ///
167    /// To override the contents of this collection use [`set_vpc_ids`](Self::set_vpc_ids).
168    ///
169    /// <p>The IDs of the VPCs to describe encryption control configurations for.</p>
170    pub fn vpc_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
171        self.inner = self.inner.vpc_ids(input.into());
172        self
173    }
174    /// <p>The IDs of the VPCs to describe encryption control configurations for.</p>
175    pub fn set_vpc_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
176        self.inner = self.inner.set_vpc_ids(input);
177        self
178    }
179    /// <p>The IDs of the VPCs to describe encryption control configurations for.</p>
180    pub fn get_vpc_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
181        self.inner.get_vpc_ids()
182    }
183    /// <p>The token returned from a previous paginated request. Pagination continues from the end of the items returned by the previous request.</p>
184    pub fn next_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
185        self.inner = self.inner.next_token(input.into());
186        self
187    }
188    /// <p>The token returned from a previous paginated request. Pagination continues from the end of the items returned by the previous request.</p>
189    pub fn set_next_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
190        self.inner = self.inner.set_next_token(input);
191        self
192    }
193    /// <p>The token returned from a previous paginated request. Pagination continues from the end of the items returned by the previous request.</p>
194    pub fn get_next_token(&self) -> &::std::option::Option<::std::string::String> {
195        self.inner.get_next_token()
196    }
197    /// <p>The maximum number of items to return for this request. To get the next page of items, make another request with the token returned in the output. For more information, see <a href="https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Query-Requests.html#api-pagination">Pagination</a>.</p>
198    pub fn max_results(mut self, input: i32) -> Self {
199        self.inner = self.inner.max_results(input);
200        self
201    }
202    /// <p>The maximum number of items to return for this request. To get the next page of items, make another request with the token returned in the output. For more information, see <a href="https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Query-Requests.html#api-pagination">Pagination</a>.</p>
203    pub fn set_max_results(mut self, input: ::std::option::Option<i32>) -> Self {
204        self.inner = self.inner.set_max_results(input);
205        self
206    }
207    /// <p>The maximum number of items to return for this request. To get the next page of items, make another request with the token returned in the output. For more information, see <a href="https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Query-Requests.html#api-pagination">Pagination</a>.</p>
208    pub fn get_max_results(&self) -> &::std::option::Option<i32> {
209        self.inner.get_max_results()
210    }
211}