aws_sdk_s3/protocol_serde/
shape_list_multipart_uploads.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_list_multipart_uploads_http_error(
4 _response_status: u16,
5 _response_headers: &::aws_smithy_runtime_api::http::Headers,
6 _response_body: &[u8],
7) -> std::result::Result<
8 crate::operation::list_multipart_uploads::ListMultipartUploadsOutput,
9 crate::operation::list_multipart_uploads::ListMultipartUploadsError,
10> {
11 #[allow(unused_mut)]
12 let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
13 .map_err(crate::operation::list_multipart_uploads::ListMultipartUploadsError::unhandled)?;
14 generic_builder = crate::s3_request_id::apply_extended_request_id(generic_builder, _response_headers);
15 generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
16 let generic = generic_builder.build();
17 Err(crate::operation::list_multipart_uploads::ListMultipartUploadsError::generic(generic))
18}
19
20#[allow(clippy::unnecessary_wraps)]
21pub fn de_list_multipart_uploads_http_response(
22 _response_status: u16,
23 _response_headers: &::aws_smithy_runtime_api::http::Headers,
24 _response_body: &[u8],
25) -> std::result::Result<
26 crate::operation::list_multipart_uploads::ListMultipartUploadsOutput,
27 crate::operation::list_multipart_uploads::ListMultipartUploadsError,
28> {
29 Ok({
30 #[allow(unused_mut)]
31 let mut output = crate::operation::list_multipart_uploads::builders::ListMultipartUploadsOutputBuilder::default();
32 output = crate::protocol_serde::shape_list_multipart_uploads::de_list_multipart_uploads(_response_body, output)
33 .map_err(crate::operation::list_multipart_uploads::ListMultipartUploadsError::unhandled)?;
34 output = output.set_request_charged(
35 crate::protocol_serde::shape_list_multipart_uploads_output::de_request_charged_header(_response_headers).map_err(|_| {
36 crate::operation::list_multipart_uploads::ListMultipartUploadsError::unhandled(
37 "Failed to parse RequestCharged from header `x-amz-request-charged",
38 )
39 })?,
40 );
41 output._set_extended_request_id(crate::s3_request_id::RequestIdExt::extended_request_id(_response_headers).map(str::to_string));
42 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
43 output.build()
44 })
45}
46
47pub fn ser_list_multipart_uploads_headers(
48 input: &crate::operation::list_multipart_uploads::ListMultipartUploadsInput,
49 mut builder: ::http::request::Builder,
50) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
51 if let ::std::option::Option::Some(inner_1) = &input.expected_bucket_owner {
52 let formatted_2 = inner_1.as_str();
53 let header_value = formatted_2;
54 let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
55 ::aws_smithy_types::error::operation::BuildError::invalid_field(
56 "expected_bucket_owner",
57 format!("`{}` cannot be used as a header value: {}", &header_value, err),
58 )
59 })?;
60 builder = builder.header("x-amz-expected-bucket-owner", header_value);
61 }
62 if let ::std::option::Option::Some(inner_3) = &input.request_payer {
63 let formatted_4 = inner_3.as_str();
64 let header_value = formatted_4;
65 let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
66 ::aws_smithy_types::error::operation::BuildError::invalid_field(
67 "request_payer",
68 format!("`{}` cannot be used as a header value: {}", &header_value, err),
69 )
70 })?;
71 builder = builder.header("x-amz-request-payer", header_value);
72 }
73 Ok(builder)
74}
75
76#[allow(unused_mut)]
77pub fn de_list_multipart_uploads(
78 inp: &[u8],
79 mut builder: crate::operation::list_multipart_uploads::builders::ListMultipartUploadsOutputBuilder,
80) -> std::result::Result<
81 crate::operation::list_multipart_uploads::builders::ListMultipartUploadsOutputBuilder,
82 ::aws_smithy_xml::decode::XmlDecodeError,
83> {
84 let mut doc = ::aws_smithy_xml::decode::Document::try_from(inp)?;
85
86 #[allow(unused_mut)]
87 let mut decoder = doc.root_element()?;
88 #[allow(unused_variables)]
89 let start_el = decoder.start_el();
90 if !start_el.matches("ListMultipartUploadsResult") {
91 return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(format!(
92 "encountered invalid XML root: expected ListMultipartUploadsResult but got {start_el:?}. This is likely a bug in the SDK."
93 )));
94 }
95 while let Some(mut tag) = decoder.next_tag() {
96 match tag.start_el() {
97 s if s.matches("CommonPrefixes") => {
98 let var_5 =
99 Some(
100 Result::<::std::vec::Vec::<crate::types::CommonPrefix>, ::aws_smithy_xml::decode::XmlDecodeError>::Ok({
101 let mut list_6 = builder.common_prefixes.take().unwrap_or_default();
102 list_6.push(
103 crate::protocol_serde::shape_common_prefix::de_common_prefix(&mut tag)
104 ?
105 );
106 list_6
107 })
108 ?
109 )
110 ;
111 builder = builder.set_common_prefixes(var_5);
112 }
113 ,
114 s if s.matches("UploadIdMarker") => {
115 let var_7 =
116 Some(
117 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
118 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
119 .into()
120 )
121 ?
122 )
123 ;
124 builder = builder.set_upload_id_marker(var_7);
125 }
126 ,
127 s if s.matches("NextKeyMarker") => {
128 let var_8 =
129 Some(
130 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
131 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
132 .into()
133 )
134 ?
135 )
136 ;
137 builder = builder.set_next_key_marker(var_8);
138 }
139 ,
140 s if s.matches("Delimiter") => {
141 let var_9 =
142 Some(
143 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
144 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
145 .into()
146 )
147 ?
148 )
149 ;
150 builder = builder.set_delimiter(var_9);
151 }
152 ,
153 s if s.matches("Upload") => {
154 let var_10 =
155 Some(
156 Result::<::std::vec::Vec::<crate::types::MultipartUpload>, ::aws_smithy_xml::decode::XmlDecodeError>::Ok({
157 let mut list_11 = builder.uploads.take().unwrap_or_default();
158 list_11.push(
159 crate::protocol_serde::shape_multipart_upload::de_multipart_upload(&mut tag)
160 ?
161 );
162 list_11
163 })
164 ?
165 )
166 ;
167 builder = builder.set_uploads(var_10);
168 }
169 ,
170 s if s.matches("MaxUploads") => {
171 let var_12 =
172 Some(
173 {
174 <i32 as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
175 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
176 )
177 .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (integer: `com.amazonaws.s3#MaxUploads`)"))
178 }
179 ?
180 )
181 ;
182 builder = builder.set_max_uploads(var_12);
183 }
184 ,
185 s if s.matches("EncodingType") => {
186 let var_13 =
187 Some(
188 Result::<crate::types::EncodingType, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
189 crate::types::EncodingType::from(
190 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
191 )
192 )
193 ?
194 )
195 ;
196 builder = builder.set_encoding_type(var_13);
197 }
198 ,
199 s if s.matches("IsTruncated") => {
200 let var_14 =
201 Some(
202 {
203 <bool as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
204 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
205 )
206 .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (boolean: `com.amazonaws.s3#IsTruncated`)"))
207 }
208 ?
209 )
210 ;
211 builder = builder.set_is_truncated(var_14);
212 }
213 ,
214 s if s.matches("Prefix") => {
215 let var_15 =
216 Some(
217 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
218 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
219 .into()
220 )
221 ?
222 )
223 ;
224 builder = builder.set_prefix(var_15);
225 }
226 ,
227 s if s.matches("NextUploadIdMarker") => {
228 let var_16 =
229 Some(
230 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
231 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
232 .into()
233 )
234 ?
235 )
236 ;
237 builder = builder.set_next_upload_id_marker(var_16);
238 }
239 ,
240 s if s.matches("Bucket") => {
241 let var_17 =
242 Some(
243 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
244 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
245 .into()
246 )
247 ?
248 )
249 ;
250 builder = builder.set_bucket(var_17);
251 }
252 ,
253 s if s.matches("KeyMarker") => {
254 let var_18 =
255 Some(
256 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
257 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
258 .into()
259 )
260 ?
261 )
262 ;
263 builder = builder.set_key_marker(var_18);
264 }
265 ,
266 _ => {}
267 }
268 }
269 Ok(builder)
270}