aws_sdk_codeartifact/protocol_serde/
shape_delete_repository.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_delete_repository_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::delete_repository::DeleteRepositoryOutput, crate::operation::delete_repository::DeleteRepositoryError> {
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::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::unhandled(generic)),
16    };
17
18    let _error_message = generic.message().map(|msg| msg.to_owned());
19    Err(match error_code {
20        "AccessDeniedException" => crate::operation::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::unhandled)?;
27                let output = output.meta(generic);
28                crate::serde_util::access_denied_exception_correct_errors(output)
29                    .build()
30                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?
31            };
32            tmp
33        }),
34        "ConflictException" => crate::operation::delete_repository::DeleteRepositoryError::ConflictException({
35            #[allow(unused_mut)]
36            let mut tmp = {
37                #[allow(unused_mut)]
38                let mut output = crate::types::error::builders::ConflictExceptionBuilder::default();
39                output = crate::protocol_serde::shape_conflict_exception::de_conflict_exception_json_err(_response_body, output)
40                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?;
41                let output = output.meta(generic);
42                crate::serde_util::conflict_exception_correct_errors(output)
43                    .build()
44                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?
45            };
46            tmp
47        }),
48        "InternalServerException" => crate::operation::delete_repository::DeleteRepositoryError::InternalServerException({
49            #[allow(unused_mut)]
50            let mut tmp = {
51                #[allow(unused_mut)]
52                let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
53                output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
54                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?;
55                let output = output.meta(generic);
56                crate::serde_util::internal_server_exception_correct_errors(output)
57                    .build()
58                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?
59            };
60            tmp
61        }),
62        "ResourceNotFoundException" => crate::operation::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::unhandled)?
73            };
74            tmp
75        }),
76        "ThrottlingException" => crate::operation::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::unhandled)?
94            };
95            tmp
96        }),
97        "ValidationException" => crate::operation::delete_repository::DeleteRepositoryError::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::delete_repository::DeleteRepositoryError::unhandled)?;
104                let output = output.meta(generic);
105                crate::serde_util::validation_exception_correct_errors(output)
106                    .build()
107                    .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?
108            };
109            tmp
110        }),
111        _ => crate::operation::delete_repository::DeleteRepositoryError::generic(generic),
112    })
113}
114
115#[allow(clippy::unnecessary_wraps)]
116pub fn de_delete_repository_http_response(
117    _response_status: u16,
118    _response_headers: &::aws_smithy_runtime_api::http::Headers,
119    _response_body: &[u8],
120) -> std::result::Result<crate::operation::delete_repository::DeleteRepositoryOutput, crate::operation::delete_repository::DeleteRepositoryError> {
121    Ok({
122        #[allow(unused_mut)]
123        let mut output = crate::operation::delete_repository::builders::DeleteRepositoryOutputBuilder::default();
124        output = crate::protocol_serde::shape_delete_repository::de_delete_repository(_response_body, output)
125            .map_err(crate::operation::delete_repository::DeleteRepositoryError::unhandled)?;
126        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
127        output.build()
128    })
129}
130
131pub(crate) fn de_delete_repository(
132    value: &[u8],
133    mut builder: crate::operation::delete_repository::builders::DeleteRepositoryOutputBuilder,
134) -> ::std::result::Result<
135    crate::operation::delete_repository::builders::DeleteRepositoryOutputBuilder,
136    ::aws_smithy_json::deserialize::error::DeserializeError,
137> {
138    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
139    let tokens = &mut tokens_owned;
140    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
141    loop {
142        match tokens.next().transpose()? {
143            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
144            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
145                "repository" => {
146                    builder = builder.set_repository(crate::protocol_serde::shape_repository_description::de_repository_description(tokens)?);
147                }
148                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
149            },
150            other => {
151                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
152                    "expected object key or end object, found: {:?}",
153                    other
154                )))
155            }
156        }
157    }
158    if tokens.next().is_some() {
159        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
160            "found more JSON tokens after completing parsing",
161        ));
162    }
163    Ok(builder)
164}