aws_sdk_codeartifact/protocol_serde/
shape_get_repository_permissions_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_repository_permissions_policy_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_repository_permissions_policy::GetRepositoryPermissionsPolicyOutput,
9    crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError,
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_repository_permissions_policy::GetRepositoryPermissionsPolicyError::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 => return Err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled(generic)),
19    };
20
21    let _error_message = generic.message().map(|msg| msg.to_owned());
22    Err(match error_code {
23        "AccessDeniedException" => crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::AccessDeniedException({
24            #[allow(unused_mut)]
25            let mut tmp = {
26                #[allow(unused_mut)]
27                let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
28                output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
29                    .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?;
30                let output = output.meta(generic);
31                crate::serde_util::access_denied_exception_correct_errors(output)
32                    .build()
33                    .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?
34            };
35            tmp
36        }),
37        "InternalServerException" => {
38            crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::InternalServerException({
39                #[allow(unused_mut)]
40                let mut tmp = {
41                    #[allow(unused_mut)]
42                    let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
43                    output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
44                        .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?;
45                    let output = output.meta(generic);
46                    crate::serde_util::internal_server_exception_correct_errors(output)
47                        .build()
48                        .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?
49                };
50                tmp
51            })
52        }
53        "ResourceNotFoundException" => {
54            crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::ResourceNotFoundException({
55                #[allow(unused_mut)]
56                let mut tmp = {
57                    #[allow(unused_mut)]
58                    let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
59                    output =
60                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
61                            .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?;
62                    let output = output.meta(generic);
63                    crate::serde_util::resource_not_found_exception_correct_errors(output)
64                        .build()
65                        .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?
66                };
67                tmp
68            })
69        }
70        "ThrottlingException" => crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::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::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::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::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::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::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?
88            };
89            tmp
90        }),
91        "ValidationException" => crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::ValidationException({
92            #[allow(unused_mut)]
93            let mut tmp = {
94                #[allow(unused_mut)]
95                let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
96                output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
97                    .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?;
98                let output = output.meta(generic);
99                crate::serde_util::validation_exception_correct_errors(output)
100                    .build()
101                    .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?
102            };
103            tmp
104        }),
105        _ => crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::generic(generic),
106    })
107}
108
109#[allow(clippy::unnecessary_wraps)]
110pub fn de_get_repository_permissions_policy_http_response(
111    _response_status: u16,
112    _response_headers: &::aws_smithy_runtime_api::http::Headers,
113    _response_body: &[u8],
114) -> std::result::Result<
115    crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyOutput,
116    crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError,
117> {
118    Ok({
119        #[allow(unused_mut)]
120        let mut output = crate::operation::get_repository_permissions_policy::builders::GetRepositoryPermissionsPolicyOutputBuilder::default();
121        output = crate::protocol_serde::shape_get_repository_permissions_policy::de_get_repository_permissions_policy(_response_body, output)
122            .map_err(crate::operation::get_repository_permissions_policy::GetRepositoryPermissionsPolicyError::unhandled)?;
123        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
124        output.build()
125    })
126}
127
128pub(crate) fn de_get_repository_permissions_policy(
129    value: &[u8],
130    mut builder: crate::operation::get_repository_permissions_policy::builders::GetRepositoryPermissionsPolicyOutputBuilder,
131) -> ::std::result::Result<
132    crate::operation::get_repository_permissions_policy::builders::GetRepositoryPermissionsPolicyOutputBuilder,
133    ::aws_smithy_json::deserialize::error::DeserializeError,
134> {
135    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
136    let tokens = &mut tokens_owned;
137    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
138    loop {
139        match tokens.next().transpose()? {
140            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
141            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
142                "policy" => {
143                    builder = builder.set_policy(crate::protocol_serde::shape_resource_policy::de_resource_policy(tokens)?);
144                }
145                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
146            },
147            other => {
148                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
149                    "expected object key or end object, found: {:?}",
150                    other
151                )))
152            }
153        }
154    }
155    if tokens.next().is_some() {
156        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
157            "found more JSON tokens after completing parsing",
158        ));
159    }
160    Ok(builder)
161}