aws_sdk_imagebuilder/protocol_serde/
shape_get_image_policy.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_get_image_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::get_image_policy::GetImagePolicyOutput, crate::operation::get_image_policy::GetImagePolicyError> {
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_image_policy::GetImagePolicyError::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_image_policy::GetImagePolicyError::unhandled(generic)),
16    };
17
18    let _error_message = generic.message().map(|msg| msg.to_owned());
19    Err(match error_code {
20        "CallRateLimitExceededException" => crate::operation::get_image_policy::GetImagePolicyError::CallRateLimitExceededException({
21            #[allow(unused_mut)]
22            let mut tmp = {
23                #[allow(unused_mut)]
24                let mut output = crate::types::error::builders::CallRateLimitExceededExceptionBuilder::default();
25                output = crate::protocol_serde::shape_call_rate_limit_exceeded_exception::de_call_rate_limit_exceeded_exception_json_err(
26                    _response_body,
27                    output,
28                )
29                .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
30                let output = output.meta(generic);
31                output.build()
32            };
33            if tmp.message.is_none() {
34                tmp.message = _error_message;
35            }
36            tmp
37        }),
38        "ForbiddenException" => crate::operation::get_image_policy::GetImagePolicyError::ForbiddenException({
39            #[allow(unused_mut)]
40            let mut tmp = {
41                #[allow(unused_mut)]
42                let mut output = crate::types::error::builders::ForbiddenExceptionBuilder::default();
43                output = crate::protocol_serde::shape_forbidden_exception::de_forbidden_exception_json_err(_response_body, output)
44                    .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
45                let output = output.meta(generic);
46                output.build()
47            };
48            if tmp.message.is_none() {
49                tmp.message = _error_message;
50            }
51            tmp
52        }),
53        "InvalidRequestException" => crate::operation::get_image_policy::GetImagePolicyError::InvalidRequestException({
54            #[allow(unused_mut)]
55            let mut tmp = {
56                #[allow(unused_mut)]
57                let mut output = crate::types::error::builders::InvalidRequestExceptionBuilder::default();
58                output = crate::protocol_serde::shape_invalid_request_exception::de_invalid_request_exception_json_err(_response_body, output)
59                    .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
60                let output = output.meta(generic);
61                output.build()
62            };
63            if tmp.message.is_none() {
64                tmp.message = _error_message;
65            }
66            tmp
67        }),
68        "ResourceNotFoundException" => crate::operation::get_image_policy::GetImagePolicyError::ResourceNotFoundException({
69            #[allow(unused_mut)]
70            let mut tmp = {
71                #[allow(unused_mut)]
72                let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
73                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
74                    .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
75                let output = output.meta(generic);
76                output.build()
77            };
78            if tmp.message.is_none() {
79                tmp.message = _error_message;
80            }
81            tmp
82        }),
83        "ServiceException" => crate::operation::get_image_policy::GetImagePolicyError::ServiceException({
84            #[allow(unused_mut)]
85            let mut tmp = {
86                #[allow(unused_mut)]
87                let mut output = crate::types::error::builders::ServiceExceptionBuilder::default();
88                output = crate::protocol_serde::shape_service_exception::de_service_exception_json_err(_response_body, output)
89                    .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
90                let output = output.meta(generic);
91                output.build()
92            };
93            if tmp.message.is_none() {
94                tmp.message = _error_message;
95            }
96            tmp
97        }),
98        "ServiceUnavailableException" => crate::operation::get_image_policy::GetImagePolicyError::ServiceUnavailableException({
99            #[allow(unused_mut)]
100            let mut tmp = {
101                #[allow(unused_mut)]
102                let mut output = crate::types::error::builders::ServiceUnavailableExceptionBuilder::default();
103                output =
104                    crate::protocol_serde::shape_service_unavailable_exception::de_service_unavailable_exception_json_err(_response_body, output)
105                        .map_err(crate::operation::get_image_policy::GetImagePolicyError::unhandled)?;
106                let output = output.meta(generic);
107                output.build()
108            };
109            if tmp.message.is_none() {
110                tmp.message = _error_message;
111            }
112            tmp
113        }),
114        _ => crate::operation::get_image_policy::GetImagePolicyError::generic(generic),
115    })
116}
117
118#[allow(clippy::unnecessary_wraps)]
119pub fn de_get_image_policy_http_response(
120    _response_status: u16,
121    _response_headers: &::aws_smithy_runtime_api::http::Headers,
122    _response_body: &[u8],
123) -> std::result::Result<crate::operation::get_image_policy::GetImagePolicyOutput, crate::operation::get_image_policy::GetImagePolicyError> {
124    Ok({
125        #[allow(unused_mut)]
126        let mut output = crate::operation::get_image_policy::builders::GetImagePolicyOutputBuilder::default();
127        output = crate::protocol_serde::shape_get_image_policy::de_get_image_policy(_response_body, output)
128            .map_err(crate::operation::get_image_policy::GetImagePolicyError::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(crate) fn de_get_image_policy(
135    value: &[u8],
136    mut builder: crate::operation::get_image_policy::builders::GetImagePolicyOutputBuilder,
137) -> ::std::result::Result<
138    crate::operation::get_image_policy::builders::GetImagePolicyOutputBuilder,
139    ::aws_smithy_json::deserialize::error::DeserializeError,
140> {
141    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
142    let tokens = &mut tokens_owned;
143    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
144    loop {
145        match tokens.next().transpose()? {
146            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
147            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
148                "policy" => {
149                    builder = builder.set_policy(
150                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
151                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
152                            .transpose()?,
153                    );
154                }
155                "requestId" => {
156                    builder = builder.set_request_id(
157                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
158                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
159                            .transpose()?,
160                    );
161                }
162                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
163            },
164            other => {
165                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
166                    "expected object key or end object, found: {:?}",
167                    other
168                )))
169            }
170        }
171    }
172    if tokens.next().is_some() {
173        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
174            "found more JSON tokens after completing parsing",
175        ));
176    }
177    Ok(builder)
178}