aws_sdk_ram/protocol_serde/
shape_get_permission.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[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}