aws_sdk_workspaces/protocol_serde/
shape_modify_account.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_modify_account_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::modify_account::ModifyAccountOutput, crate::operation::modify_account::ModifyAccountError> {
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::modify_account::ModifyAccountError::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::modify_account::ModifyAccountError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "AccessDeniedException" => crate::operation::modify_account::ModifyAccountError::AccessDeniedException({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
25 output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
26 .map_err(crate::operation::modify_account::ModifyAccountError::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 "InvalidParameterValuesException" => crate::operation::modify_account::ModifyAccountError::InvalidParameterValuesException({
36 #[allow(unused_mut)]
37 let mut tmp = {
38 #[allow(unused_mut)]
39 let mut output = crate::types::error::builders::InvalidParameterValuesExceptionBuilder::default();
40 output = crate::protocol_serde::shape_invalid_parameter_values_exception::de_invalid_parameter_values_exception_json_err(
41 _response_body,
42 output,
43 )
44 .map_err(crate::operation::modify_account::ModifyAccountError::unhandled)?;
45 let output = output.meta(generic);
46 output.build()
47 };
48 if tmp.message.is_none() {
49 tmp.message = _error_message;
50 }
51 tmp
52 }),
53 "InvalidResourceStateException" => crate::operation::modify_account::ModifyAccountError::InvalidResourceStateException({
54 #[allow(unused_mut)]
55 let mut tmp = {
56 #[allow(unused_mut)]
57 let mut output = crate::types::error::builders::InvalidResourceStateExceptionBuilder::default();
58 output = crate::protocol_serde::shape_invalid_resource_state_exception::de_invalid_resource_state_exception_json_err(
59 _response_body,
60 output,
61 )
62 .map_err(crate::operation::modify_account::ModifyAccountError::unhandled)?;
63 let output = output.meta(generic);
64 output.build()
65 };
66 if tmp.message.is_none() {
67 tmp.message = _error_message;
68 }
69 tmp
70 }),
71 "ResourceNotFoundException" => crate::operation::modify_account::ModifyAccountError::ResourceNotFoundException({
72 #[allow(unused_mut)]
73 let mut tmp = {
74 #[allow(unused_mut)]
75 let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
76 output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
77 .map_err(crate::operation::modify_account::ModifyAccountError::unhandled)?;
78 let output = output.meta(generic);
79 output.build()
80 };
81 if tmp.message.is_none() {
82 tmp.message = _error_message;
83 }
84 tmp
85 }),
86 "ResourceUnavailableException" => crate::operation::modify_account::ModifyAccountError::ResourceUnavailableException({
87 #[allow(unused_mut)]
88 let mut tmp = {
89 #[allow(unused_mut)]
90 let mut output = crate::types::error::builders::ResourceUnavailableExceptionBuilder::default();
91 output =
92 crate::protocol_serde::shape_resource_unavailable_exception::de_resource_unavailable_exception_json_err(_response_body, output)
93 .map_err(crate::operation::modify_account::ModifyAccountError::unhandled)?;
94 let output = output.meta(generic);
95 output.build()
96 };
97 if tmp.message.is_none() {
98 tmp.message = _error_message;
99 }
100 tmp
101 }),
102 _ => crate::operation::modify_account::ModifyAccountError::generic(generic),
103 })
104}
105
106#[allow(clippy::unnecessary_wraps)]
107pub fn de_modify_account_http_response(
108 _response_status: u16,
109 _response_headers: &::aws_smithy_runtime_api::http::Headers,
110 _response_body: &[u8],
111) -> std::result::Result<crate::operation::modify_account::ModifyAccountOutput, crate::operation::modify_account::ModifyAccountError> {
112 Ok({
113 #[allow(unused_mut)]
114 let mut output = crate::operation::modify_account::builders::ModifyAccountOutputBuilder::default();
115 output = crate::protocol_serde::shape_modify_account::de_modify_account(_response_body, output)
116 .map_err(crate::operation::modify_account::ModifyAccountError::unhandled)?;
117 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
118 output.build()
119 })
120}
121
122pub fn ser_modify_account_input(
123 input: &crate::operation::modify_account::ModifyAccountInput,
124) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
125 let mut out = String::new();
126 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
127 crate::protocol_serde::shape_modify_account_input::ser_modify_account_input_input(&mut object, input)?;
128 object.finish();
129 Ok(::aws_smithy_types::body::SdkBody::from(out))
130}
131
132pub(crate) fn de_modify_account(
133 _value: &[u8],
134 mut builder: crate::operation::modify_account::builders::ModifyAccountOutputBuilder,
135) -> ::std::result::Result<
136 crate::operation::modify_account::builders::ModifyAccountOutputBuilder,
137 ::aws_smithy_json::deserialize::error::DeserializeError,
138> {
139 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(_value)).peekable();
140 let tokens = &mut tokens_owned;
141 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
142 loop {
143 match tokens.next().transpose()? {
144 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
145 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
146 "Message" => {
147 builder = builder.set_message(
148 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
149 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
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: {other:?}"
158 )))
159 }
160 }
161 }
162 if tokens.next().is_some() {
163 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
164 "found more JSON tokens after completing parsing",
165 ));
166 }
167 Ok(builder)
168}