aws_sdk_inspector2/protocol_serde/
shape_get_findings_report_status.rs

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