aws_sdk_elasticsearch/protocol_serde/
shape_delete_elasticsearch_domain.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_delete_elasticsearch_domain_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::delete_elasticsearch_domain::DeleteElasticsearchDomainOutput,
9    crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError,
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::delete_elasticsearch_domain::DeleteElasticsearchDomainError::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 => {
19            return Err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::unhandled(
20                generic,
21            ))
22        }
23    };
24
25    let _error_message = generic.message().map(|msg| msg.to_owned());
26    Err(match error_code {
27        "BaseException" => crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::BaseException({
28            #[allow(unused_mut)]
29            let mut tmp = {
30                #[allow(unused_mut)]
31                let mut output = crate::types::error::builders::BaseExceptionBuilder::default();
32                output = crate::protocol_serde::shape_base_exception::de_base_exception_json_err(_response_body, output)
33                    .map_err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::unhandled)?;
34                let output = output.meta(generic);
35                output.build()
36            };
37            if tmp.message.is_none() {
38                tmp.message = _error_message;
39            }
40            tmp
41        }),
42        "InternalException" => crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::InternalException({
43            #[allow(unused_mut)]
44            let mut tmp = {
45                #[allow(unused_mut)]
46                let mut output = crate::types::error::builders::InternalExceptionBuilder::default();
47                output = crate::protocol_serde::shape_internal_exception::de_internal_exception_json_err(_response_body, output)
48                    .map_err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::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        "ResourceNotFoundException" => crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::ResourceNotFoundException({
58            #[allow(unused_mut)]
59            let mut tmp = {
60                #[allow(unused_mut)]
61                let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
62                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
63                    .map_err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::unhandled)?;
64                let output = output.meta(generic);
65                output.build()
66            };
67            if tmp.message.is_none() {
68                tmp.message = _error_message;
69            }
70            tmp
71        }),
72        "ValidationException" => crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::ValidationException({
73            #[allow(unused_mut)]
74            let mut tmp = {
75                #[allow(unused_mut)]
76                let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
77                output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
78                    .map_err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::unhandled)?;
79                let output = output.meta(generic);
80                output.build()
81            };
82            if tmp.message.is_none() {
83                tmp.message = _error_message;
84            }
85            tmp
86        }),
87        _ => crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::generic(generic),
88    })
89}
90
91#[allow(clippy::unnecessary_wraps)]
92pub fn de_delete_elasticsearch_domain_http_response(
93    _response_status: u16,
94    _response_headers: &::aws_smithy_runtime_api::http::Headers,
95    _response_body: &[u8],
96) -> std::result::Result<
97    crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainOutput,
98    crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError,
99> {
100    Ok({
101        #[allow(unused_mut)]
102        let mut output = crate::operation::delete_elasticsearch_domain::builders::DeleteElasticsearchDomainOutputBuilder::default();
103        output = crate::protocol_serde::shape_delete_elasticsearch_domain::de_delete_elasticsearch_domain(_response_body, output)
104            .map_err(crate::operation::delete_elasticsearch_domain::DeleteElasticsearchDomainError::unhandled)?;
105        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
106        output.build()
107    })
108}
109
110pub(crate) fn de_delete_elasticsearch_domain(
111    value: &[u8],
112    mut builder: crate::operation::delete_elasticsearch_domain::builders::DeleteElasticsearchDomainOutputBuilder,
113) -> ::std::result::Result<
114    crate::operation::delete_elasticsearch_domain::builders::DeleteElasticsearchDomainOutputBuilder,
115    ::aws_smithy_json::deserialize::error::DeserializeError,
116> {
117    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
118    let tokens = &mut tokens_owned;
119    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
120    loop {
121        match tokens.next().transpose()? {
122            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
123            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
124                "DomainStatus" => {
125                    builder = builder.set_domain_status(crate::protocol_serde::shape_elasticsearch_domain_status::de_elasticsearch_domain_status(
126                        tokens,
127                    )?);
128                }
129                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
130            },
131            other => {
132                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
133                    "expected object key or end object, found: {:?}",
134                    other
135                )))
136            }
137        }
138    }
139    if tokens.next().is_some() {
140        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
141            "found more JSON tokens after completing parsing",
142        ));
143    }
144    Ok(builder)
145}