aws_sdk_fsx/protocol_serde/
shape_create_file_system_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_create_file_system_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::create_file_system_from_backup::CreateFileSystemFromBackupOutput,
9    crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError,
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::create_file_system_from_backup::CreateFileSystemFromBackupError::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::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled(generic)),
19    };
20
21    let _error_message = generic.message().map(|msg| msg.to_owned());
22    Err(match error_code {
23        "ActiveDirectoryError" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::ActiveDirectoryError({
24            #[allow(unused_mut)]
25            let mut tmp = {
26                #[allow(unused_mut)]
27                let mut output = crate::types::error::builders::ActiveDirectoryErrorBuilder::default();
28                output = crate::protocol_serde::shape_active_directory_error::de_active_directory_error_json_err(_response_body, output)
29                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
30                let output = output.meta(generic);
31                crate::serde_util::active_directory_error_correct_errors(output).build()
32            };
33            if tmp.message.is_none() {
34                tmp.message = _error_message;
35            }
36            tmp
37        }),
38        "BackupNotFound" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::BackupNotFound({
39            #[allow(unused_mut)]
40            let mut tmp = {
41                #[allow(unused_mut)]
42                let mut output = crate::types::error::builders::BackupNotFoundBuilder::default();
43                output = crate::protocol_serde::shape_backup_not_found::de_backup_not_found_json_err(_response_body, output)
44                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
45                let output = output.meta(generic);
46                output.build()
47            };
48            if tmp.message.is_none() {
49                tmp.message = _error_message;
50            }
51            tmp
52        }),
53        "BadRequest" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::BadRequest({
54            #[allow(unused_mut)]
55            let mut tmp = {
56                #[allow(unused_mut)]
57                let mut output = crate::types::error::builders::BadRequestBuilder::default();
58                output = crate::protocol_serde::shape_bad_request::de_bad_request_json_err(_response_body, output)
59                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
60                let output = output.meta(generic);
61                output.build()
62            };
63            if tmp.message.is_none() {
64                tmp.message = _error_message;
65            }
66            tmp
67        }),
68        "IncompatibleParameterError" => {
69            crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::IncompatibleParameterError({
70                #[allow(unused_mut)]
71                let mut tmp = {
72                    #[allow(unused_mut)]
73                    let mut output = crate::types::error::builders::IncompatibleParameterErrorBuilder::default();
74                    output =
75                        crate::protocol_serde::shape_incompatible_parameter_error::de_incompatible_parameter_error_json_err(_response_body, output)
76                            .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
77                    let output = output.meta(generic);
78                    crate::serde_util::incompatible_parameter_error_correct_errors(output).build()
79                };
80                if tmp.message.is_none() {
81                    tmp.message = _error_message;
82                }
83                tmp
84            })
85        }
86        "InternalServerError" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::InternalServerError({
87            #[allow(unused_mut)]
88            let mut tmp = {
89                #[allow(unused_mut)]
90                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
91                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
92                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
93                let output = output.meta(generic);
94                output.build()
95            };
96            if tmp.message.is_none() {
97                tmp.message = _error_message;
98            }
99            tmp
100        }),
101        "InvalidNetworkSettings" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::InvalidNetworkSettings({
102            #[allow(unused_mut)]
103            let mut tmp = {
104                #[allow(unused_mut)]
105                let mut output = crate::types::error::builders::InvalidNetworkSettingsBuilder::default();
106                output = crate::protocol_serde::shape_invalid_network_settings::de_invalid_network_settings_json_err(_response_body, output)
107                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
108                let output = output.meta(generic);
109                output.build()
110            };
111            if tmp.message.is_none() {
112                tmp.message = _error_message;
113            }
114            tmp
115        }),
116        "InvalidPerUnitStorageThroughput" => {
117            crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::InvalidPerUnitStorageThroughput({
118                #[allow(unused_mut)]
119                let mut tmp = {
120                    #[allow(unused_mut)]
121                    let mut output = crate::types::error::builders::InvalidPerUnitStorageThroughputBuilder::default();
122                    output = crate::protocol_serde::shape_invalid_per_unit_storage_throughput::de_invalid_per_unit_storage_throughput_json_err(
123                        _response_body,
124                        output,
125                    )
126                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
127                    let output = output.meta(generic);
128                    output.build()
129                };
130                if tmp.message.is_none() {
131                    tmp.message = _error_message;
132                }
133                tmp
134            })
135        }
136        "MissingFileSystemConfiguration" => {
137            crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::MissingFileSystemConfiguration({
138                #[allow(unused_mut)]
139                let mut tmp = {
140                    #[allow(unused_mut)]
141                    let mut output = crate::types::error::builders::MissingFileSystemConfigurationBuilder::default();
142                    output = crate::protocol_serde::shape_missing_file_system_configuration::de_missing_file_system_configuration_json_err(
143                        _response_body,
144                        output,
145                    )
146                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
147                    let output = output.meta(generic);
148                    output.build()
149                };
150                if tmp.message.is_none() {
151                    tmp.message = _error_message;
152                }
153                tmp
154            })
155        }
156        "ServiceLimitExceeded" => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::ServiceLimitExceeded({
157            #[allow(unused_mut)]
158            let mut tmp = {
159                #[allow(unused_mut)]
160                let mut output = crate::types::error::builders::ServiceLimitExceededBuilder::default();
161                output = crate::protocol_serde::shape_service_limit_exceeded::de_service_limit_exceeded_json_err(_response_body, output)
162                    .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
163                let output = output.meta(generic);
164                crate::serde_util::service_limit_exceeded_correct_errors(output).build()
165            };
166            if tmp.message.is_none() {
167                tmp.message = _error_message;
168            }
169            tmp
170        }),
171        _ => crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::generic(generic),
172    })
173}
174
175#[allow(clippy::unnecessary_wraps)]
176pub fn de_create_file_system_from_backup_http_response(
177    _response_status: u16,
178    _response_headers: &::aws_smithy_runtime_api::http::Headers,
179    _response_body: &[u8],
180) -> std::result::Result<
181    crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupOutput,
182    crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError,
183> {
184    Ok({
185        #[allow(unused_mut)]
186        let mut output = crate::operation::create_file_system_from_backup::builders::CreateFileSystemFromBackupOutputBuilder::default();
187        output = crate::protocol_serde::shape_create_file_system_from_backup::de_create_file_system_from_backup(_response_body, output)
188            .map_err(crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupError::unhandled)?;
189        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
190        output.build()
191    })
192}
193
194pub fn ser_create_file_system_from_backup_input(
195    input: &crate::operation::create_file_system_from_backup::CreateFileSystemFromBackupInput,
196) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
197    let mut out = String::new();
198    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
199    crate::protocol_serde::shape_create_file_system_from_backup_input::ser_create_file_system_from_backup_input_input(&mut object, input)?;
200    object.finish();
201    Ok(::aws_smithy_types::body::SdkBody::from(out))
202}
203
204pub(crate) fn de_create_file_system_from_backup(
205    value: &[u8],
206    mut builder: crate::operation::create_file_system_from_backup::builders::CreateFileSystemFromBackupOutputBuilder,
207) -> ::std::result::Result<
208    crate::operation::create_file_system_from_backup::builders::CreateFileSystemFromBackupOutputBuilder,
209    ::aws_smithy_json::deserialize::error::DeserializeError,
210> {
211    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
212    let tokens = &mut tokens_owned;
213    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
214    loop {
215        match tokens.next().transpose()? {
216            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
217            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
218                "FileSystem" => {
219                    builder = builder.set_file_system(crate::protocol_serde::shape_file_system::de_file_system(tokens)?);
220                }
221                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
222            },
223            other => {
224                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
225                    "expected object key or end object, found: {:?}",
226                    other
227                )))
228            }
229        }
230    }
231    if tokens.next().is_some() {
232        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
233            "found more JSON tokens after completing parsing",
234        ));
235    }
236    Ok(builder)
237}