aws_sdk_dynamodb/protocol_serde/
shape_restore_table_from_backup.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_restore_table_from_backup_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::restore_table_from_backup::RestoreTableFromBackupOutput,
9    crate::operation::restore_table_from_backup::RestoreTableFromBackupError,
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::restore_table_from_backup::RestoreTableFromBackupError::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::restore_table_from_backup::RestoreTableFromBackupError::unhandled(
20                generic,
21            ))
22        }
23    };
24
25    let _error_message = generic.message().map(|msg| msg.to_owned());
26    Err(match error_code {
27        "BackupInUseException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::BackupInUseException({
28            #[allow(unused_mut)]
29            let mut tmp = {
30                #[allow(unused_mut)]
31                let mut output = crate::types::error::builders::BackupInUseExceptionBuilder::default();
32                output = crate::protocol_serde::shape_backup_in_use_exception::de_backup_in_use_exception_json_err(_response_body, output)
33                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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        "BackupNotFoundException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::BackupNotFoundException({
43            #[allow(unused_mut)]
44            let mut tmp = {
45                #[allow(unused_mut)]
46                let mut output = crate::types::error::builders::BackupNotFoundExceptionBuilder::default();
47                output = crate::protocol_serde::shape_backup_not_found_exception::de_backup_not_found_exception_json_err(_response_body, output)
48                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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        "InternalServerError" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::InternalServerError({
58            #[allow(unused_mut)]
59            let mut tmp = {
60                #[allow(unused_mut)]
61                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
62                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
63                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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        "InvalidEndpointException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::InvalidEndpointException({
73            #[allow(unused_mut)]
74            let mut tmp = {
75                #[allow(unused_mut)]
76                let mut output = crate::types::error::builders::InvalidEndpointExceptionBuilder::default();
77                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
78                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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        "LimitExceededException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::LimitExceededException({
88            #[allow(unused_mut)]
89            let mut tmp = {
90                #[allow(unused_mut)]
91                let mut output = crate::types::error::builders::LimitExceededExceptionBuilder::default();
92                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
93                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
94                let output = output.meta(generic);
95                output.build()
96            };
97            if tmp.message.is_none() {
98                tmp.message = _error_message;
99            }
100            tmp
101        }),
102        "TableAlreadyExistsException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::TableAlreadyExistsException({
103            #[allow(unused_mut)]
104            let mut tmp = {
105                #[allow(unused_mut)]
106                let mut output = crate::types::error::builders::TableAlreadyExistsExceptionBuilder::default();
107                output =
108                    crate::protocol_serde::shape_table_already_exists_exception::de_table_already_exists_exception_json_err(_response_body, output)
109                        .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
110                let output = output.meta(generic);
111                output.build()
112            };
113            if tmp.message.is_none() {
114                tmp.message = _error_message;
115            }
116            tmp
117        }),
118        "TableInUseException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::TableInUseException({
119            #[allow(unused_mut)]
120            let mut tmp = {
121                #[allow(unused_mut)]
122                let mut output = crate::types::error::builders::TableInUseExceptionBuilder::default();
123                output = crate::protocol_serde::shape_table_in_use_exception::de_table_in_use_exception_json_err(_response_body, output)
124                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
125                let output = output.meta(generic);
126                output.build()
127            };
128            if tmp.message.is_none() {
129                tmp.message = _error_message;
130            }
131            tmp
132        }),
133        _ => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::generic(generic),
134    })
135}
136
137#[allow(clippy::unnecessary_wraps)]
138pub fn de_restore_table_from_backup_http_response(
139    _response_status: u16,
140    _response_headers: &::aws_smithy_runtime_api::http::Headers,
141    _response_body: &[u8],
142) -> std::result::Result<
143    crate::operation::restore_table_from_backup::RestoreTableFromBackupOutput,
144    crate::operation::restore_table_from_backup::RestoreTableFromBackupError,
145> {
146    Ok({
147        #[allow(unused_mut)]
148        let mut output = crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder::default();
149        output = crate::protocol_serde::shape_restore_table_from_backup::de_restore_table_from_backup(_response_body, output)
150            .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
151        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
152        output.build()
153    })
154}
155
156pub fn ser_restore_table_from_backup_input(
157    input: &crate::operation::restore_table_from_backup::RestoreTableFromBackupInput,
158) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
159    let mut out = String::new();
160    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
161    crate::protocol_serde::shape_restore_table_from_backup_input::ser_restore_table_from_backup_input_input(&mut object, input)?;
162    object.finish();
163    Ok(::aws_smithy_types::body::SdkBody::from(out))
164}
165
166pub(crate) fn de_restore_table_from_backup(
167    value: &[u8],
168    mut builder: crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder,
169) -> ::std::result::Result<
170    crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder,
171    ::aws_smithy_json::deserialize::error::DeserializeError,
172> {
173    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
174    let tokens = &mut tokens_owned;
175    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
176    loop {
177        match tokens.next().transpose()? {
178            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
179            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
180                "TableDescription" => {
181                    builder = builder.set_table_description(crate::protocol_serde::shape_table_description::de_table_description(tokens)?);
182                }
183                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
184            },
185            other => {
186                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
187                    "expected object key or end object, found: {:?}",
188                    other
189                )))
190            }
191        }
192    }
193    if tokens.next().is_some() {
194        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
195            "found more JSON tokens after completing parsing",
196        ));
197    }
198    Ok(builder)
199}