aws_sdk_sagemaker/protocol_serde/
shape_describe_cluster.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_describe_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::describe_cluster::DescribeClusterOutput, crate::operation::describe_cluster::DescribeClusterError> {
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::describe_cluster::DescribeClusterError::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::describe_cluster::DescribeClusterError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "ResourceNotFound" => crate::operation::describe_cluster::DescribeClusterError::ResourceNotFound({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::ResourceNotFoundBuilder::default();
25 output = crate::protocol_serde::shape_resource_not_found::de_resource_not_found_json_err(_response_body, output)
26 .map_err(crate::operation::describe_cluster::DescribeClusterError::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 _ => crate::operation::describe_cluster::DescribeClusterError::generic(generic),
36 })
37}
38
39#[allow(clippy::unnecessary_wraps)]
40pub fn de_describe_cluster_http_response(
41 _response_status: u16,
42 _response_headers: &::aws_smithy_runtime_api::http::Headers,
43 _response_body: &[u8],
44) -> std::result::Result<crate::operation::describe_cluster::DescribeClusterOutput, crate::operation::describe_cluster::DescribeClusterError> {
45 Ok({
46 #[allow(unused_mut)]
47 let mut output = crate::operation::describe_cluster::builders::DescribeClusterOutputBuilder::default();
48 output = crate::protocol_serde::shape_describe_cluster::de_describe_cluster(_response_body, output)
49 .map_err(crate::operation::describe_cluster::DescribeClusterError::unhandled)?;
50 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
51 crate::serde_util::describe_cluster_output_output_correct_errors(output).build()
52 })
53}
54
55pub fn ser_describe_cluster_input(
56 input: &crate::operation::describe_cluster::DescribeClusterInput,
57) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
58 let mut out = String::new();
59 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
60 crate::protocol_serde::shape_describe_cluster_input::ser_describe_cluster_input_input(&mut object, input)?;
61 object.finish();
62 Ok(::aws_smithy_types::body::SdkBody::from(out))
63}
64
65pub(crate) fn de_describe_cluster(
66 value: &[u8],
67 mut builder: crate::operation::describe_cluster::builders::DescribeClusterOutputBuilder,
68) -> ::std::result::Result<
69 crate::operation::describe_cluster::builders::DescribeClusterOutputBuilder,
70 ::aws_smithy_json::deserialize::error::DeserializeError,
71> {
72 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
73 let tokens = &mut tokens_owned;
74 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
75 loop {
76 match tokens.next().transpose()? {
77 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
78 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
79 "ClusterArn" => {
80 builder = builder.set_cluster_arn(
81 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
82 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
83 .transpose()?,
84 );
85 }
86 "ClusterName" => {
87 builder = builder.set_cluster_name(
88 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
89 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
90 .transpose()?,
91 );
92 }
93 "ClusterStatus" => {
94 builder = builder.set_cluster_status(
95 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
96 .map(|s| s.to_unescaped().map(|u| crate::types::ClusterStatus::from(u.as_ref())))
97 .transpose()?,
98 );
99 }
100 "CreationTime" => {
101 builder = builder.set_creation_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
102 tokens.next(),
103 ::aws_smithy_types::date_time::Format::EpochSeconds,
104 )?);
105 }
106 "FailureMessage" => {
107 builder = builder.set_failure_message(
108 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
109 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
110 .transpose()?,
111 );
112 }
113 "InstanceGroups" => {
114 builder = builder.set_instance_groups(
115 crate::protocol_serde::shape_cluster_instance_group_details_list::de_cluster_instance_group_details_list(tokens)?,
116 );
117 }
118 "RestrictedInstanceGroups" => {
119 builder = builder.set_restricted_instance_groups(
120 crate::protocol_serde::shape_cluster_restricted_instance_group_details_list::de_cluster_restricted_instance_group_details_list(tokens)?
121 );
122 }
123 "VpcConfig" => {
124 builder = builder.set_vpc_config(crate::protocol_serde::shape_vpc_config::de_vpc_config(tokens)?);
125 }
126 "Orchestrator" => {
127 builder = builder.set_orchestrator(crate::protocol_serde::shape_cluster_orchestrator::de_cluster_orchestrator(tokens)?);
128 }
129 "TieredStorageConfig" => {
130 builder = builder.set_tiered_storage_config(
131 crate::protocol_serde::shape_cluster_tiered_storage_config::de_cluster_tiered_storage_config(tokens)?,
132 );
133 }
134 "NodeRecovery" => {
135 builder = builder.set_node_recovery(
136 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
137 .map(|s| s.to_unescaped().map(|u| crate::types::ClusterNodeRecovery::from(u.as_ref())))
138 .transpose()?,
139 );
140 }
141 "NodeProvisioningMode" => {
142 builder = builder.set_node_provisioning_mode(
143 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
144 .map(|s| s.to_unescaped().map(|u| crate::types::ClusterNodeProvisioningMode::from(u.as_ref())))
145 .transpose()?,
146 );
147 }
148 "ClusterRole" => {
149 builder = builder.set_cluster_role(
150 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
151 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
152 .transpose()?,
153 );
154 }
155 "AutoScaling" => {
156 builder = builder.set_auto_scaling(
157 crate::protocol_serde::shape_cluster_auto_scaling_config_output::de_cluster_auto_scaling_config_output(tokens)?,
158 );
159 }
160 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
161 },
162 other => {
163 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
164 "expected object key or end object, found: {:?}",
165 other
166 )))
167 }
168 }
169 }
170 if tokens.next().is_some() {
171 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
172 "found more JSON tokens after completing parsing",
173 ));
174 }
175 Ok(builder)
176}