aws_sdk_ec2/protocol_serde/
shape_modify_snapshot_tier.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_modify_snapshot_tier_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::modify_snapshot_tier::ModifySnapshotTierOutput,
9 crate::operation::modify_snapshot_tier::ModifySnapshotTierError,
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::modify_snapshot_tier::ModifySnapshotTierError::unhandled)?;
14 generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
15 let generic = generic_builder.build();
16 Err(crate::operation::modify_snapshot_tier::ModifySnapshotTierError::generic(generic))
17}
18
19#[allow(clippy::unnecessary_wraps)]
20pub fn de_modify_snapshot_tier_http_response(
21 _response_status: u16,
22 _response_headers: &::aws_smithy_runtime_api::http::Headers,
23 _response_body: &[u8],
24) -> std::result::Result<
25 crate::operation::modify_snapshot_tier::ModifySnapshotTierOutput,
26 crate::operation::modify_snapshot_tier::ModifySnapshotTierError,
27> {
28 Ok({
29 #[allow(unused_mut)]
30 let mut output = crate::operation::modify_snapshot_tier::builders::ModifySnapshotTierOutputBuilder::default();
31 output = crate::protocol_serde::shape_modify_snapshot_tier::de_modify_snapshot_tier(_response_body, output)
32 .map_err(crate::operation::modify_snapshot_tier::ModifySnapshotTierError::unhandled)?;
33 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
34 output.build()
35 })
36}
37
38#[allow(unused_mut)]
39pub fn de_modify_snapshot_tier(
40 inp: &[u8],
41 mut builder: crate::operation::modify_snapshot_tier::builders::ModifySnapshotTierOutputBuilder,
42) -> std::result::Result<crate::operation::modify_snapshot_tier::builders::ModifySnapshotTierOutputBuilder, ::aws_smithy_xml::decode::XmlDecodeError>
43{
44 let mut doc = ::aws_smithy_xml::decode::Document::try_from(inp)?;
45
46 #[allow(unused_mut)]
47 let mut decoder = doc.root_element()?;
48 #[allow(unused_variables)]
49 let start_el = decoder.start_el();
50 if !(start_el.matches("ModifySnapshotTierResponse")) {
51 return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(format!(
52 "invalid root, expected ModifySnapshotTierResponse got {:?}",
53 start_el
54 )));
55 }
56 while let Some(mut tag) = decoder.next_tag() {
57 match tag.start_el() {
58 s if s.matches("snapshotId") => {
59 let var_1 =
60 Some(
61 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
62 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
63 .into()
64 )
65 ?
66 )
67 ;
68 builder = builder.set_snapshot_id(var_1);
69 }
70 ,
71 s if s.matches("tieringStartTime") => {
72 let var_2 =
73 Some(
74 ::aws_smithy_types::DateTime::from_str(
75 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
76 , ::aws_smithy_types::date_time::Format::DateTimeWithOffset
77 )
78 .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (timestamp: `com.amazonaws.ec2#MillisecondDateTime`)"))
79 ?
80 )
81 ;
82 builder = builder.set_tiering_start_time(var_2);
83 }
84 ,
85 _ => {}
86 }
87 }
88 Ok(builder)
89}