aws_sdk_s3/protocol_serde/
shape_get_object.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_get_object_http_response(
4    response: &mut ::aws_smithy_runtime_api::http::Response,
5) -> std::result::Result<crate::operation::get_object::GetObjectOutput, crate::operation::get_object::GetObjectError> {
6    let mut _response_body = ::aws_smithy_types::body::SdkBody::taken();
7    std::mem::swap(&mut _response_body, response.body_mut());
8    let _response_body = &mut _response_body;
9
10    let _response_status = response.status().as_u16();
11    let _response_headers = response.headers();
12    Ok({
13        #[allow(unused_mut)]
14        let mut output = crate::operation::get_object::builders::GetObjectOutputBuilder::default();
15        output = output.set_accept_ranges(
16            crate::protocol_serde::shape_get_object_output::de_accept_ranges_header(_response_headers)
17                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse AcceptRanges from header `accept-ranges"))?,
18        );
19        output = output.set_body(Some(crate::protocol_serde::shape_get_object_output::de_body_payload(_response_body)?));
20        output = output.set_bucket_key_enabled(
21            crate::protocol_serde::shape_get_object_output::de_bucket_key_enabled_header(_response_headers).map_err(|_| {
22                crate::operation::get_object::GetObjectError::unhandled(
23                    "Failed to parse BucketKeyEnabled from header `x-amz-server-side-encryption-bucket-key-enabled",
24                )
25            })?,
26        );
27        output = output.set_cache_control(
28            crate::protocol_serde::shape_get_object_output::de_cache_control_header(_response_headers)
29                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse CacheControl from header `Cache-Control"))?,
30        );
31        output = output.set_checksum_crc32(
32            crate::protocol_serde::shape_get_object_output::de_checksum_crc32_header(_response_headers).map_err(|_| {
33                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumCRC32 from header `x-amz-checksum-crc32")
34            })?,
35        );
36        output = output.set_checksum_crc32_c(
37            crate::protocol_serde::shape_get_object_output::de_checksum_crc32_c_header(_response_headers).map_err(|_| {
38                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumCRC32C from header `x-amz-checksum-crc32c")
39            })?,
40        );
41        output = output.set_checksum_crc64_nvme(
42            crate::protocol_serde::shape_get_object_output::de_checksum_crc64_nvme_header(_response_headers).map_err(|_| {
43                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumCRC64NVME from header `x-amz-checksum-crc64nvme")
44            })?,
45        );
46        output = output.set_checksum_sha1(
47            crate::protocol_serde::shape_get_object_output::de_checksum_sha1_header(_response_headers).map_err(|_| {
48                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumSHA1 from header `x-amz-checksum-sha1")
49            })?,
50        );
51        output = output.set_checksum_sha256(
52            crate::protocol_serde::shape_get_object_output::de_checksum_sha256_header(_response_headers).map_err(|_| {
53                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumSHA256 from header `x-amz-checksum-sha256")
54            })?,
55        );
56        output = output.set_checksum_type(
57            crate::protocol_serde::shape_get_object_output::de_checksum_type_header(_response_headers).map_err(|_| {
58                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ChecksumType from header `x-amz-checksum-type")
59            })?,
60        );
61        output = output.set_content_disposition(
62            crate::protocol_serde::shape_get_object_output::de_content_disposition_header(_response_headers).map_err(|_| {
63                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentDisposition from header `Content-Disposition")
64            })?,
65        );
66        output = output.set_content_encoding(
67            crate::protocol_serde::shape_get_object_output::de_content_encoding_header(_response_headers).map_err(|_| {
68                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentEncoding from header `Content-Encoding")
69            })?,
70        );
71        output = output.set_content_language(
72            crate::protocol_serde::shape_get_object_output::de_content_language_header(_response_headers).map_err(|_| {
73                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentLanguage from header `Content-Language")
74            })?,
75        );
76        output = output.set_content_length(
77            crate::protocol_serde::shape_get_object_output::de_content_length_header(_response_headers)
78                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentLength from header `Content-Length"))?,
79        );
80        output = output.set_content_range(
81            crate::protocol_serde::shape_get_object_output::de_content_range_header(_response_headers)
82                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentRange from header `Content-Range"))?,
83        );
84        output = output.set_content_type(
85            crate::protocol_serde::shape_get_object_output::de_content_type_header(_response_headers)
86                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse ContentType from header `Content-Type"))?,
87        );
88        output = output.set_delete_marker(
89            crate::protocol_serde::shape_get_object_output::de_delete_marker_header(_response_headers).map_err(|_| {
90                crate::operation::get_object::GetObjectError::unhandled("Failed to parse DeleteMarker from header `x-amz-delete-marker")
91            })?,
92        );
93        output = output.set_e_tag(
94            crate::protocol_serde::shape_get_object_output::de_e_tag_header(_response_headers)
95                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse ETag from header `ETag"))?,
96        );
97        output = output.set_expiration(
98            crate::protocol_serde::shape_get_object_output::de_expiration_header(_response_headers)
99                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse Expiration from header `x-amz-expiration"))?,
100        );
101        output = output.set_expires(
102            crate::protocol_serde::shape_get_object_output::de_expires_header(_response_headers)
103                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse Expires from header `Expires"))?,
104        );
105        output = output.set_expires_string(
106            crate::protocol_serde::shape_get_object_output::de_expires_string_header(_response_headers)
107                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse ExpiresString from header `ExpiresString"))?,
108        );
109        output = output.set_last_modified(
110            crate::protocol_serde::shape_get_object_output::de_last_modified_header(_response_headers)
111                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse LastModified from header `Last-Modified"))?,
112        );
113        output = output.set_metadata(
114            crate::protocol_serde::shape_get_object_output::de_metadata_prefix_header(_response_headers)
115                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse Metadata from prefix header `x-amz-meta-"))?,
116        );
117        output = output.set_missing_meta(
118            crate::protocol_serde::shape_get_object_output::de_missing_meta_header(_response_headers).map_err(|_| {
119                crate::operation::get_object::GetObjectError::unhandled("Failed to parse MissingMeta from header `x-amz-missing-meta")
120            })?,
121        );
122        output = output.set_object_lock_legal_hold_status(
123            crate::protocol_serde::shape_get_object_output::de_object_lock_legal_hold_status_header(_response_headers).map_err(|_| {
124                crate::operation::get_object::GetObjectError::unhandled(
125                    "Failed to parse ObjectLockLegalHoldStatus from header `x-amz-object-lock-legal-hold",
126                )
127            })?,
128        );
129        output = output.set_object_lock_mode(
130            crate::protocol_serde::shape_get_object_output::de_object_lock_mode_header(_response_headers).map_err(|_| {
131                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ObjectLockMode from header `x-amz-object-lock-mode")
132            })?,
133        );
134        output = output.set_object_lock_retain_until_date(
135            crate::protocol_serde::shape_get_object_output::de_object_lock_retain_until_date_header(_response_headers).map_err(|_| {
136                crate::operation::get_object::GetObjectError::unhandled(
137                    "Failed to parse ObjectLockRetainUntilDate from header `x-amz-object-lock-retain-until-date",
138                )
139            })?,
140        );
141        output = output.set_parts_count(
142            crate::protocol_serde::shape_get_object_output::de_parts_count_header(_response_headers).map_err(|_| {
143                crate::operation::get_object::GetObjectError::unhandled("Failed to parse PartsCount from header `x-amz-mp-parts-count")
144            })?,
145        );
146        output = output.set_replication_status(
147            crate::protocol_serde::shape_get_object_output::de_replication_status_header(_response_headers).map_err(|_| {
148                crate::operation::get_object::GetObjectError::unhandled("Failed to parse ReplicationStatus from header `x-amz-replication-status")
149            })?,
150        );
151        output = output.set_request_charged(
152            crate::protocol_serde::shape_get_object_output::de_request_charged_header(_response_headers).map_err(|_| {
153                crate::operation::get_object::GetObjectError::unhandled("Failed to parse RequestCharged from header `x-amz-request-charged")
154            })?,
155        );
156        output = output.set_restore(
157            crate::protocol_serde::shape_get_object_output::de_restore_header(_response_headers)
158                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse Restore from header `x-amz-restore"))?,
159        );
160        output = output.set_sse_customer_algorithm(
161            crate::protocol_serde::shape_get_object_output::de_sse_customer_algorithm_header(_response_headers).map_err(|_| {
162                crate::operation::get_object::GetObjectError::unhandled(
163                    "Failed to parse SSECustomerAlgorithm from header `x-amz-server-side-encryption-customer-algorithm",
164                )
165            })?,
166        );
167        output = output.set_sse_customer_key_md5(
168            crate::protocol_serde::shape_get_object_output::de_sse_customer_key_md5_header(_response_headers).map_err(|_| {
169                crate::operation::get_object::GetObjectError::unhandled(
170                    "Failed to parse SSECustomerKeyMD5 from header `x-amz-server-side-encryption-customer-key-MD5",
171                )
172            })?,
173        );
174        output = output.set_ssekms_key_id(
175            crate::protocol_serde::shape_get_object_output::de_ssekms_key_id_header(_response_headers).map_err(|_| {
176                crate::operation::get_object::GetObjectError::unhandled(
177                    "Failed to parse SSEKMSKeyId from header `x-amz-server-side-encryption-aws-kms-key-id",
178                )
179            })?,
180        );
181        output = output.set_server_side_encryption(
182            crate::protocol_serde::shape_get_object_output::de_server_side_encryption_header(_response_headers).map_err(|_| {
183                crate::operation::get_object::GetObjectError::unhandled(
184                    "Failed to parse ServerSideEncryption from header `x-amz-server-side-encryption",
185                )
186            })?,
187        );
188        output = output.set_storage_class(
189            crate::protocol_serde::shape_get_object_output::de_storage_class_header(_response_headers).map_err(|_| {
190                crate::operation::get_object::GetObjectError::unhandled("Failed to parse StorageClass from header `x-amz-storage-class")
191            })?,
192        );
193        output = output.set_tag_count(
194            crate::protocol_serde::shape_get_object_output::de_tag_count_header(_response_headers)
195                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse TagCount from header `x-amz-tagging-count"))?,
196        );
197        output = output.set_version_id(
198            crate::protocol_serde::shape_get_object_output::de_version_id_header(_response_headers)
199                .map_err(|_| crate::operation::get_object::GetObjectError::unhandled("Failed to parse VersionId from header `x-amz-version-id"))?,
200        );
201        output = output.set_website_redirect_location(
202            crate::protocol_serde::shape_get_object_output::de_website_redirect_location_header(_response_headers).map_err(|_| {
203                crate::operation::get_object::GetObjectError::unhandled(
204                    "Failed to parse WebsiteRedirectLocation from header `x-amz-website-redirect-location",
205                )
206            })?,
207        );
208        output._set_extended_request_id(crate::s3_request_id::RequestIdExt::extended_request_id(_response_headers).map(str::to_string));
209        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
210        output.build()
211    })
212}
213
214#[allow(clippy::unnecessary_wraps)]
215pub fn de_get_object_http_error(
216    _response_status: u16,
217    _response_headers: &::aws_smithy_runtime_api::http::Headers,
218    _response_body: &[u8],
219) -> std::result::Result<crate::operation::get_object::GetObjectOutput, crate::operation::get_object::GetObjectError> {
220    #[allow(unused_mut)]
221    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
222        .map_err(crate::operation::get_object::GetObjectError::unhandled)?;
223    generic_builder = crate::s3_request_id::apply_extended_request_id(generic_builder, _response_headers);
224    generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
225    let generic = generic_builder.build();
226    let error_code = match generic.code() {
227        Some(code) => code,
228        None => return Err(crate::operation::get_object::GetObjectError::unhandled(generic)),
229    };
230
231    let _error_message = generic.message().map(|msg| msg.to_owned());
232    Err(match error_code {
233        "InvalidObjectState" => crate::operation::get_object::GetObjectError::InvalidObjectState({
234            #[allow(unused_mut)]
235            let mut tmp = {
236                #[allow(unused_mut)]
237                let mut output = crate::types::error::builders::InvalidObjectStateBuilder::default();
238                output = crate::protocol_serde::shape_invalid_object_state::de_invalid_object_state_xml_err(_response_body, output)
239                    .map_err(crate::operation::get_object::GetObjectError::unhandled)?;
240                let output = output.meta(generic);
241                output.build()
242            };
243            if tmp.message.is_none() {
244                tmp.message = _error_message;
245            }
246            tmp
247        }),
248        "NoSuchKey" => crate::operation::get_object::GetObjectError::NoSuchKey({
249            #[allow(unused_mut)]
250            let mut tmp = {
251                #[allow(unused_mut)]
252                let mut output = crate::types::error::builders::NoSuchKeyBuilder::default();
253                output = crate::protocol_serde::shape_no_such_key::de_no_such_key_xml_err(_response_body, output)
254                    .map_err(crate::operation::get_object::GetObjectError::unhandled)?;
255                let output = output.meta(generic);
256                output.build()
257            };
258            if tmp.message.is_none() {
259                tmp.message = _error_message;
260            }
261            tmp
262        }),
263        _ => crate::operation::get_object::GetObjectError::generic(generic),
264    })
265}
266
267pub fn ser_get_object_headers(
268    input: &crate::operation::get_object::GetObjectInput,
269    mut builder: ::http::request::Builder,
270) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
271    if let ::std::option::Option::Some(inner_1) = &input.if_match {
272        let formatted_2 = inner_1.as_str();
273        let header_value = formatted_2;
274        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
275            ::aws_smithy_types::error::operation::BuildError::invalid_field(
276                "if_match",
277                format!("`{}` cannot be used as a header value: {}", &header_value, err),
278            )
279        })?;
280        builder = builder.header("If-Match", header_value);
281    }
282    if let ::std::option::Option::Some(inner_3) = &input.if_modified_since {
283        let formatted_4 = inner_3.fmt(::aws_smithy_types::date_time::Format::HttpDate)?;
284        let header_value = formatted_4;
285        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
286            ::aws_smithy_types::error::operation::BuildError::invalid_field(
287                "if_modified_since",
288                format!("`{}` cannot be used as a header value: {}", &header_value, err),
289            )
290        })?;
291        builder = builder.header("If-Modified-Since", header_value);
292    }
293    if let ::std::option::Option::Some(inner_5) = &input.if_none_match {
294        let formatted_6 = inner_5.as_str();
295        let header_value = formatted_6;
296        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
297            ::aws_smithy_types::error::operation::BuildError::invalid_field(
298                "if_none_match",
299                format!("`{}` cannot be used as a header value: {}", &header_value, err),
300            )
301        })?;
302        builder = builder.header("If-None-Match", header_value);
303    }
304    if let ::std::option::Option::Some(inner_7) = &input.if_unmodified_since {
305        let formatted_8 = inner_7.fmt(::aws_smithy_types::date_time::Format::HttpDate)?;
306        let header_value = formatted_8;
307        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
308            ::aws_smithy_types::error::operation::BuildError::invalid_field(
309                "if_unmodified_since",
310                format!("`{}` cannot be used as a header value: {}", &header_value, err),
311            )
312        })?;
313        builder = builder.header("If-Unmodified-Since", header_value);
314    }
315    if let ::std::option::Option::Some(inner_9) = &input.range {
316        let formatted_10 = inner_9.as_str();
317        let header_value = formatted_10;
318        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
319            ::aws_smithy_types::error::operation::BuildError::invalid_field(
320                "range",
321                format!("`{}` cannot be used as a header value: {}", &header_value, err),
322            )
323        })?;
324        builder = builder.header("Range", header_value);
325    }
326    if let ::std::option::Option::Some(inner_11) = &input.sse_customer_algorithm {
327        let formatted_12 = inner_11.as_str();
328        let header_value = formatted_12;
329        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
330            ::aws_smithy_types::error::operation::BuildError::invalid_field(
331                "sse_customer_algorithm",
332                format!("`{}` cannot be used as a header value: {}", &header_value, err),
333            )
334        })?;
335        builder = builder.header("x-amz-server-side-encryption-customer-algorithm", header_value);
336    }
337    if let ::std::option::Option::Some(inner_13) = &input.sse_customer_key {
338        let formatted_14 = inner_13.as_str();
339        let header_value = formatted_14;
340        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
341            ::aws_smithy_types::error::operation::BuildError::invalid_field(
342                "sse_customer_key",
343                format!("`{}` cannot be used as a header value: {}", &"*** Sensitive Data Redacted ***", err),
344            )
345        })?;
346        builder = builder.header("x-amz-server-side-encryption-customer-key", header_value);
347    }
348    if let ::std::option::Option::Some(inner_15) = &input.sse_customer_key_md5 {
349        let formatted_16 = inner_15.as_str();
350        let header_value = formatted_16;
351        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
352            ::aws_smithy_types::error::operation::BuildError::invalid_field(
353                "sse_customer_key_md5",
354                format!("`{}` cannot be used as a header value: {}", &header_value, err),
355            )
356        })?;
357        builder = builder.header("x-amz-server-side-encryption-customer-key-MD5", header_value);
358    }
359    if let ::std::option::Option::Some(inner_17) = &input.request_payer {
360        let formatted_18 = inner_17.as_str();
361        let header_value = formatted_18;
362        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
363            ::aws_smithy_types::error::operation::BuildError::invalid_field(
364                "request_payer",
365                format!("`{}` cannot be used as a header value: {}", &header_value, err),
366            )
367        })?;
368        builder = builder.header("x-amz-request-payer", header_value);
369    }
370    if let ::std::option::Option::Some(inner_19) = &input.expected_bucket_owner {
371        let formatted_20 = inner_19.as_str();
372        let header_value = formatted_20;
373        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
374            ::aws_smithy_types::error::operation::BuildError::invalid_field(
375                "expected_bucket_owner",
376                format!("`{}` cannot be used as a header value: {}", &header_value, err),
377            )
378        })?;
379        builder = builder.header("x-amz-expected-bucket-owner", header_value);
380    }
381    if let ::std::option::Option::Some(inner_21) = &input.checksum_mode {
382        let formatted_22 = inner_21.as_str();
383        let header_value = formatted_22;
384        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
385            ::aws_smithy_types::error::operation::BuildError::invalid_field(
386                "checksum_mode",
387                format!("`{}` cannot be used as a header value: {}", &header_value, err),
388            )
389        })?;
390        builder = builder.header("x-amz-checksum-mode", header_value);
391    }
392    Ok(builder)
393}