aws_sdk_dax/protocol_serde/
shape_create_cluster.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[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}