Skip to main content

aws_sdk_cloudhsmv2/protocol_serde/
shape_get_resource_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_resource_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_resource_policy::GetResourcePolicyOutput, crate::operation::get_resource_policy::GetResourcePolicyError>
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::get_resource_policy::GetResourcePolicyError::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::get_resource_policy::GetResourcePolicyError::unhandled(generic)),
17    };
18
19    let _error_message = generic.message().map(|msg| msg.to_owned());
20    Err(match error_code {
21        "CloudHsmAccessDeniedException" => crate::operation::get_resource_policy::GetResourcePolicyError::CloudHsmAccessDeniedException({
22            #[allow(unused_mut)]
23            let mut tmp = {
24                #[allow(unused_mut)]
25                let mut output = crate::types::error::builders::CloudHsmAccessDeniedExceptionBuilder::default();
26                output = crate::protocol_serde::shape_cloud_hsm_access_denied_exception::de_cloud_hsm_access_denied_exception_json_err(
27                    _response_body,
28                    output,
29                )
30                .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
31                let output = output.meta(generic);
32                output.build()
33            };
34            if tmp.message.is_none() {
35                tmp.message = _error_message;
36            }
37            tmp
38        }),
39        "CloudHsmInternalFailureException" => crate::operation::get_resource_policy::GetResourcePolicyError::CloudHsmInternalFailureException({
40            #[allow(unused_mut)]
41            let mut tmp = {
42                #[allow(unused_mut)]
43                let mut output = crate::types::error::builders::CloudHsmInternalFailureExceptionBuilder::default();
44                output = crate::protocol_serde::shape_cloud_hsm_internal_failure_exception::de_cloud_hsm_internal_failure_exception_json_err(
45                    _response_body,
46                    output,
47                )
48                .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
49                let output = output.meta(generic);
50                output.build()
51            };
52            if tmp.message.is_none() {
53                tmp.message = _error_message;
54            }
55            tmp
56        }),
57        "CloudHsmInvalidRequestException" => crate::operation::get_resource_policy::GetResourcePolicyError::CloudHsmInvalidRequestException({
58            #[allow(unused_mut)]
59            let mut tmp = {
60                #[allow(unused_mut)]
61                let mut output = crate::types::error::builders::CloudHsmInvalidRequestExceptionBuilder::default();
62                output = crate::protocol_serde::shape_cloud_hsm_invalid_request_exception::de_cloud_hsm_invalid_request_exception_json_err(
63                    _response_body,
64                    output,
65                )
66                .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
67                let output = output.meta(generic);
68                output.build()
69            };
70            if tmp.message.is_none() {
71                tmp.message = _error_message;
72            }
73            tmp
74        }),
75        "CloudHsmResourceNotFoundException" => crate::operation::get_resource_policy::GetResourcePolicyError::CloudHsmResourceNotFoundException({
76            #[allow(unused_mut)]
77            let mut tmp = {
78                #[allow(unused_mut)]
79                let mut output = crate::types::error::builders::CloudHsmResourceNotFoundExceptionBuilder::default();
80                output = crate::protocol_serde::shape_cloud_hsm_resource_not_found_exception::de_cloud_hsm_resource_not_found_exception_json_err(
81                    _response_body,
82                    output,
83                )
84                .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
85                let output = output.meta(generic);
86                output.build()
87            };
88            if tmp.message.is_none() {
89                tmp.message = _error_message;
90            }
91            tmp
92        }),
93        "CloudHsmServiceException" => crate::operation::get_resource_policy::GetResourcePolicyError::CloudHsmServiceException({
94            #[allow(unused_mut)]
95            let mut tmp = {
96                #[allow(unused_mut)]
97                let mut output = crate::types::error::builders::CloudHsmServiceExceptionBuilder::default();
98                output = crate::protocol_serde::shape_cloud_hsm_service_exception::de_cloud_hsm_service_exception_json_err(_response_body, output)
99                    .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
100                let output = output.meta(generic);
101                output.build()
102            };
103            if tmp.message.is_none() {
104                tmp.message = _error_message;
105            }
106            tmp
107        }),
108        _ => crate::operation::get_resource_policy::GetResourcePolicyError::generic(generic),
109    })
110}
111
112#[allow(clippy::unnecessary_wraps)]
113pub fn de_get_resource_policy_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_resource_policy::GetResourcePolicyOutput, crate::operation::get_resource_policy::GetResourcePolicyError>
118{
119    Ok({
120        #[allow(unused_mut)]
121        let mut output = crate::operation::get_resource_policy::builders::GetResourcePolicyOutputBuilder::default();
122        output = crate::protocol_serde::shape_get_resource_policy::de_get_resource_policy(_response_body, output)
123            .map_err(crate::operation::get_resource_policy::GetResourcePolicyError::unhandled)?;
124        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
125        output.build()
126    })
127}
128
129pub fn ser_get_resource_policy_input(
130    input: &crate::operation::get_resource_policy::GetResourcePolicyInput,
131) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
132    let mut out = String::new();
133    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
134    crate::protocol_serde::shape_get_resource_policy_input::ser_get_resource_policy_input_input(&mut object, input)?;
135    object.finish();
136    Ok(::aws_smithy_types::body::SdkBody::from(out))
137}
138
139pub(crate) fn de_get_resource_policy(
140    _value: &[u8],
141    mut builder: crate::operation::get_resource_policy::builders::GetResourcePolicyOutputBuilder,
142) -> ::std::result::Result<
143    crate::operation::get_resource_policy::builders::GetResourcePolicyOutputBuilder,
144    ::aws_smithy_json::deserialize::error::DeserializeError,
145> {
146    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(_value)).peekable();
147    let tokens = &mut tokens_owned;
148    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
149    loop {
150        match tokens.next().transpose()? {
151            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
152            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
153                "Policy" => {
154                    builder = builder.set_policy(
155                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
156                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
157                            .transpose()?,
158                    );
159                }
160                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
161            },
162            other => {
163                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
164                    "expected object key or end object, found: {other:?}"
165                )))
166            }
167        }
168    }
169    if tokens.next().is_some() {
170        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
171            "found more JSON tokens after completing parsing",
172        ));
173    }
174    Ok(builder)
175}