aws_sdk_accessanalyzer/protocol_serde/
shape_validate_policy.rs1#[allow(clippy::unnecessary_wraps)]
3pub fn de_validate_policy_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::validate_policy::ValidatePolicyOutput, crate::operation::validate_policy::ValidatePolicyError> {
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::validate_policy::ValidatePolicyError::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::validate_policy::ValidatePolicyError::unhandled(generic)),
16 };
17
18 let _error_message = generic.message().map(|msg| msg.to_owned());
19 Err(match error_code {
20 "AccessDeniedException" => crate::operation::validate_policy::ValidatePolicyError::AccessDeniedException({
21 #[allow(unused_mut)]
22 let mut tmp = {
23 #[allow(unused_mut)]
24 let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
25 output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
26 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?;
27 let output = output.meta(generic);
28 crate::serde_util::access_denied_exception_correct_errors(output)
29 .build()
30 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?
31 };
32 tmp
33 }),
34 "InternalServerException" => crate::operation::validate_policy::ValidatePolicyError::InternalServerException({
35 #[allow(unused_mut)]
36 let mut tmp = {
37 #[allow(unused_mut)]
38 let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
39 output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
40 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?;
41 output = output.set_retry_after_seconds(
42 crate::protocol_serde::shape_internal_server_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
43 crate::operation::validate_policy::ValidatePolicyError::unhandled(
44 "Failed to parse retryAfterSeconds from header `Retry-After",
45 )
46 })?,
47 );
48 let output = output.meta(generic);
49 crate::serde_util::internal_server_exception_correct_errors(output)
50 .build()
51 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?
52 };
53 tmp
54 }),
55 "ThrottlingException" => crate::operation::validate_policy::ValidatePolicyError::ThrottlingException({
56 #[allow(unused_mut)]
57 let mut tmp = {
58 #[allow(unused_mut)]
59 let mut output = crate::types::error::builders::ThrottlingExceptionBuilder::default();
60 output = crate::protocol_serde::shape_throttling_exception::de_throttling_exception_json_err(_response_body, output)
61 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?;
62 output = output.set_retry_after_seconds(
63 crate::protocol_serde::shape_throttling_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
64 crate::operation::validate_policy::ValidatePolicyError::unhandled(
65 "Failed to parse retryAfterSeconds from header `Retry-After",
66 )
67 })?,
68 );
69 let output = output.meta(generic);
70 crate::serde_util::throttling_exception_correct_errors(output)
71 .build()
72 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?
73 };
74 tmp
75 }),
76 "ValidationException" => crate::operation::validate_policy::ValidatePolicyError::ValidationException({
77 #[allow(unused_mut)]
78 let mut tmp = {
79 #[allow(unused_mut)]
80 let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
81 output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
82 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?;
83 let output = output.meta(generic);
84 crate::serde_util::validation_exception_correct_errors(output)
85 .build()
86 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?
87 };
88 tmp
89 }),
90 _ => crate::operation::validate_policy::ValidatePolicyError::generic(generic),
91 })
92}
93
94#[allow(clippy::unnecessary_wraps)]
95pub fn de_validate_policy_http_response(
96 _response_status: u16,
97 _response_headers: &::aws_smithy_runtime_api::http::Headers,
98 _response_body: &[u8],
99) -> std::result::Result<crate::operation::validate_policy::ValidatePolicyOutput, crate::operation::validate_policy::ValidatePolicyError> {
100 Ok({
101 #[allow(unused_mut)]
102 let mut output = crate::operation::validate_policy::builders::ValidatePolicyOutputBuilder::default();
103 output = crate::protocol_serde::shape_validate_policy::de_validate_policy(_response_body, output)
104 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?;
105 output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
106 crate::serde_util::validate_policy_output_output_correct_errors(output)
107 .build()
108 .map_err(crate::operation::validate_policy::ValidatePolicyError::unhandled)?
109 })
110}
111
112pub fn ser_validate_policy_input(
113 input: &crate::operation::validate_policy::ValidatePolicyInput,
114) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
115 let mut out = String::new();
116 let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
117 crate::protocol_serde::shape_validate_policy_input::ser_validate_policy_input_input(&mut object, input)?;
118 object.finish();
119 Ok(::aws_smithy_types::body::SdkBody::from(out))
120}
121
122pub(crate) fn de_validate_policy(
123 value: &[u8],
124 mut builder: crate::operation::validate_policy::builders::ValidatePolicyOutputBuilder,
125) -> ::std::result::Result<
126 crate::operation::validate_policy::builders::ValidatePolicyOutputBuilder,
127 ::aws_smithy_json::deserialize::error::DeserializeError,
128> {
129 let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
130 let tokens = &mut tokens_owned;
131 ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
132 loop {
133 match tokens.next().transpose()? {
134 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
135 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
136 "findings" => {
137 builder =
138 builder.set_findings(crate::protocol_serde::shape_validate_policy_finding_list::de_validate_policy_finding_list(tokens)?);
139 }
140 "nextToken" => {
141 builder = builder.set_next_token(
142 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
143 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
144 .transpose()?,
145 );
146 }
147 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
148 },
149 other => {
150 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
151 "expected object key or end object, found: {:?}",
152 other
153 )))
154 }
155 }
156 }
157 if tokens.next().is_some() {
158 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
159 "found more JSON tokens after completing parsing",
160 ));
161 }
162 Ok(builder)
163}