aws_sdk_accessanalyzer/protocol_serde/
shape_check_no_new_access.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_check_no_new_access_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::check_no_new_access::CheckNoNewAccessOutput, crate::operation::check_no_new_access::CheckNoNewAccessError>
8{
9    #[allow(unused_mut)]
10    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
11        .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
12    generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
13    let generic = generic_builder.build();
14    let error_code = match generic.code() {
15        Some(code) => code,
16        None => return Err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled(generic)),
17    };
18
19    let _error_message = generic.message().map(|msg| msg.to_owned());
20    Err(match error_code {
21        "AccessDeniedException" => crate::operation::check_no_new_access::CheckNoNewAccessError::AccessDeniedException({
22            #[allow(unused_mut)]
23            let mut tmp = {
24                #[allow(unused_mut)]
25                let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
26                output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
27                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
28                let output = output.meta(generic);
29                crate::serde_util::access_denied_exception_correct_errors(output)
30                    .build()
31                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
32            };
33            tmp
34        }),
35        "InternalServerException" => crate::operation::check_no_new_access::CheckNoNewAccessError::InternalServerException({
36            #[allow(unused_mut)]
37            let mut tmp = {
38                #[allow(unused_mut)]
39                let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
40                output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
41                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
42                output = output.set_retry_after_seconds(
43                    crate::protocol_serde::shape_internal_server_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
44                        crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled(
45                            "Failed to parse retryAfterSeconds from header `Retry-After",
46                        )
47                    })?,
48                );
49                let output = output.meta(generic);
50                crate::serde_util::internal_server_exception_correct_errors(output)
51                    .build()
52                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
53            };
54            tmp
55        }),
56        "InvalidParameterException" => crate::operation::check_no_new_access::CheckNoNewAccessError::InvalidParameterException({
57            #[allow(unused_mut)]
58            let mut tmp = {
59                #[allow(unused_mut)]
60                let mut output = crate::types::error::builders::InvalidParameterExceptionBuilder::default();
61                output = crate::protocol_serde::shape_invalid_parameter_exception::de_invalid_parameter_exception_json_err(_response_body, output)
62                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
63                let output = output.meta(generic);
64                crate::serde_util::invalid_parameter_exception_correct_errors(output)
65                    .build()
66                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
67            };
68            tmp
69        }),
70        "ThrottlingException" => crate::operation::check_no_new_access::CheckNoNewAccessError::ThrottlingException({
71            #[allow(unused_mut)]
72            let mut tmp = {
73                #[allow(unused_mut)]
74                let mut output = crate::types::error::builders::ThrottlingExceptionBuilder::default();
75                output = crate::protocol_serde::shape_throttling_exception::de_throttling_exception_json_err(_response_body, output)
76                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
77                output = output.set_retry_after_seconds(
78                    crate::protocol_serde::shape_throttling_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
79                        crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled(
80                            "Failed to parse retryAfterSeconds from header `Retry-After",
81                        )
82                    })?,
83                );
84                let output = output.meta(generic);
85                crate::serde_util::throttling_exception_correct_errors(output)
86                    .build()
87                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
88            };
89            tmp
90        }),
91        "UnprocessableEntityException" => crate::operation::check_no_new_access::CheckNoNewAccessError::UnprocessableEntityException({
92            #[allow(unused_mut)]
93            let mut tmp = {
94                #[allow(unused_mut)]
95                let mut output = crate::types::error::builders::UnprocessableEntityExceptionBuilder::default();
96                output =
97                    crate::protocol_serde::shape_unprocessable_entity_exception::de_unprocessable_entity_exception_json_err(_response_body, output)
98                        .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
99                let output = output.meta(generic);
100                crate::serde_util::unprocessable_entity_exception_correct_errors(output)
101                    .build()
102                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
103            };
104            tmp
105        }),
106        "ValidationException" => crate::operation::check_no_new_access::CheckNoNewAccessError::ValidationException({
107            #[allow(unused_mut)]
108            let mut tmp = {
109                #[allow(unused_mut)]
110                let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
111                output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
112                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
113                let output = output.meta(generic);
114                crate::serde_util::validation_exception_correct_errors(output)
115                    .build()
116                    .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?
117            };
118            tmp
119        }),
120        _ => crate::operation::check_no_new_access::CheckNoNewAccessError::generic(generic),
121    })
122}
123
124#[allow(clippy::unnecessary_wraps)]
125pub fn de_check_no_new_access_http_response(
126    _response_status: u16,
127    _response_headers: &::aws_smithy_runtime_api::http::Headers,
128    _response_body: &[u8],
129) -> std::result::Result<crate::operation::check_no_new_access::CheckNoNewAccessOutput, crate::operation::check_no_new_access::CheckNoNewAccessError>
130{
131    Ok({
132        #[allow(unused_mut)]
133        let mut output = crate::operation::check_no_new_access::builders::CheckNoNewAccessOutputBuilder::default();
134        output = crate::protocol_serde::shape_check_no_new_access::de_check_no_new_access(_response_body, output)
135            .map_err(crate::operation::check_no_new_access::CheckNoNewAccessError::unhandled)?;
136        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
137        output.build()
138    })
139}
140
141pub fn ser_check_no_new_access_input(
142    input: &crate::operation::check_no_new_access::CheckNoNewAccessInput,
143) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
144    let mut out = String::new();
145    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
146    crate::protocol_serde::shape_check_no_new_access_input::ser_check_no_new_access_input_input(&mut object, input)?;
147    object.finish();
148    Ok(::aws_smithy_types::body::SdkBody::from(out))
149}
150
151pub(crate) fn de_check_no_new_access(
152    value: &[u8],
153    mut builder: crate::operation::check_no_new_access::builders::CheckNoNewAccessOutputBuilder,
154) -> ::std::result::Result<
155    crate::operation::check_no_new_access::builders::CheckNoNewAccessOutputBuilder,
156    ::aws_smithy_json::deserialize::error::DeserializeError,
157> {
158    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
159    let tokens = &mut tokens_owned;
160    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
161    loop {
162        match tokens.next().transpose()? {
163            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
164            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
165                "message" => {
166                    builder = builder.set_message(
167                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
168                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
169                            .transpose()?,
170                    );
171                }
172                "reasons" => {
173                    builder = builder.set_reasons(crate::protocol_serde::shape_reason_summary_list::de_reason_summary_list(tokens)?);
174                }
175                "result" => {
176                    builder = builder.set_result(
177                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
178                            .map(|s| s.to_unescaped().map(|u| crate::types::CheckNoNewAccessResult::from(u.as_ref())))
179                            .transpose()?,
180                    );
181                }
182                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
183            },
184            other => {
185                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
186                    "expected object key or end object, found: {:?}",
187                    other
188                )))
189            }
190        }
191    }
192    if tokens.next().is_some() {
193        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
194            "found more JSON tokens after completing parsing",
195        ));
196    }
197    Ok(builder)
198}