aws_sdk_elasticsearch/protocol_serde/
shape_upgrade_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_upgrade_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::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainOutput,
9    crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError,
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::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::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::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled(generic)),
19    };
20
21    let _error_message = generic.message().map(|msg| msg.to_owned());
22    Err(match error_code {
23        "BaseException" => crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::BaseException({
24            #[allow(unused_mut)]
25            let mut tmp = {
26                #[allow(unused_mut)]
27                let mut output = crate::types::error::builders::BaseExceptionBuilder::default();
28                output = crate::protocol_serde::shape_base_exception::de_base_exception_json_err(_response_body, output)
29                    .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::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        "DisabledOperationException" => {
39            crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::DisabledOperationException({
40                #[allow(unused_mut)]
41                let mut tmp = {
42                    #[allow(unused_mut)]
43                    let mut output = crate::types::error::builders::DisabledOperationExceptionBuilder::default();
44                    output =
45                        crate::protocol_serde::shape_disabled_operation_exception::de_disabled_operation_exception_json_err(_response_body, output)
46                            .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
47                    let output = output.meta(generic);
48                    output.build()
49                };
50                if tmp.message.is_none() {
51                    tmp.message = _error_message;
52                }
53                tmp
54            })
55        }
56        "InternalException" => crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::InternalException({
57            #[allow(unused_mut)]
58            let mut tmp = {
59                #[allow(unused_mut)]
60                let mut output = crate::types::error::builders::InternalExceptionBuilder::default();
61                output = crate::protocol_serde::shape_internal_exception::de_internal_exception_json_err(_response_body, output)
62                    .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
63                let output = output.meta(generic);
64                output.build()
65            };
66            if tmp.message.is_none() {
67                tmp.message = _error_message;
68            }
69            tmp
70        }),
71        "ResourceAlreadyExistsException" => {
72            crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::ResourceAlreadyExistsException({
73                #[allow(unused_mut)]
74                let mut tmp = {
75                    #[allow(unused_mut)]
76                    let mut output = crate::types::error::builders::ResourceAlreadyExistsExceptionBuilder::default();
77                    output = crate::protocol_serde::shape_resource_already_exists_exception::de_resource_already_exists_exception_json_err(
78                        _response_body,
79                        output,
80                    )
81                    .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
82                    let output = output.meta(generic);
83                    output.build()
84                };
85                if tmp.message.is_none() {
86                    tmp.message = _error_message;
87                }
88                tmp
89            })
90        }
91        "ResourceNotFoundException" => crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::ResourceNotFoundException({
92            #[allow(unused_mut)]
93            let mut tmp = {
94                #[allow(unused_mut)]
95                let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
96                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
97                    .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
98                let output = output.meta(generic);
99                output.build()
100            };
101            if tmp.message.is_none() {
102                tmp.message = _error_message;
103            }
104            tmp
105        }),
106        "ValidationException" => crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::ValidationException({
107            #[allow(unused_mut)]
108            let mut tmp = {
109                #[allow(unused_mut)]
110                let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
111                output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
112                    .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
113                let output = output.meta(generic);
114                output.build()
115            };
116            if tmp.message.is_none() {
117                tmp.message = _error_message;
118            }
119            tmp
120        }),
121        _ => crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::generic(generic),
122    })
123}
124
125#[allow(clippy::unnecessary_wraps)]
126pub fn de_upgrade_elasticsearch_domain_http_response(
127    _response_status: u16,
128    _response_headers: &::aws_smithy_runtime_api::http::Headers,
129    _response_body: &[u8],
130) -> std::result::Result<
131    crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainOutput,
132    crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError,
133> {
134    Ok({
135        #[allow(unused_mut)]
136        let mut output = crate::operation::upgrade_elasticsearch_domain::builders::UpgradeElasticsearchDomainOutputBuilder::default();
137        output = crate::protocol_serde::shape_upgrade_elasticsearch_domain::de_upgrade_elasticsearch_domain(_response_body, output)
138            .map_err(crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainError::unhandled)?;
139        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
140        output.build()
141    })
142}
143
144pub fn ser_upgrade_elasticsearch_domain_input(
145    input: &crate::operation::upgrade_elasticsearch_domain::UpgradeElasticsearchDomainInput,
146) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
147    let mut out = String::new();
148    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
149    crate::protocol_serde::shape_upgrade_elasticsearch_domain_input::ser_upgrade_elasticsearch_domain_input_input(&mut object, input)?;
150    object.finish();
151    Ok(::aws_smithy_types::body::SdkBody::from(out))
152}
153
154pub(crate) fn de_upgrade_elasticsearch_domain(
155    value: &[u8],
156    mut builder: crate::operation::upgrade_elasticsearch_domain::builders::UpgradeElasticsearchDomainOutputBuilder,
157) -> ::std::result::Result<
158    crate::operation::upgrade_elasticsearch_domain::builders::UpgradeElasticsearchDomainOutputBuilder,
159    ::aws_smithy_json::deserialize::error::DeserializeError,
160> {
161    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
162    let tokens = &mut tokens_owned;
163    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
164    loop {
165        match tokens.next().transpose()? {
166            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
167            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
168                "ChangeProgressDetails" => {
169                    builder = builder
170                        .set_change_progress_details(crate::protocol_serde::shape_change_progress_details::de_change_progress_details(tokens)?);
171                }
172                "DomainName" => {
173                    builder = builder.set_domain_name(
174                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
175                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
176                            .transpose()?,
177                    );
178                }
179                "PerformCheckOnly" => {
180                    builder = builder.set_perform_check_only(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
181                }
182                "TargetVersion" => {
183                    builder = builder.set_target_version(
184                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
185                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
186                            .transpose()?,
187                    );
188                }
189                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
190            },
191            other => {
192                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
193                    "expected object key or end object, found: {:?}",
194                    other
195                )))
196            }
197        }
198    }
199    if tokens.next().is_some() {
200        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
201            "found more JSON tokens after completing parsing",
202        ));
203    }
204    Ok(builder)
205}