aws_sdk_elasticloadbalancingv2/protocol_serde/
shape_modify_target_group_attributes.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_modify_target_group_attributes_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_target_group_attributes::ModifyTargetGroupAttributesOutput,
9 crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError,
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_target_group_attributes::ModifyTargetGroupAttributesError::unhandled)?;
14 generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
15 let generic = generic_builder.build();
16 let error_code = match generic.code() {
17 Some(code) => code,
18 None => return Err(crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::unhandled(generic)),
19 };
20
21 let _error_message = generic.message().map(|msg| msg.to_owned());
22 Err(match error_code {
23 "InvalidConfigurationRequest" => {
24 crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::InvalidConfigurationRequestException({
25 #[allow(unused_mut)]
26 let mut tmp = {
27 #[allow(unused_mut)]
28 let mut output = crate::types::error::builders::InvalidConfigurationRequestExceptionBuilder::default();
29 output =
30 crate::protocol_serde::shape_invalid_configuration_request_exception::de_invalid_configuration_request_exception_xml_err(
31 _response_body,
32 output,
33 )
34 .map_err(crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::unhandled)?;
35 let output = output.meta(generic);
36 output.build()
37 };
38 if tmp.message.is_none() {
39 tmp.message = _error_message;
40 }
41 tmp
42 })
43 }
44 "TargetGroupNotFound" => crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::TargetGroupNotFoundException({
45 #[allow(unused_mut)]
46 let mut tmp = {
47 #[allow(unused_mut)]
48 let mut output = crate::types::error::builders::TargetGroupNotFoundExceptionBuilder::default();
49 output = crate::protocol_serde::shape_target_group_not_found_exception::de_target_group_not_found_exception_xml_err(
50 _response_body,
51 output,
52 )
53 .map_err(crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::unhandled)?;
54 let output = output.meta(generic);
55 output.build()
56 };
57 if tmp.message.is_none() {
58 tmp.message = _error_message;
59 }
60 tmp
61 }),
62 _ => crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::generic(generic),
63 })
64}
65
66#[allow(clippy::unnecessary_wraps)]
67pub fn de_modify_target_group_attributes_http_response(
68 _response_status: u16,
69 _response_headers: &::aws_smithy_runtime_api::http::Headers,
70 _response_body: &[u8],
71) -> std::result::Result<
72 crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesOutput,
73 crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError,
74> {
75 Ok({
76 #[allow(unused_mut)]
77 let mut output = crate::operation::modify_target_group_attributes::builders::ModifyTargetGroupAttributesOutputBuilder::default();
78 output = crate::protocol_serde::shape_modify_target_group_attributes::de_modify_target_group_attributes(_response_body, output)
79 .map_err(crate::operation::modify_target_group_attributes::ModifyTargetGroupAttributesError::unhandled)?;
80 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
81 output.build()
82 })
83}
84
85#[allow(unused_mut)]
86pub fn de_modify_target_group_attributes(
87 inp: &[u8],
88 mut builder: crate::operation::modify_target_group_attributes::builders::ModifyTargetGroupAttributesOutputBuilder,
89) -> std::result::Result<
90 crate::operation::modify_target_group_attributes::builders::ModifyTargetGroupAttributesOutputBuilder,
91 ::aws_smithy_xml::decode::XmlDecodeError,
92> {
93 let mut doc = ::aws_smithy_xml::decode::Document::try_from(inp)?;
94
95 #[allow(unused_mut)]
96 let mut decoder = doc.root_element()?;
97 #[allow(unused_variables)]
98 let start_el = decoder.start_el();
99 if !(start_el.matches("ModifyTargetGroupAttributesResponse")) {
100 return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(format!(
101 "invalid root, expected ModifyTargetGroupAttributesResponse got {:?}",
102 start_el
103 )));
104 }
105 if let Some(mut result_tag) = decoder.next_tag() {
106 let start_el = result_tag.start_el();
107 if !(start_el.matches("ModifyTargetGroupAttributesResult")) {
108 return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(format!(
109 "invalid result, expected ModifyTargetGroupAttributesResult got {:?}",
110 start_el
111 )));
112 }
113 while let Some(mut tag) = result_tag.next_tag() {
114 match tag.start_el() {
115 s if s.matches("Attributes") => {
116 let var_1 =
117 Some(
118 crate::protocol_serde::shape_target_group_attributes::de_target_group_attributes(&mut tag)
119 ?
120 )
121 ;
122 builder = builder.set_attributes(var_1);
123 }
124 ,
125 _ => {}
126 }
127 }
128 } else {
129 return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(
130 "expected ModifyTargetGroupAttributesResult tag",
131 ));
132 };
133 Ok(builder)
134}