aws_sdk_fsx/protocol_serde/
shape_delete_file_cache.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_delete_file_cache_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::delete_file_cache::DeleteFileCacheOutput, crate::operation::delete_file_cache::DeleteFileCacheError> {
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::delete_file_cache::DeleteFileCacheError::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::delete_file_cache::DeleteFileCacheError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "BadRequest" => crate::operation::delete_file_cache::DeleteFileCacheError::BadRequest({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::BadRequestBuilder::default();
25 output = crate::protocol_serde::shape_bad_request::de_bad_request_json_err(_response_body, output)
26 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::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 "FileCacheNotFound" => crate::operation::delete_file_cache::DeleteFileCacheError::FileCacheNotFound({
36 #[allow(unused_mut)]
37 let mut tmp = {
38 #[allow(unused_mut)]
39 let mut output = crate::types::error::builders::FileCacheNotFoundBuilder::default();
40 output = crate::protocol_serde::shape_file_cache_not_found::de_file_cache_not_found_json_err(_response_body, output)
41 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::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 "IncompatibleParameterError" => crate::operation::delete_file_cache::DeleteFileCacheError::IncompatibleParameterError({
51 #[allow(unused_mut)]
52 let mut tmp = {
53 #[allow(unused_mut)]
54 let mut output = crate::types::error::builders::IncompatibleParameterErrorBuilder::default();
55 output = crate::protocol_serde::shape_incompatible_parameter_error::de_incompatible_parameter_error_json_err(_response_body, output)
56 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::unhandled)?;
57 let output = output.meta(generic);
58 crate::serde_util::incompatible_parameter_error_correct_errors(output).build()
59 };
60 if tmp.message.is_none() {
61 tmp.message = _error_message;
62 }
63 tmp
64 }),
65 "InternalServerError" => crate::operation::delete_file_cache::DeleteFileCacheError::InternalServerError({
66 #[allow(unused_mut)]
67 let mut tmp = {
68 #[allow(unused_mut)]
69 let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
70 output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
71 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::unhandled)?;
72 let output = output.meta(generic);
73 output.build()
74 };
75 if tmp.message.is_none() {
76 tmp.message = _error_message;
77 }
78 tmp
79 }),
80 "ServiceLimitExceeded" => crate::operation::delete_file_cache::DeleteFileCacheError::ServiceLimitExceeded({
81 #[allow(unused_mut)]
82 let mut tmp = {
83 #[allow(unused_mut)]
84 let mut output = crate::types::error::builders::ServiceLimitExceededBuilder::default();
85 output = crate::protocol_serde::shape_service_limit_exceeded::de_service_limit_exceeded_json_err(_response_body, output)
86 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::unhandled)?;
87 let output = output.meta(generic);
88 crate::serde_util::service_limit_exceeded_correct_errors(output).build()
89 };
90 if tmp.message.is_none() {
91 tmp.message = _error_message;
92 }
93 tmp
94 }),
95 _ => crate::operation::delete_file_cache::DeleteFileCacheError::generic(generic),
96 })
97}
98
99#[allow(clippy::unnecessary_wraps)]
100pub fn de_delete_file_cache_http_response(
101 _response_status: u16,
102 _response_headers: &::aws_smithy_runtime_api::http::Headers,
103 _response_body: &[u8],
104) -> std::result::Result<crate::operation::delete_file_cache::DeleteFileCacheOutput, crate::operation::delete_file_cache::DeleteFileCacheError> {
105 Ok({
106 #[allow(unused_mut)]
107 let mut output = crate::operation::delete_file_cache::builders::DeleteFileCacheOutputBuilder::default();
108 output = crate::protocol_serde::shape_delete_file_cache::de_delete_file_cache(_response_body, output)
109 .map_err(crate::operation::delete_file_cache::DeleteFileCacheError::unhandled)?;
110 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
111 output.build()
112 })
113}
114
115pub fn ser_delete_file_cache_input(
116 input: &crate::operation::delete_file_cache::DeleteFileCacheInput,
117) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
118 let mut out = String::new();
119 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
120 crate::protocol_serde::shape_delete_file_cache_input::ser_delete_file_cache_input_input(&mut object, input)?;
121 object.finish();
122 Ok(::aws_smithy_types::body::SdkBody::from(out))
123}
124
125pub(crate) fn de_delete_file_cache(
126 value: &[u8],
127 mut builder: crate::operation::delete_file_cache::builders::DeleteFileCacheOutputBuilder,
128) -> ::std::result::Result<
129 crate::operation::delete_file_cache::builders::DeleteFileCacheOutputBuilder,
130 ::aws_smithy_json::deserialize::error::DeserializeError,
131> {
132 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
133 let tokens = &mut tokens_owned;
134 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
135 loop {
136 match tokens.next().transpose()? {
137 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
138 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
139 "FileCacheId" => {
140 builder = builder.set_file_cache_id(
141 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
142 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
143 .transpose()?,
144 );
145 }
146 "Lifecycle" => {
147 builder = builder.set_lifecycle(
148 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
149 .map(|s| s.to_unescaped().map(|u| crate::types::FileCacheLifecycle::from(u.as_ref())))
150 .transpose()?,
151 );
152 }
153 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
154 },
155 other => {
156 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
157 "expected object key or end object, found: {:?}",
158 other
159 )))
160 }
161 }
162 }
163 if tokens.next().is_some() {
164 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
165 "found more JSON tokens after completing parsing",
166 ));
167 }
168 Ok(builder)
169}