aws_sdk_ram/protocol_serde/
shape_get_permission.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_get_permission_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::get_permission::GetPermissionOutput, crate::operation::get_permission::GetPermissionError> {
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::get_permission::GetPermissionError::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::get_permission::GetPermissionError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "InvalidParameterException" => crate::operation::get_permission::GetPermissionError::InvalidParameterException({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::InvalidParameterExceptionBuilder::default();
25 output = crate::protocol_serde::shape_invalid_parameter_exception::de_invalid_parameter_exception_json_err(_response_body, output)
26 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
27 let output = output.meta(generic);
28 crate::serde_util::invalid_parameter_exception_correct_errors(output)
29 .build()
30 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
31 };
32 tmp
33 }),
34 "MalformedArnException" => crate::operation::get_permission::GetPermissionError::MalformedArnException({
35 #[allow(unused_mut)]
36 let mut tmp = {
37 #[allow(unused_mut)]
38 let mut output = crate::types::error::builders::MalformedArnExceptionBuilder::default();
39 output = crate::protocol_serde::shape_malformed_arn_exception::de_malformed_arn_exception_json_err(_response_body, output)
40 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
41 let output = output.meta(generic);
42 crate::serde_util::malformed_arn_exception_correct_errors(output)
43 .build()
44 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
45 };
46 tmp
47 }),
48 "OperationNotPermittedException" => crate::operation::get_permission::GetPermissionError::OperationNotPermittedException({
49 #[allow(unused_mut)]
50 let mut tmp = {
51 #[allow(unused_mut)]
52 let mut output = crate::types::error::builders::OperationNotPermittedExceptionBuilder::default();
53 output = crate::protocol_serde::shape_operation_not_permitted_exception::de_operation_not_permitted_exception_json_err(
54 _response_body,
55 output,
56 )
57 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
58 let output = output.meta(generic);
59 crate::serde_util::operation_not_permitted_exception_correct_errors(output)
60 .build()
61 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
62 };
63 tmp
64 }),
65 "ServerInternalException" => crate::operation::get_permission::GetPermissionError::ServerInternalException({
66 #[allow(unused_mut)]
67 let mut tmp = {
68 #[allow(unused_mut)]
69 let mut output = crate::types::error::builders::ServerInternalExceptionBuilder::default();
70 output = crate::protocol_serde::shape_server_internal_exception::de_server_internal_exception_json_err(_response_body, output)
71 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
72 let output = output.meta(generic);
73 crate::serde_util::server_internal_exception_correct_errors(output)
74 .build()
75 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
76 };
77 tmp
78 }),
79 "ServiceUnavailableException" => crate::operation::get_permission::GetPermissionError::ServiceUnavailableException({
80 #[allow(unused_mut)]
81 let mut tmp = {
82 #[allow(unused_mut)]
83 let mut output = crate::types::error::builders::ServiceUnavailableExceptionBuilder::default();
84 output =
85 crate::protocol_serde::shape_service_unavailable_exception::de_service_unavailable_exception_json_err(_response_body, output)
86 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
87 let output = output.meta(generic);
88 crate::serde_util::service_unavailable_exception_correct_errors(output)
89 .build()
90 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
91 };
92 tmp
93 }),
94 "UnknownResourceException" => crate::operation::get_permission::GetPermissionError::UnknownResourceException({
95 #[allow(unused_mut)]
96 let mut tmp = {
97 #[allow(unused_mut)]
98 let mut output = crate::types::error::builders::UnknownResourceExceptionBuilder::default();
99 output = crate::protocol_serde::shape_unknown_resource_exception::de_unknown_resource_exception_json_err(_response_body, output)
100 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
101 let output = output.meta(generic);
102 crate::serde_util::unknown_resource_exception_correct_errors(output)
103 .build()
104 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?
105 };
106 tmp
107 }),
108 _ => crate::operation::get_permission::GetPermissionError::generic(generic),
109 })
110}
111
112#[allow(clippy::unnecessary_wraps)]
113pub fn de_get_permission_http_response(
114 _response_status: u16,
115 _response_headers: &::aws_smithy_runtime_api::http::Headers,
116 _response_body: &[u8],
117) -> std::result::Result<crate::operation::get_permission::GetPermissionOutput, crate::operation::get_permission::GetPermissionError> {
118 Ok({
119 #[allow(unused_mut)]
120 let mut output = crate::operation::get_permission::builders::GetPermissionOutputBuilder::default();
121 output = crate::protocol_serde::shape_get_permission::de_get_permission(_response_body, output)
122 .map_err(crate::operation::get_permission::GetPermissionError::unhandled)?;
123 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
124 output.build()
125 })
126}
127
128pub fn ser_get_permission_input(
129 input: &crate::operation::get_permission::GetPermissionInput,
130) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
131 let mut out = String::new();
132 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
133 crate::protocol_serde::shape_get_permission_input::ser_get_permission_input_input(&mut object, input)?;
134 object.finish();
135 Ok(::aws_smithy_types::body::SdkBody::from(out))
136}
137
138pub(crate) fn de_get_permission(
139 value: &[u8],
140 mut builder: crate::operation::get_permission::builders::GetPermissionOutputBuilder,
141) -> ::std::result::Result<
142 crate::operation::get_permission::builders::GetPermissionOutputBuilder,
143 ::aws_smithy_json::deserialize::error::DeserializeError,
144> {
145 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
146 let tokens = &mut tokens_owned;
147 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
148 loop {
149 match tokens.next().transpose()? {
150 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
151 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
152 "permission" => {
153 builder = builder
154 .set_permission(crate::protocol_serde::shape_resource_share_permission_detail::de_resource_share_permission_detail(tokens)?);
155 }
156 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
157 },
158 other => {
159 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
160 "expected object key or end object, found: {:?}",
161 other
162 )))
163 }
164 }
165 }
166 if tokens.next().is_some() {
167 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
168 "found more JSON tokens after completing parsing",
169 ));
170 }
171 Ok(builder)
172}