aws_sdk_memorydb/protocol_serde/
shape_failover_shard.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_failover_shard_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::failover_shard::FailoverShardOutput, crate::operation::failover_shard::FailoverShardError> {
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::failover_shard::FailoverShardError::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::failover_shard::FailoverShardError::unhandled(generic)),
16    };
17
18    let _error_message = generic.message().map(|msg| msg.to_owned());
19    Err(match error_code {
20        "APICallRateForCustomerExceededFault" => {
21            crate::operation::failover_shard::FailoverShardError::ApiCallRateForCustomerExceededFault({
22                #[allow(unused_mut)]
23                let mut tmp = {
24                    #[allow(unused_mut)]
25                    let mut output = crate::types::error::builders::ApiCallRateForCustomerExceededFaultBuilder::default();
26                    output = crate::protocol_serde::shape_api_call_rate_for_customer_exceeded_fault::de_api_call_rate_for_customer_exceeded_fault_json_err(_response_body, output).map_err(crate::operation::failover_shard::FailoverShardError::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        }
36        "ClusterNotFoundFault" => crate::operation::failover_shard::FailoverShardError::ClusterNotFoundFault({
37            #[allow(unused_mut)]
38            let mut tmp = {
39                #[allow(unused_mut)]
40                let mut output = crate::types::error::builders::ClusterNotFoundFaultBuilder::default();
41                output = crate::protocol_serde::shape_cluster_not_found_fault::de_cluster_not_found_fault_json_err(_response_body, output)
42                    .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
43                let output = output.meta(generic);
44                output.build()
45            };
46            if tmp.message.is_none() {
47                tmp.message = _error_message;
48            }
49            tmp
50        }),
51        "InvalidClusterStateFault" => crate::operation::failover_shard::FailoverShardError::InvalidClusterStateFault({
52            #[allow(unused_mut)]
53            let mut tmp = {
54                #[allow(unused_mut)]
55                let mut output = crate::types::error::builders::InvalidClusterStateFaultBuilder::default();
56                output = crate::protocol_serde::shape_invalid_cluster_state_fault::de_invalid_cluster_state_fault_json_err(_response_body, output)
57                    .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
58                let output = output.meta(generic);
59                output.build()
60            };
61            if tmp.message.is_none() {
62                tmp.message = _error_message;
63            }
64            tmp
65        }),
66        "InvalidKMSKeyFault" => crate::operation::failover_shard::FailoverShardError::InvalidKmsKeyFault({
67            #[allow(unused_mut)]
68            let mut tmp = {
69                #[allow(unused_mut)]
70                let mut output = crate::types::error::builders::InvalidKmsKeyFaultBuilder::default();
71                output = crate::protocol_serde::shape_invalid_kms_key_fault::de_invalid_kms_key_fault_json_err(_response_body, output)
72                    .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
73                let output = output.meta(generic);
74                output.build()
75            };
76            if tmp.message.is_none() {
77                tmp.message = _error_message;
78            }
79            tmp
80        }),
81        "InvalidParameterCombinationException" => crate::operation::failover_shard::FailoverShardError::InvalidParameterCombinationException({
82            #[allow(unused_mut)]
83            let mut tmp = {
84                #[allow(unused_mut)]
85                let mut output = crate::types::error::builders::InvalidParameterCombinationExceptionBuilder::default();
86                output = crate::protocol_serde::shape_invalid_parameter_combination_exception::de_invalid_parameter_combination_exception_json_err(
87                    _response_body,
88                    output,
89                )
90                .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
91                let output = output.meta(generic);
92                output.build()
93            };
94            if tmp.message.is_none() {
95                tmp.message = _error_message;
96            }
97            tmp
98        }),
99        "InvalidParameterValueException" => crate::operation::failover_shard::FailoverShardError::InvalidParameterValueException({
100            #[allow(unused_mut)]
101            let mut tmp = {
102                #[allow(unused_mut)]
103                let mut output = crate::types::error::builders::InvalidParameterValueExceptionBuilder::default();
104                output = crate::protocol_serde::shape_invalid_parameter_value_exception::de_invalid_parameter_value_exception_json_err(
105                    _response_body,
106                    output,
107                )
108                .map_err(crate::operation::failover_shard::FailoverShardError::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        "ShardNotFoundFault" => crate::operation::failover_shard::FailoverShardError::ShardNotFoundFault({
118            #[allow(unused_mut)]
119            let mut tmp = {
120                #[allow(unused_mut)]
121                let mut output = crate::types::error::builders::ShardNotFoundFaultBuilder::default();
122                output = crate::protocol_serde::shape_shard_not_found_fault::de_shard_not_found_fault_json_err(_response_body, output)
123                    .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
124                let output = output.meta(generic);
125                output.build()
126            };
127            if tmp.message.is_none() {
128                tmp.message = _error_message;
129            }
130            tmp
131        }),
132        "TestFailoverNotAvailableFault" => crate::operation::failover_shard::FailoverShardError::TestFailoverNotAvailableFault({
133            #[allow(unused_mut)]
134            let mut tmp = {
135                #[allow(unused_mut)]
136                let mut output = crate::types::error::builders::TestFailoverNotAvailableFaultBuilder::default();
137                output = crate::protocol_serde::shape_test_failover_not_available_fault::de_test_failover_not_available_fault_json_err(
138                    _response_body,
139                    output,
140                )
141                .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
142                let output = output.meta(generic);
143                output.build()
144            };
145            if tmp.message.is_none() {
146                tmp.message = _error_message;
147            }
148            tmp
149        }),
150        _ => crate::operation::failover_shard::FailoverShardError::generic(generic),
151    })
152}
153
154#[allow(clippy::unnecessary_wraps)]
155pub fn de_failover_shard_http_response(
156    _response_status: u16,
157    _response_headers: &::aws_smithy_runtime_api::http::Headers,
158    _response_body: &[u8],
159) -> std::result::Result<crate::operation::failover_shard::FailoverShardOutput, crate::operation::failover_shard::FailoverShardError> {
160    Ok({
161        #[allow(unused_mut)]
162        let mut output = crate::operation::failover_shard::builders::FailoverShardOutputBuilder::default();
163        output = crate::protocol_serde::shape_failover_shard::de_failover_shard(_response_body, output)
164            .map_err(crate::operation::failover_shard::FailoverShardError::unhandled)?;
165        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
166        output.build()
167    })
168}
169
170pub fn ser_failover_shard_input(
171    input: &crate::operation::failover_shard::FailoverShardInput,
172) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
173    let mut out = String::new();
174    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
175    crate::protocol_serde::shape_failover_shard_input::ser_failover_shard_input_input(&mut object, input)?;
176    object.finish();
177    Ok(::aws_smithy_types::body::SdkBody::from(out))
178}
179
180pub(crate) fn de_failover_shard(
181    value: &[u8],
182    mut builder: crate::operation::failover_shard::builders::FailoverShardOutputBuilder,
183) -> ::std::result::Result<
184    crate::operation::failover_shard::builders::FailoverShardOutputBuilder,
185    ::aws_smithy_json::deserialize::error::DeserializeError,
186> {
187    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
188    let tokens = &mut tokens_owned;
189    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
190    loop {
191        match tokens.next().transpose()? {
192            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
193            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
194                "Cluster" => {
195                    builder = builder.set_cluster(crate::protocol_serde::shape_cluster::de_cluster(tokens)?);
196                }
197                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
198            },
199            other => {
200                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
201                    "expected object key or end object, found: {other:?}"
202                )))
203            }
204        }
205    }
206    if tokens.next().is_some() {
207        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
208            "found more JSON tokens after completing parsing",
209        ));
210    }
211    Ok(builder)
212}