aws_sdk_dax/protocol_serde/
shape_create_cluster.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_create_cluster_http_error(
4 _response_status: u16,
5 _response_headers: &::aws_smithy_runtime_api::http::Headers,
6 _response_body: &[u8],
7) -> std::result::Result<crate::operation::create_cluster::CreateClusterOutput, crate::operation::create_cluster::CreateClusterError> {
8 #[allow(unused_mut)]
9 let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
10 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
11 generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
12 let generic = generic_builder.build();
13 let error_code = match generic.code() {
14 Some(code) => code,
15 None => return Err(crate::operation::create_cluster::CreateClusterError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "ClusterAlreadyExistsFault" => crate::operation::create_cluster::CreateClusterError::ClusterAlreadyExistsFault({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::ClusterAlreadyExistsFaultBuilder::default();
25 output = crate::protocol_serde::shape_cluster_already_exists_fault::de_cluster_already_exists_fault_json_err(_response_body, output)
26 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
27 let output = output.meta(generic);
28 output.build()
29 };
30 if tmp.message.is_none() {
31 tmp.message = _error_message;
32 }
33 tmp
34 }),
35 "ClusterQuotaForCustomerExceededFault" => {
36 crate::operation::create_cluster::CreateClusterError::ClusterQuotaForCustomerExceededFault({
37 #[allow(unused_mut)]
38 let mut tmp = {
39 #[allow(unused_mut)]
40 let mut output = crate::types::error::builders::ClusterQuotaForCustomerExceededFaultBuilder::default();
41 output = crate::protocol_serde::shape_cluster_quota_for_customer_exceeded_fault::de_cluster_quota_for_customer_exceeded_fault_json_err(_response_body, output).map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
42 let output = output.meta(generic);
43 output.build()
44 };
45 if tmp.message.is_none() {
46 tmp.message = _error_message;
47 }
48 tmp
49 })
50 }
51 "InsufficientClusterCapacityFault" => crate::operation::create_cluster::CreateClusterError::InsufficientClusterCapacityFault({
52 #[allow(unused_mut)]
53 let mut tmp = {
54 #[allow(unused_mut)]
55 let mut output = crate::types::error::builders::InsufficientClusterCapacityFaultBuilder::default();
56 output = crate::protocol_serde::shape_insufficient_cluster_capacity_fault::de_insufficient_cluster_capacity_fault_json_err(
57 _response_body,
58 output,
59 )
60 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
61 let output = output.meta(generic);
62 output.build()
63 };
64 if tmp.message.is_none() {
65 tmp.message = _error_message;
66 }
67 tmp
68 }),
69 "InvalidClusterStateFault" => crate::operation::create_cluster::CreateClusterError::InvalidClusterStateFault({
70 #[allow(unused_mut)]
71 let mut tmp = {
72 #[allow(unused_mut)]
73 let mut output = crate::types::error::builders::InvalidClusterStateFaultBuilder::default();
74 output = crate::protocol_serde::shape_invalid_cluster_state_fault::de_invalid_cluster_state_fault_json_err(_response_body, output)
75 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
76 let output = output.meta(generic);
77 output.build()
78 };
79 if tmp.message.is_none() {
80 tmp.message = _error_message;
81 }
82 tmp
83 }),
84 "InvalidParameterCombinationException" => crate::operation::create_cluster::CreateClusterError::InvalidParameterCombinationException({
85 #[allow(unused_mut)]
86 let mut tmp = {
87 #[allow(unused_mut)]
88 let mut output = crate::types::error::builders::InvalidParameterCombinationExceptionBuilder::default();
89 output = crate::protocol_serde::shape_invalid_parameter_combination_exception::de_invalid_parameter_combination_exception_json_err(
90 _response_body,
91 output,
92 )
93 .map_err(crate::operation::create_cluster::CreateClusterError::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 "InvalidParameterGroupStateFault" => crate::operation::create_cluster::CreateClusterError::InvalidParameterGroupStateFault({
103 #[allow(unused_mut)]
104 let mut tmp = {
105 #[allow(unused_mut)]
106 let mut output = crate::types::error::builders::InvalidParameterGroupStateFaultBuilder::default();
107 output = crate::protocol_serde::shape_invalid_parameter_group_state_fault::de_invalid_parameter_group_state_fault_json_err(
108 _response_body,
109 output,
110 )
111 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
112 let output = output.meta(generic);
113 output.build()
114 };
115 if tmp.message.is_none() {
116 tmp.message = _error_message;
117 }
118 tmp
119 }),
120 "InvalidParameterValueException" => crate::operation::create_cluster::CreateClusterError::InvalidParameterValueException({
121 #[allow(unused_mut)]
122 let mut tmp = {
123 #[allow(unused_mut)]
124 let mut output = crate::types::error::builders::InvalidParameterValueExceptionBuilder::default();
125 output = crate::protocol_serde::shape_invalid_parameter_value_exception::de_invalid_parameter_value_exception_json_err(
126 _response_body,
127 output,
128 )
129 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
130 let output = output.meta(generic);
131 output.build()
132 };
133 if tmp.message.is_none() {
134 tmp.message = _error_message;
135 }
136 tmp
137 }),
138 "InvalidVPCNetworkStateFault" => crate::operation::create_cluster::CreateClusterError::InvalidVpcNetworkStateFault({
139 #[allow(unused_mut)]
140 let mut tmp = {
141 #[allow(unused_mut)]
142 let mut output = crate::types::error::builders::InvalidVpcNetworkStateFaultBuilder::default();
143 output =
144 crate::protocol_serde::shape_invalid_vpc_network_state_fault::de_invalid_vpc_network_state_fault_json_err(_response_body, output)
145 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
146 let output = output.meta(generic);
147 output.build()
148 };
149 if tmp.message.is_none() {
150 tmp.message = _error_message;
151 }
152 tmp
153 }),
154 "NodeQuotaForClusterExceededFault" => crate::operation::create_cluster::CreateClusterError::NodeQuotaForClusterExceededFault({
155 #[allow(unused_mut)]
156 let mut tmp = {
157 #[allow(unused_mut)]
158 let mut output = crate::types::error::builders::NodeQuotaForClusterExceededFaultBuilder::default();
159 output = crate::protocol_serde::shape_node_quota_for_cluster_exceeded_fault::de_node_quota_for_cluster_exceeded_fault_json_err(
160 _response_body,
161 output,
162 )
163 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
164 let output = output.meta(generic);
165 output.build()
166 };
167 if tmp.message.is_none() {
168 tmp.message = _error_message;
169 }
170 tmp
171 }),
172 "NodeQuotaForCustomerExceededFault" => crate::operation::create_cluster::CreateClusterError::NodeQuotaForCustomerExceededFault({
173 #[allow(unused_mut)]
174 let mut tmp = {
175 #[allow(unused_mut)]
176 let mut output = crate::types::error::builders::NodeQuotaForCustomerExceededFaultBuilder::default();
177 output = crate::protocol_serde::shape_node_quota_for_customer_exceeded_fault::de_node_quota_for_customer_exceeded_fault_json_err(
178 _response_body,
179 output,
180 )
181 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
182 let output = output.meta(generic);
183 output.build()
184 };
185 if tmp.message.is_none() {
186 tmp.message = _error_message;
187 }
188 tmp
189 }),
190 "ParameterGroupNotFoundFault" => crate::operation::create_cluster::CreateClusterError::ParameterGroupNotFoundFault({
191 #[allow(unused_mut)]
192 let mut tmp = {
193 #[allow(unused_mut)]
194 let mut output = crate::types::error::builders::ParameterGroupNotFoundFaultBuilder::default();
195 output =
196 crate::protocol_serde::shape_parameter_group_not_found_fault::de_parameter_group_not_found_fault_json_err(_response_body, output)
197 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
198 let output = output.meta(generic);
199 output.build()
200 };
201 if tmp.message.is_none() {
202 tmp.message = _error_message;
203 }
204 tmp
205 }),
206 "ServiceLinkedRoleNotFoundFault" => crate::operation::create_cluster::CreateClusterError::ServiceLinkedRoleNotFoundFault({
207 #[allow(unused_mut)]
208 let mut tmp = {
209 #[allow(unused_mut)]
210 let mut output = crate::types::error::builders::ServiceLinkedRoleNotFoundFaultBuilder::default();
211 output = crate::protocol_serde::shape_service_linked_role_not_found_fault::de_service_linked_role_not_found_fault_json_err(
212 _response_body,
213 output,
214 )
215 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
216 let output = output.meta(generic);
217 output.build()
218 };
219 if tmp.message.is_none() {
220 tmp.message = _error_message;
221 }
222 tmp
223 }),
224 "ServiceQuotaExceededException" => crate::operation::create_cluster::CreateClusterError::ServiceQuotaExceededException({
225 #[allow(unused_mut)]
226 let mut tmp = {
227 #[allow(unused_mut)]
228 let mut output = crate::types::error::builders::ServiceQuotaExceededExceptionBuilder::default();
229 output = crate::protocol_serde::shape_service_quota_exceeded_exception::de_service_quota_exceeded_exception_json_err(
230 _response_body,
231 output,
232 )
233 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
234 let output = output.meta(generic);
235 output.build()
236 };
237 if tmp.message.is_none() {
238 tmp.message = _error_message;
239 }
240 tmp
241 }),
242 "SubnetGroupNotFoundFault" => crate::operation::create_cluster::CreateClusterError::SubnetGroupNotFoundFault({
243 #[allow(unused_mut)]
244 let mut tmp = {
245 #[allow(unused_mut)]
246 let mut output = crate::types::error::builders::SubnetGroupNotFoundFaultBuilder::default();
247 output = crate::protocol_serde::shape_subnet_group_not_found_fault::de_subnet_group_not_found_fault_json_err(_response_body, output)
248 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
249 let output = output.meta(generic);
250 output.build()
251 };
252 if tmp.message.is_none() {
253 tmp.message = _error_message;
254 }
255 tmp
256 }),
257 "TagQuotaPerResourceExceeded" => crate::operation::create_cluster::CreateClusterError::TagQuotaPerResourceExceeded({
258 #[allow(unused_mut)]
259 let mut tmp = {
260 #[allow(unused_mut)]
261 let mut output = crate::types::error::builders::TagQuotaPerResourceExceededBuilder::default();
262 output =
263 crate::protocol_serde::shape_tag_quota_per_resource_exceeded::de_tag_quota_per_resource_exceeded_json_err(_response_body, output)
264 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
265 let output = output.meta(generic);
266 output.build()
267 };
268 if tmp.message.is_none() {
269 tmp.message = _error_message;
270 }
271 tmp
272 }),
273 _ => crate::operation::create_cluster::CreateClusterError::generic(generic),
274 })
275}
276
277#[allow(clippy::unnecessary_wraps)]
278pub fn de_create_cluster_http_response(
279 _response_status: u16,
280 _response_headers: &::aws_smithy_runtime_api::http::Headers,
281 _response_body: &[u8],
282) -> std::result::Result<crate::operation::create_cluster::CreateClusterOutput, crate::operation::create_cluster::CreateClusterError> {
283 Ok({
284 #[allow(unused_mut)]
285 let mut output = crate::operation::create_cluster::builders::CreateClusterOutputBuilder::default();
286 output = crate::protocol_serde::shape_create_cluster::de_create_cluster(_response_body, output)
287 .map_err(crate::operation::create_cluster::CreateClusterError::unhandled)?;
288 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
289 output.build()
290 })
291}
292
293pub fn ser_create_cluster_input(
294 input: &crate::operation::create_cluster::CreateClusterInput,
295) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
296 let mut out = String::new();
297 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
298 crate::protocol_serde::shape_create_cluster_input::ser_create_cluster_input_input(&mut object, input)?;
299 object.finish();
300 Ok(::aws_smithy_types::body::SdkBody::from(out))
301}
302
303pub(crate) fn de_create_cluster(
304 value: &[u8],
305 mut builder: crate::operation::create_cluster::builders::CreateClusterOutputBuilder,
306) -> ::std::result::Result<
307 crate::operation::create_cluster::builders::CreateClusterOutputBuilder,
308 ::aws_smithy_json::deserialize::error::DeserializeError,
309> {
310 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
311 let tokens = &mut tokens_owned;
312 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
313 loop {
314 match tokens.next().transpose()? {
315 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
316 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
317 "Cluster" => {
318 builder = builder.set_cluster(crate::protocol_serde::shape_cluster::de_cluster(tokens)?);
319 }
320 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
321 },
322 other => {
323 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
324 "expected object key or end object, found: {:?}",
325 other
326 )))
327 }
328 }
329 }
330 if tokens.next().is_some() {
331 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
332 "found more JSON tokens after completing parsing",
333 ));
334 }
335 Ok(builder)
336}