aws_sdk_m2/protocol_serde/
shape_get_data_set_details.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_get_data_set_details_http_error(
4 _response_status: u16,
5 _response_headers: &::aws_smithy_runtime_api::http::Headers,
6 _response_body: &[u8],
7) -> std::result::Result<
8 crate::operation::get_data_set_details::GetDataSetDetailsOutput,
9 crate::operation::get_data_set_details::GetDataSetDetailsError,
10> {
11 #[allow(unused_mut)]
12 let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
13 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
14 generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
15 let generic = generic_builder.build();
16 let error_code = match generic.code() {
17 Some(code) => code,
18 None => return Err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled(generic)),
19 };
20
21 let _error_message = generic.message().map(|msg| msg.to_owned());
22 Err(match error_code {
23 "AccessDeniedException" => crate::operation::get_data_set_details::GetDataSetDetailsError::AccessDeniedException({
24 #[allow(unused_mut)]
25 let mut tmp = {
26 #[allow(unused_mut)]
27 let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
28 output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
29 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
30 let output = output.meta(generic);
31 crate::serde_util::access_denied_exception_correct_errors(output)
32 .build()
33 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
34 };
35 tmp
36 }),
37 "ConflictException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ConflictException({
38 #[allow(unused_mut)]
39 let mut tmp = {
40 #[allow(unused_mut)]
41 let mut output = crate::types::error::builders::ConflictExceptionBuilder::default();
42 output = crate::protocol_serde::shape_conflict_exception::de_conflict_exception_json_err(_response_body, output)
43 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
44 let output = output.meta(generic);
45 crate::serde_util::conflict_exception_correct_errors(output)
46 .build()
47 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
48 };
49 tmp
50 }),
51 "ExecutionTimeoutException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ExecutionTimeoutException({
52 #[allow(unused_mut)]
53 let mut tmp = {
54 #[allow(unused_mut)]
55 let mut output = crate::types::error::builders::ExecutionTimeoutExceptionBuilder::default();
56 output = crate::protocol_serde::shape_execution_timeout_exception::de_execution_timeout_exception_json_err(_response_body, output)
57 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
58 let output = output.meta(generic);
59 crate::serde_util::execution_timeout_exception_correct_errors(output)
60 .build()
61 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
62 };
63 tmp
64 }),
65 "InternalServerException" => crate::operation::get_data_set_details::GetDataSetDetailsError::InternalServerException({
66 #[allow(unused_mut)]
67 let mut tmp = {
68 #[allow(unused_mut)]
69 let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
70 output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
71 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
72 output = output.set_retry_after_seconds(
73 crate::protocol_serde::shape_internal_server_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
74 crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled(
75 "Failed to parse retryAfterSeconds from header `Retry-After",
76 )
77 })?,
78 );
79 let output = output.meta(generic);
80 crate::serde_util::internal_server_exception_correct_errors(output)
81 .build()
82 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
83 };
84 tmp
85 }),
86 "ResourceNotFoundException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ResourceNotFoundException({
87 #[allow(unused_mut)]
88 let mut tmp = {
89 #[allow(unused_mut)]
90 let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
91 output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
92 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
93 let output = output.meta(generic);
94 crate::serde_util::resource_not_found_exception_correct_errors(output)
95 .build()
96 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
97 };
98 tmp
99 }),
100 "ServiceUnavailableException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ServiceUnavailableException({
101 #[allow(unused_mut)]
102 let mut tmp = {
103 #[allow(unused_mut)]
104 let mut output = crate::types::error::builders::ServiceUnavailableExceptionBuilder::default();
105 output =
106 crate::protocol_serde::shape_service_unavailable_exception::de_service_unavailable_exception_json_err(_response_body, output)
107 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
108 let output = output.meta(generic);
109 crate::serde_util::service_unavailable_exception_correct_errors(output)
110 .build()
111 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
112 };
113 tmp
114 }),
115 "ThrottlingException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ThrottlingException({
116 #[allow(unused_mut)]
117 let mut tmp = {
118 #[allow(unused_mut)]
119 let mut output = crate::types::error::builders::ThrottlingExceptionBuilder::default();
120 output = crate::protocol_serde::shape_throttling_exception::de_throttling_exception_json_err(_response_body, output)
121 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
122 output = output.set_retry_after_seconds(
123 crate::protocol_serde::shape_throttling_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
124 crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled(
125 "Failed to parse retryAfterSeconds from header `Retry-After",
126 )
127 })?,
128 );
129 let output = output.meta(generic);
130 crate::serde_util::throttling_exception_correct_errors(output)
131 .build()
132 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
133 };
134 tmp
135 }),
136 "ValidationException" => crate::operation::get_data_set_details::GetDataSetDetailsError::ValidationException({
137 #[allow(unused_mut)]
138 let mut tmp = {
139 #[allow(unused_mut)]
140 let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
141 output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
142 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
143 let output = output.meta(generic);
144 crate::serde_util::validation_exception_correct_errors(output)
145 .build()
146 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
147 };
148 tmp
149 }),
150 _ => crate::operation::get_data_set_details::GetDataSetDetailsError::generic(generic),
151 })
152}
153
154#[allow(clippy::unnecessary_wraps)]
155pub fn de_get_data_set_details_http_response(
156 _response_status: u16,
157 _response_headers: &::aws_smithy_runtime_api::http::Headers,
158 _response_body: &[u8],
159) -> std::result::Result<
160 crate::operation::get_data_set_details::GetDataSetDetailsOutput,
161 crate::operation::get_data_set_details::GetDataSetDetailsError,
162> {
163 Ok({
164 #[allow(unused_mut)]
165 let mut output = crate::operation::get_data_set_details::builders::GetDataSetDetailsOutputBuilder::default();
166 output = crate::protocol_serde::shape_get_data_set_details::de_get_data_set_details(_response_body, output)
167 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?;
168 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
169 crate::serde_util::get_data_set_details_output_output_correct_errors(output)
170 .build()
171 .map_err(crate::operation::get_data_set_details::GetDataSetDetailsError::unhandled)?
172 })
173}
174
175pub(crate) fn de_get_data_set_details(
176 value: &[u8],
177 mut builder: crate::operation::get_data_set_details::builders::GetDataSetDetailsOutputBuilder,
178) -> ::std::result::Result<
179 crate::operation::get_data_set_details::builders::GetDataSetDetailsOutputBuilder,
180 ::aws_smithy_json::deserialize::error::DeserializeError,
181> {
182 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
183 let tokens = &mut tokens_owned;
184 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
185 loop {
186 match tokens.next().transpose()? {
187 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
188 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
189 "blocksize" => {
190 builder = builder.set_blocksize(
191 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
192 .map(i32::try_from)
193 .transpose()?,
194 );
195 }
196 "creationTime" => {
197 builder = builder.set_creation_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
198 tokens.next(),
199 ::aws_smithy_types::date_time::Format::EpochSeconds,
200 )?);
201 }
202 "dataSetName" => {
203 builder = builder.set_data_set_name(
204 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
205 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
206 .transpose()?,
207 );
208 }
209 "dataSetOrg" => {
210 builder = builder
211 .set_data_set_org(crate::protocol_serde::shape_dataset_detail_org_attributes::de_dataset_detail_org_attributes(tokens)?);
212 }
213 "fileSize" => {
214 builder = builder.set_file_size(
215 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
216 .map(i64::try_from)
217 .transpose()?,
218 );
219 }
220 "lastReferencedTime" => {
221 builder = builder.set_last_referenced_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
222 tokens.next(),
223 ::aws_smithy_types::date_time::Format::EpochSeconds,
224 )?);
225 }
226 "lastUpdatedTime" => {
227 builder = builder.set_last_updated_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
228 tokens.next(),
229 ::aws_smithy_types::date_time::Format::EpochSeconds,
230 )?);
231 }
232 "location" => {
233 builder = builder.set_location(
234 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
235 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
236 .transpose()?,
237 );
238 }
239 "recordLength" => {
240 builder = builder.set_record_length(
241 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
242 .map(i32::try_from)
243 .transpose()?,
244 );
245 }
246 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
247 },
248 other => {
249 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
250 "expected object key or end object, found: {:?}",
251 other
252 )))
253 }
254 }
255 }
256 if tokens.next().is_some() {
257 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
258 "found more JSON tokens after completing parsing",
259 ));
260 }
261 Ok(builder)
262}