aws_sdk_wafregional/protocol_serde/
shape_create_geo_match_set.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_create_geo_match_set_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::create_geo_match_set::CreateGeoMatchSetOutput,
9 crate::operation::create_geo_match_set::CreateGeoMatchSetError,
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::create_geo_match_set::CreateGeoMatchSetError::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::create_geo_match_set::CreateGeoMatchSetError::unhandled(generic)),
19 };
20
21 let _error_message = generic.message().map(|msg| msg.to_owned());
22 Err(match error_code {
23 "WAFDisallowedNameException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafDisallowedNameException({
24 #[allow(unused_mut)]
25 let mut tmp = {
26 #[allow(unused_mut)]
27 let mut output = crate::types::error::builders::WafDisallowedNameExceptionBuilder::default();
28 output =
29 crate::protocol_serde::shape_waf_disallowed_name_exception::de_waf_disallowed_name_exception_json_err(_response_body, output)
30 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
31 let output = output.meta(generic);
32 output.build()
33 };
34 if tmp.message.is_none() {
35 tmp.message = _error_message;
36 }
37 tmp
38 }),
39 "WAFInternalErrorException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafInternalErrorException({
40 #[allow(unused_mut)]
41 let mut tmp = {
42 #[allow(unused_mut)]
43 let mut output = crate::types::error::builders::WafInternalErrorExceptionBuilder::default();
44 output = crate::protocol_serde::shape_waf_internal_error_exception::de_waf_internal_error_exception_json_err(_response_body, output)
45 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
46 let output = output.meta(generic);
47 output.build()
48 };
49 if tmp.message.is_none() {
50 tmp.message = _error_message;
51 }
52 tmp
53 }),
54 "WAFInvalidAccountException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafInvalidAccountException({
55 #[allow(unused_mut)]
56 let mut tmp = {
57 #[allow(unused_mut)]
58 let mut output = crate::types::error::builders::WafInvalidAccountExceptionBuilder::default();
59 output =
60 crate::protocol_serde::shape_waf_invalid_account_exception::de_waf_invalid_account_exception_json_err(_response_body, output)
61 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
62 let output = output.meta(generic);
63 output.build()
64 };
65 if tmp.message.is_none() {
66 tmp.message = _error_message;
67 }
68 tmp
69 }),
70 "WAFInvalidParameterException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafInvalidParameterException({
71 #[allow(unused_mut)]
72 let mut tmp = {
73 #[allow(unused_mut)]
74 let mut output = crate::types::error::builders::WafInvalidParameterExceptionBuilder::default();
75 output =
76 crate::protocol_serde::shape_waf_invalid_parameter_exception::de_waf_invalid_parameter_exception_json_err(_response_body, output)
77 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
78 let output = output.meta(generic);
79 output.build()
80 };
81 if tmp.message.is_none() {
82 tmp.message = _error_message;
83 }
84 tmp
85 }),
86 "WAFLimitsExceededException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafLimitsExceededException({
87 #[allow(unused_mut)]
88 let mut tmp = {
89 #[allow(unused_mut)]
90 let mut output = crate::types::error::builders::WafLimitsExceededExceptionBuilder::default();
91 output =
92 crate::protocol_serde::shape_waf_limits_exceeded_exception::de_waf_limits_exceeded_exception_json_err(_response_body, output)
93 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
94 let output = output.meta(generic);
95 output.build()
96 };
97 if tmp.message.is_none() {
98 tmp.message = _error_message;
99 }
100 tmp
101 }),
102 "WAFStaleDataException" => crate::operation::create_geo_match_set::CreateGeoMatchSetError::WafStaleDataException({
103 #[allow(unused_mut)]
104 let mut tmp = {
105 #[allow(unused_mut)]
106 let mut output = crate::types::error::builders::WafStaleDataExceptionBuilder::default();
107 output = crate::protocol_serde::shape_waf_stale_data_exception::de_waf_stale_data_exception_json_err(_response_body, output)
108 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
109 let output = output.meta(generic);
110 output.build()
111 };
112 if tmp.message.is_none() {
113 tmp.message = _error_message;
114 }
115 tmp
116 }),
117 _ => crate::operation::create_geo_match_set::CreateGeoMatchSetError::generic(generic),
118 })
119}
120
121#[allow(clippy::unnecessary_wraps)]
122pub fn de_create_geo_match_set_http_response(
123 _response_status: u16,
124 _response_headers: &::aws_smithy_runtime_api::http::Headers,
125 _response_body: &[u8],
126) -> std::result::Result<
127 crate::operation::create_geo_match_set::CreateGeoMatchSetOutput,
128 crate::operation::create_geo_match_set::CreateGeoMatchSetError,
129> {
130 Ok({
131 #[allow(unused_mut)]
132 let mut output = crate::operation::create_geo_match_set::builders::CreateGeoMatchSetOutputBuilder::default();
133 output = crate::protocol_serde::shape_create_geo_match_set::de_create_geo_match_set(_response_body, output)
134 .map_err(crate::operation::create_geo_match_set::CreateGeoMatchSetError::unhandled)?;
135 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
136 output.build()
137 })
138}
139
140pub fn ser_create_geo_match_set_input(
141 input: &crate::operation::create_geo_match_set::CreateGeoMatchSetInput,
142) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
143 let mut out = String::new();
144 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
145 crate::protocol_serde::shape_create_geo_match_set_input::ser_create_geo_match_set_input_input(&mut object, input)?;
146 object.finish();
147 Ok(::aws_smithy_types::body::SdkBody::from(out))
148}
149
150pub(crate) fn de_create_geo_match_set(
151 value: &[u8],
152 mut builder: crate::operation::create_geo_match_set::builders::CreateGeoMatchSetOutputBuilder,
153) -> ::std::result::Result<
154 crate::operation::create_geo_match_set::builders::CreateGeoMatchSetOutputBuilder,
155 ::aws_smithy_json::deserialize::error::DeserializeError,
156> {
157 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
158 let tokens = &mut tokens_owned;
159 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
160 loop {
161 match tokens.next().transpose()? {
162 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
163 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
164 "GeoMatchSet" => {
165 builder = builder.set_geo_match_set(crate::protocol_serde::shape_geo_match_set::de_geo_match_set(tokens)?);
166 }
167 "ChangeToken" => {
168 builder = builder.set_change_token(
169 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
170 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
171 .transpose()?,
172 );
173 }
174 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
175 },
176 other => {
177 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
178 "expected object key or end object, found: {:?}",
179 other
180 )))
181 }
182 }
183 }
184 if tokens.next().is_some() {
185 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
186 "found more JSON tokens after completing parsing",
187 ));
188 }
189 Ok(builder)
190}