aws_sdk_memorydb/protocol_serde/
shape_failover_shard.rs1#[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}