aws_sdk_appstream/protocol_serde/
shape_create_directory_config.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_create_directory_config_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::create_directory_config::CreateDirectoryConfigOutput,
9 crate::operation::create_directory_config::CreateDirectoryConfigError,
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::create_directory_config::CreateDirectoryConfigError::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::create_directory_config::CreateDirectoryConfigError::unhandled(generic)),
19 };
20
21 let _error_message = generic.message().map(|msg| msg.to_owned());
22 Err(match error_code {
23 "InvalidAccountStatusException" => crate::operation::create_directory_config::CreateDirectoryConfigError::InvalidAccountStatusException({
24 #[allow(unused_mut)]
25 let mut tmp = {
26 #[allow(unused_mut)]
27 let mut output = crate::types::error::builders::InvalidAccountStatusExceptionBuilder::default();
28 output = crate::protocol_serde::shape_invalid_account_status_exception::de_invalid_account_status_exception_json_err(
29 _response_body,
30 output,
31 )
32 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
33 let output = output.meta(generic);
34 output.build()
35 };
36 if tmp.message.is_none() {
37 tmp.message = _error_message;
38 }
39 tmp
40 }),
41 "InvalidRoleException" => crate::operation::create_directory_config::CreateDirectoryConfigError::InvalidRoleException({
42 #[allow(unused_mut)]
43 let mut tmp = {
44 #[allow(unused_mut)]
45 let mut output = crate::types::error::builders::InvalidRoleExceptionBuilder::default();
46 output = crate::protocol_serde::shape_invalid_role_exception::de_invalid_role_exception_json_err(_response_body, output)
47 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
48 let output = output.meta(generic);
49 output.build()
50 };
51 if tmp.message.is_none() {
52 tmp.message = _error_message;
53 }
54 tmp
55 }),
56 "LimitExceededException" => crate::operation::create_directory_config::CreateDirectoryConfigError::LimitExceededException({
57 #[allow(unused_mut)]
58 let mut tmp = {
59 #[allow(unused_mut)]
60 let mut output = crate::types::error::builders::LimitExceededExceptionBuilder::default();
61 output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
62 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::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 "OperationNotPermittedException" => crate::operation::create_directory_config::CreateDirectoryConfigError::OperationNotPermittedException({
72 #[allow(unused_mut)]
73 let mut tmp = {
74 #[allow(unused_mut)]
75 let mut output = crate::types::error::builders::OperationNotPermittedExceptionBuilder::default();
76 output = crate::protocol_serde::shape_operation_not_permitted_exception::de_operation_not_permitted_exception_json_err(
77 _response_body,
78 output,
79 )
80 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
81 let output = output.meta(generic);
82 output.build()
83 };
84 if tmp.message.is_none() {
85 tmp.message = _error_message;
86 }
87 tmp
88 }),
89 "ResourceAlreadyExistsException" => crate::operation::create_directory_config::CreateDirectoryConfigError::ResourceAlreadyExistsException({
90 #[allow(unused_mut)]
91 let mut tmp = {
92 #[allow(unused_mut)]
93 let mut output = crate::types::error::builders::ResourceAlreadyExistsExceptionBuilder::default();
94 output = crate::protocol_serde::shape_resource_already_exists_exception::de_resource_already_exists_exception_json_err(
95 _response_body,
96 output,
97 )
98 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
99 let output = output.meta(generic);
100 output.build()
101 };
102 if tmp.message.is_none() {
103 tmp.message = _error_message;
104 }
105 tmp
106 }),
107 "ResourceNotFoundException" => crate::operation::create_directory_config::CreateDirectoryConfigError::ResourceNotFoundException({
108 #[allow(unused_mut)]
109 let mut tmp = {
110 #[allow(unused_mut)]
111 let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
112 output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
113 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
114 let output = output.meta(generic);
115 output.build()
116 };
117 if tmp.message.is_none() {
118 tmp.message = _error_message;
119 }
120 tmp
121 }),
122 _ => crate::operation::create_directory_config::CreateDirectoryConfigError::generic(generic),
123 })
124}
125
126#[allow(clippy::unnecessary_wraps)]
127pub fn de_create_directory_config_http_response(
128 _response_status: u16,
129 _response_headers: &::aws_smithy_runtime_api::http::Headers,
130 _response_body: &[u8],
131) -> std::result::Result<
132 crate::operation::create_directory_config::CreateDirectoryConfigOutput,
133 crate::operation::create_directory_config::CreateDirectoryConfigError,
134> {
135 Ok({
136 #[allow(unused_mut)]
137 let mut output = crate::operation::create_directory_config::builders::CreateDirectoryConfigOutputBuilder::default();
138 output = crate::protocol_serde::shape_create_directory_config::de_create_directory_config(_response_body, output)
139 .map_err(crate::operation::create_directory_config::CreateDirectoryConfigError::unhandled)?;
140 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
141 output.build()
142 })
143}
144
145pub fn ser_create_directory_config_input(
146 input: &crate::operation::create_directory_config::CreateDirectoryConfigInput,
147) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
148 let mut out = String::new();
149 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
150 crate::protocol_serde::shape_create_directory_config_input::ser_create_directory_config_input_input(&mut object, input)?;
151 object.finish();
152 Ok(::aws_smithy_types::body::SdkBody::from(out))
153}
154
155pub(crate) fn de_create_directory_config(
156 value: &[u8],
157 mut builder: crate::operation::create_directory_config::builders::CreateDirectoryConfigOutputBuilder,
158) -> ::std::result::Result<
159 crate::operation::create_directory_config::builders::CreateDirectoryConfigOutputBuilder,
160 ::aws_smithy_json::deserialize::error::DeserializeError,
161> {
162 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
163 let tokens = &mut tokens_owned;
164 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
165 loop {
166 match tokens.next().transpose()? {
167 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
168 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
169 "DirectoryConfig" => {
170 builder = builder.set_directory_config(crate::protocol_serde::shape_directory_config::de_directory_config(tokens)?);
171 }
172 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
173 },
174 other => {
175 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
176 "expected object key or end object, found: {:?}",
177 other
178 )))
179 }
180 }
181 }
182 if tokens.next().is_some() {
183 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
184 "found more JSON tokens after completing parsing",
185 ));
186 }
187 Ok(builder)
188}