aws_sdk_appstream/protocol_serde/
shape_batch_disassociate_user_stack.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_batch_disassociate_user_stack_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::batch_disassociate_user_stack::BatchDisassociateUserStackOutput,
9 crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError,
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::batch_disassociate_user_stack::BatchDisassociateUserStackError::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::batch_disassociate_user_stack::BatchDisassociateUserStackError::unhandled(generic)),
19 };
20
21 let _error_message = generic.message().map(|msg| msg.to_owned());
22 Err(match error_code {
23 "InvalidParameterCombinationException" => {
24 crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::InvalidParameterCombinationException({
25 #[allow(unused_mut)]
26 let mut tmp = {
27 #[allow(unused_mut)]
28 let mut output = crate::types::error::builders::InvalidParameterCombinationExceptionBuilder::default();
29 output =
30 crate::protocol_serde::shape_invalid_parameter_combination_exception::de_invalid_parameter_combination_exception_json_err(
31 _response_body,
32 output,
33 )
34 .map_err(crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::unhandled)?;
35 let output = output.meta(generic);
36 output.build()
37 };
38 if tmp.message.is_none() {
39 tmp.message = _error_message;
40 }
41 tmp
42 })
43 }
44 "OperationNotPermittedException" => {
45 crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::OperationNotPermittedException({
46 #[allow(unused_mut)]
47 let mut tmp = {
48 #[allow(unused_mut)]
49 let mut output = crate::types::error::builders::OperationNotPermittedExceptionBuilder::default();
50 output = crate::protocol_serde::shape_operation_not_permitted_exception::de_operation_not_permitted_exception_json_err(
51 _response_body,
52 output,
53 )
54 .map_err(crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::unhandled)?;
55 let output = output.meta(generic);
56 output.build()
57 };
58 if tmp.message.is_none() {
59 tmp.message = _error_message;
60 }
61 tmp
62 })
63 }
64 _ => crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::generic(generic),
65 })
66}
67
68#[allow(clippy::unnecessary_wraps)]
69pub fn de_batch_disassociate_user_stack_http_response(
70 _response_status: u16,
71 _response_headers: &::aws_smithy_runtime_api::http::Headers,
72 _response_body: &[u8],
73) -> std::result::Result<
74 crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackOutput,
75 crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError,
76> {
77 Ok({
78 #[allow(unused_mut)]
79 let mut output = crate::operation::batch_disassociate_user_stack::builders::BatchDisassociateUserStackOutputBuilder::default();
80 output = crate::protocol_serde::shape_batch_disassociate_user_stack::de_batch_disassociate_user_stack(_response_body, output)
81 .map_err(crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackError::unhandled)?;
82 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
83 output.build()
84 })
85}
86
87pub fn ser_batch_disassociate_user_stack_input(
88 input: &crate::operation::batch_disassociate_user_stack::BatchDisassociateUserStackInput,
89) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
90 let mut out = String::new();
91 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
92 crate::protocol_serde::shape_batch_disassociate_user_stack_input::ser_batch_disassociate_user_stack_input_input(&mut object, input)?;
93 object.finish();
94 Ok(::aws_smithy_types::body::SdkBody::from(out))
95}
96
97pub(crate) fn de_batch_disassociate_user_stack(
98 value: &[u8],
99 mut builder: crate::operation::batch_disassociate_user_stack::builders::BatchDisassociateUserStackOutputBuilder,
100) -> ::std::result::Result<
101 crate::operation::batch_disassociate_user_stack::builders::BatchDisassociateUserStackOutputBuilder,
102 ::aws_smithy_json::deserialize::error::DeserializeError,
103> {
104 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
105 let tokens = &mut tokens_owned;
106 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
107 loop {
108 match tokens.next().transpose()? {
109 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
110 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
111 "errors" => {
112 builder = builder
113 .set_errors(crate::protocol_serde::shape_user_stack_association_error_list::de_user_stack_association_error_list(tokens)?);
114 }
115 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
116 },
117 other => {
118 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
119 "expected object key or end object, found: {:?}",
120 other
121 )))
122 }
123 }
124 }
125 if tokens.next().is_some() {
126 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
127 "found more JSON tokens after completing parsing",
128 ));
129 }
130 Ok(builder)
131}