aws_sdk_s3/operation/list_object_versions/builders.rs
1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::list_object_versions::_list_object_versions_output::ListObjectVersionsOutputBuilder;
3
4pub use crate::operation::list_object_versions::_list_object_versions_input::ListObjectVersionsInputBuilder;
5
6impl crate::operation::list_object_versions::builders::ListObjectVersionsInputBuilder {
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::list_object_versions::ListObjectVersionsOutput,
13 ::aws_smithy_runtime_api::client::result::SdkError<
14 crate::operation::list_object_versions::ListObjectVersionsError,
15 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16 >,
17 > {
18 let mut fluent_builder = client.list_object_versions();
19 fluent_builder.inner = self;
20 fluent_builder.send().await
21 }
22}
23/// Fluent builder constructing a request to `ListObjectVersions`.
24///
25/// <note>
26/// <p>This operation is not supported for directory buckets.</p>
27/// </note>
28/// <p>Returns metadata about all versions of the objects in a bucket. You can also use request parameters as selection criteria to return metadata about a subset of all the object versions.</p><important>
29/// <p>To use this operation, you must have permission to perform the <code>s3:ListBucketVersions</code> action. Be aware of the name difference.</p>
30/// </important> <note>
31/// <p>A <code>200 OK</code> response can contain valid or invalid XML. Make sure to design your application to parse the contents of the response and handle it appropriately.</p>
32/// </note>
33/// <p>To use this operation, you must have READ access to the bucket.</p>
34/// <p>The following operations are related to <code>ListObjectVersions</code>:</p>
35/// <ul>
36/// <li>
37/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListObjectsV2.html">ListObjectsV2</a></p></li>
38/// <li>
39/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html">GetObject</a></p></li>
40/// <li>
41/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObject.html">PutObject</a></p></li>
42/// <li>
43/// <p><a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObject.html">DeleteObject</a></p></li>
44/// </ul><important>
45/// <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>
46/// </important>
47#[derive(::std::clone::Clone, ::std::fmt::Debug)]
48pub struct ListObjectVersionsFluentBuilder {
49 handle: ::std::sync::Arc<crate::client::Handle>,
50 inner: crate::operation::list_object_versions::builders::ListObjectVersionsInputBuilder,
51 config_override: ::std::option::Option<crate::config::Builder>,
52}
53impl
54 crate::client::customize::internal::CustomizableSend<
55 crate::operation::list_object_versions::ListObjectVersionsOutput,
56 crate::operation::list_object_versions::ListObjectVersionsError,
57 > for ListObjectVersionsFluentBuilder
58{
59 fn send(
60 self,
61 config_override: crate::config::Builder,
62 ) -> crate::client::customize::internal::BoxFuture<
63 crate::client::customize::internal::SendResult<
64 crate::operation::list_object_versions::ListObjectVersionsOutput,
65 crate::operation::list_object_versions::ListObjectVersionsError,
66 >,
67 > {
68 ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
69 }
70}
71impl ListObjectVersionsFluentBuilder {
72 /// Creates a new `ListObjectVersionsFluentBuilder`.
73 pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
74 Self {
75 handle,
76 inner: ::std::default::Default::default(),
77 config_override: ::std::option::Option::None,
78 }
79 }
80 /// Access the ListObjectVersions as a reference.
81 pub fn as_input(&self) -> &crate::operation::list_object_versions::builders::ListObjectVersionsInputBuilder {
82 &self.inner
83 }
84 /// Sends the request and returns the response.
85 ///
86 /// If an error occurs, an `SdkError` will be returned with additional details that
87 /// can be matched against.
88 ///
89 /// By default, any retryable failures will be retried twice. Retry behavior
90 /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
91 /// set when configuring the client.
92 pub async fn send(
93 self,
94 ) -> ::std::result::Result<
95 crate::operation::list_object_versions::ListObjectVersionsOutput,
96 ::aws_smithy_runtime_api::client::result::SdkError<
97 crate::operation::list_object_versions::ListObjectVersionsError,
98 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
99 >,
100 > {
101 let input = self
102 .inner
103 .build()
104 .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
105 let runtime_plugins = crate::operation::list_object_versions::ListObjectVersions::operation_runtime_plugins(
106 self.handle.runtime_plugins.clone(),
107 &self.handle.conf,
108 self.config_override,
109 );
110 crate::operation::list_object_versions::ListObjectVersions::orchestrate(&runtime_plugins, input).await
111 }
112
113 /// Consumes this builder, creating a customizable operation that can be modified before being sent.
114 pub fn customize(
115 self,
116 ) -> crate::client::customize::CustomizableOperation<
117 crate::operation::list_object_versions::ListObjectVersionsOutput,
118 crate::operation::list_object_versions::ListObjectVersionsError,
119 Self,
120 > {
121 crate::client::customize::CustomizableOperation::new(self)
122 }
123 pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
124 self.set_config_override(::std::option::Option::Some(config_override.into()));
125 self
126 }
127
128 pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
129 self.config_override = config_override;
130 self
131 }
132 /// <p>The bucket name that contains the objects.</p>
133 pub fn bucket(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
134 self.inner = self.inner.bucket(input.into());
135 self
136 }
137 /// <p>The bucket name that contains the objects.</p>
138 pub fn set_bucket(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
139 self.inner = self.inner.set_bucket(input);
140 self
141 }
142 /// <p>The bucket name that contains the objects.</p>
143 pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
144 self.inner.get_bucket()
145 }
146 /// <p>A delimiter is a character that you specify to group keys. All keys that contain the same string between the <code>prefix</code> and the first occurrence of the delimiter are grouped under a single result element in <code>CommonPrefixes</code>. These groups are counted as one result against the <code>max-keys</code> limitation. These keys are not returned elsewhere in the response.</p>
147 /// <p><code>CommonPrefixes</code> is filtered out from results if it is not lexicographically greater than the key-marker.</p>
148 pub fn delimiter(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
149 self.inner = self.inner.delimiter(input.into());
150 self
151 }
152 /// <p>A delimiter is a character that you specify to group keys. All keys that contain the same string between the <code>prefix</code> and the first occurrence of the delimiter are grouped under a single result element in <code>CommonPrefixes</code>. These groups are counted as one result against the <code>max-keys</code> limitation. These keys are not returned elsewhere in the response.</p>
153 /// <p><code>CommonPrefixes</code> is filtered out from results if it is not lexicographically greater than the key-marker.</p>
154 pub fn set_delimiter(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
155 self.inner = self.inner.set_delimiter(input);
156 self
157 }
158 /// <p>A delimiter is a character that you specify to group keys. All keys that contain the same string between the <code>prefix</code> and the first occurrence of the delimiter are grouped under a single result element in <code>CommonPrefixes</code>. These groups are counted as one result against the <code>max-keys</code> limitation. These keys are not returned elsewhere in the response.</p>
159 /// <p><code>CommonPrefixes</code> is filtered out from results if it is not lexicographically greater than the key-marker.</p>
160 pub fn get_delimiter(&self) -> &::std::option::Option<::std::string::String> {
161 self.inner.get_delimiter()
162 }
163 /// <p>Encoding type used by Amazon S3 to encode the <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html">object keys</a> in the response. Responses are encoded only in UTF-8. An object key can contain any Unicode character. However, the XML 1.0 parser can't parse certain characters, such as characters with an ASCII value from 0 to 10. For characters that aren't supported in XML 1.0, you can add this parameter to request that Amazon S3 encode the keys in the response. For more information about characters to avoid in object key names, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html#object-key-guidelines">Object key naming guidelines</a>.</p><note>
164 /// <p>When using the URL encoding type, non-ASCII characters that are used in an object's key name will be percent-encoded according to UTF-8 code values. For example, the object <code>test_file(3).png</code> will appear as <code>test_file%283%29.png</code>.</p>
165 /// </note>
166 pub fn encoding_type(mut self, input: crate::types::EncodingType) -> Self {
167 self.inner = self.inner.encoding_type(input);
168 self
169 }
170 /// <p>Encoding type used by Amazon S3 to encode the <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html">object keys</a> in the response. Responses are encoded only in UTF-8. An object key can contain any Unicode character. However, the XML 1.0 parser can't parse certain characters, such as characters with an ASCII value from 0 to 10. For characters that aren't supported in XML 1.0, you can add this parameter to request that Amazon S3 encode the keys in the response. For more information about characters to avoid in object key names, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html#object-key-guidelines">Object key naming guidelines</a>.</p><note>
171 /// <p>When using the URL encoding type, non-ASCII characters that are used in an object's key name will be percent-encoded according to UTF-8 code values. For example, the object <code>test_file(3).png</code> will appear as <code>test_file%283%29.png</code>.</p>
172 /// </note>
173 pub fn set_encoding_type(mut self, input: ::std::option::Option<crate::types::EncodingType>) -> Self {
174 self.inner = self.inner.set_encoding_type(input);
175 self
176 }
177 /// <p>Encoding type used by Amazon S3 to encode the <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html">object keys</a> in the response. Responses are encoded only in UTF-8. An object key can contain any Unicode character. However, the XML 1.0 parser can't parse certain characters, such as characters with an ASCII value from 0 to 10. For characters that aren't supported in XML 1.0, you can add this parameter to request that Amazon S3 encode the keys in the response. For more information about characters to avoid in object key names, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html#object-key-guidelines">Object key naming guidelines</a>.</p><note>
178 /// <p>When using the URL encoding type, non-ASCII characters that are used in an object's key name will be percent-encoded according to UTF-8 code values. For example, the object <code>test_file(3).png</code> will appear as <code>test_file%283%29.png</code>.</p>
179 /// </note>
180 pub fn get_encoding_type(&self) -> &::std::option::Option<crate::types::EncodingType> {
181 self.inner.get_encoding_type()
182 }
183 /// <p>Specifies the key to start with when listing objects in a bucket.</p>
184 pub fn key_marker(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
185 self.inner = self.inner.key_marker(input.into());
186 self
187 }
188 /// <p>Specifies the key to start with when listing objects in a bucket.</p>
189 pub fn set_key_marker(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
190 self.inner = self.inner.set_key_marker(input);
191 self
192 }
193 /// <p>Specifies the key to start with when listing objects in a bucket.</p>
194 pub fn get_key_marker(&self) -> &::std::option::Option<::std::string::String> {
195 self.inner.get_key_marker()
196 }
197 /// <p>Sets the maximum number of keys returned in the response. By default, the action returns up to 1,000 key names. The response might contain fewer keys but will never contain more. If additional keys satisfy the search criteria, but were not returned because <code>max-keys</code> was exceeded, the response contains <code><istruncated>
198 /// true
199 /// </istruncated></code>. To return the additional keys, see <code>key-marker</code> and <code>version-id-marker</code>.</p>
200 pub fn max_keys(mut self, input: i32) -> Self {
201 self.inner = self.inner.max_keys(input);
202 self
203 }
204 /// <p>Sets the maximum number of keys returned in the response. By default, the action returns up to 1,000 key names. The response might contain fewer keys but will never contain more. If additional keys satisfy the search criteria, but were not returned because <code>max-keys</code> was exceeded, the response contains <code><istruncated>
205 /// true
206 /// </istruncated></code>. To return the additional keys, see <code>key-marker</code> and <code>version-id-marker</code>.</p>
207 pub fn set_max_keys(mut self, input: ::std::option::Option<i32>) -> Self {
208 self.inner = self.inner.set_max_keys(input);
209 self
210 }
211 /// <p>Sets the maximum number of keys returned in the response. By default, the action returns up to 1,000 key names. The response might contain fewer keys but will never contain more. If additional keys satisfy the search criteria, but were not returned because <code>max-keys</code> was exceeded, the response contains <code><istruncated>
212 /// true
213 /// </istruncated></code>. To return the additional keys, see <code>key-marker</code> and <code>version-id-marker</code>.</p>
214 pub fn get_max_keys(&self) -> &::std::option::Option<i32> {
215 self.inner.get_max_keys()
216 }
217 /// <p>Use this parameter to select only those keys that begin with the specified prefix. You can use prefixes to separate a bucket into different groupings of keys. (You can think of using <code>prefix</code> to make groups in the same way that you'd use a folder in a file system.) You can use <code>prefix</code> with <code>delimiter</code> to roll up numerous objects into a single result under <code>CommonPrefixes</code>.</p>
218 pub fn prefix(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
219 self.inner = self.inner.prefix(input.into());
220 self
221 }
222 /// <p>Use this parameter to select only those keys that begin with the specified prefix. You can use prefixes to separate a bucket into different groupings of keys. (You can think of using <code>prefix</code> to make groups in the same way that you'd use a folder in a file system.) You can use <code>prefix</code> with <code>delimiter</code> to roll up numerous objects into a single result under <code>CommonPrefixes</code>.</p>
223 pub fn set_prefix(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
224 self.inner = self.inner.set_prefix(input);
225 self
226 }
227 /// <p>Use this parameter to select only those keys that begin with the specified prefix. You can use prefixes to separate a bucket into different groupings of keys. (You can think of using <code>prefix</code> to make groups in the same way that you'd use a folder in a file system.) You can use <code>prefix</code> with <code>delimiter</code> to roll up numerous objects into a single result under <code>CommonPrefixes</code>.</p>
228 pub fn get_prefix(&self) -> &::std::option::Option<::std::string::String> {
229 self.inner.get_prefix()
230 }
231 /// <p>Specifies the object version you want to start listing from.</p>
232 pub fn version_id_marker(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
233 self.inner = self.inner.version_id_marker(input.into());
234 self
235 }
236 /// <p>Specifies the object version you want to start listing from.</p>
237 pub fn set_version_id_marker(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
238 self.inner = self.inner.set_version_id_marker(input);
239 self
240 }
241 /// <p>Specifies the object version you want to start listing from.</p>
242 pub fn get_version_id_marker(&self) -> &::std::option::Option<::std::string::String> {
243 self.inner.get_version_id_marker()
244 }
245 /// <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>
246 pub fn expected_bucket_owner(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
247 self.inner = self.inner.expected_bucket_owner(input.into());
248 self
249 }
250 /// <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>
251 pub fn set_expected_bucket_owner(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
252 self.inner = self.inner.set_expected_bucket_owner(input);
253 self
254 }
255 /// <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>
256 pub fn get_expected_bucket_owner(&self) -> &::std::option::Option<::std::string::String> {
257 self.inner.get_expected_bucket_owner()
258 }
259 /// <p>Confirms that the requester knows that they will be charged for the request. Bucket owners need not specify this parameter in their requests. If either the source or destination S3 bucket has Requester Pays enabled, the requester will pay for corresponding charges to copy the object. For information about downloading objects from Requester Pays buckets, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/ObjectsinRequesterPaysBuckets.html">Downloading Objects in Requester Pays Buckets</a> in the <i>Amazon S3 User Guide</i>.</p><note>
260 /// <p>This functionality is not supported for directory buckets.</p>
261 /// </note>
262 pub fn request_payer(mut self, input: crate::types::RequestPayer) -> Self {
263 self.inner = self.inner.request_payer(input);
264 self
265 }
266 /// <p>Confirms that the requester knows that they will be charged for the request. Bucket owners need not specify this parameter in their requests. If either the source or destination S3 bucket has Requester Pays enabled, the requester will pay for corresponding charges to copy the object. For information about downloading objects from Requester Pays buckets, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/ObjectsinRequesterPaysBuckets.html">Downloading Objects in Requester Pays Buckets</a> in the <i>Amazon S3 User Guide</i>.</p><note>
267 /// <p>This functionality is not supported for directory buckets.</p>
268 /// </note>
269 pub fn set_request_payer(mut self, input: ::std::option::Option<crate::types::RequestPayer>) -> Self {
270 self.inner = self.inner.set_request_payer(input);
271 self
272 }
273 /// <p>Confirms that the requester knows that they will be charged for the request. Bucket owners need not specify this parameter in their requests. If either the source or destination S3 bucket has Requester Pays enabled, the requester will pay for corresponding charges to copy the object. For information about downloading objects from Requester Pays buckets, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/ObjectsinRequesterPaysBuckets.html">Downloading Objects in Requester Pays Buckets</a> in the <i>Amazon S3 User Guide</i>.</p><note>
274 /// <p>This functionality is not supported for directory buckets.</p>
275 /// </note>
276 pub fn get_request_payer(&self) -> &::std::option::Option<crate::types::RequestPayer> {
277 self.inner.get_request_payer()
278 }
279 ///
280 /// Appends an item to `OptionalObjectAttributes`.
281 ///
282 /// To override the contents of this collection use [`set_optional_object_attributes`](Self::set_optional_object_attributes).
283 ///
284 /// <p>Specifies the optional fields that you want returned in the response. Fields that you do not specify are not returned.</p>
285 pub fn optional_object_attributes(mut self, input: crate::types::OptionalObjectAttributes) -> Self {
286 self.inner = self.inner.optional_object_attributes(input);
287 self
288 }
289 /// <p>Specifies the optional fields that you want returned in the response. Fields that you do not specify are not returned.</p>
290 pub fn set_optional_object_attributes(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::OptionalObjectAttributes>>) -> Self {
291 self.inner = self.inner.set_optional_object_attributes(input);
292 self
293 }
294 /// <p>Specifies the optional fields that you want returned in the response. Fields that you do not specify are not returned.</p>
295 pub fn get_optional_object_attributes(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::OptionalObjectAttributes>> {
296 self.inner.get_optional_object_attributes()
297 }
298}