aws_sdk_databasemigration/protocol_serde/
shape_s3_settings.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub fn ser_s3_settings(
3    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
4    input: &crate::types::S3Settings,
5) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
6    if let Some(var_1) = &input.service_access_role_arn {
7        object.key("ServiceAccessRoleArn").string(var_1.as_str());
8    }
9    if let Some(var_2) = &input.external_table_definition {
10        object.key("ExternalTableDefinition").string(var_2.as_str());
11    }
12    if let Some(var_3) = &input.csv_row_delimiter {
13        object.key("CsvRowDelimiter").string(var_3.as_str());
14    }
15    if let Some(var_4) = &input.csv_delimiter {
16        object.key("CsvDelimiter").string(var_4.as_str());
17    }
18    if let Some(var_5) = &input.bucket_folder {
19        object.key("BucketFolder").string(var_5.as_str());
20    }
21    if let Some(var_6) = &input.bucket_name {
22        object.key("BucketName").string(var_6.as_str());
23    }
24    if let Some(var_7) = &input.compression_type {
25        object.key("CompressionType").string(var_7.as_str());
26    }
27    if let Some(var_8) = &input.encryption_mode {
28        object.key("EncryptionMode").string(var_8.as_str());
29    }
30    if let Some(var_9) = &input.server_side_encryption_kms_key_id {
31        object.key("ServerSideEncryptionKmsKeyId").string(var_9.as_str());
32    }
33    if let Some(var_10) = &input.data_format {
34        object.key("DataFormat").string(var_10.as_str());
35    }
36    if let Some(var_11) = &input.encoding_type {
37        object.key("EncodingType").string(var_11.as_str());
38    }
39    if let Some(var_12) = &input.dict_page_size_limit {
40        object.key("DictPageSizeLimit").number(
41            #[allow(clippy::useless_conversion)]
42            ::aws_smithy_types::Number::NegInt((*var_12).into()),
43        );
44    }
45    if let Some(var_13) = &input.row_group_length {
46        object.key("RowGroupLength").number(
47            #[allow(clippy::useless_conversion)]
48            ::aws_smithy_types::Number::NegInt((*var_13).into()),
49        );
50    }
51    if let Some(var_14) = &input.data_page_size {
52        object.key("DataPageSize").number(
53            #[allow(clippy::useless_conversion)]
54            ::aws_smithy_types::Number::NegInt((*var_14).into()),
55        );
56    }
57    if let Some(var_15) = &input.parquet_version {
58        object.key("ParquetVersion").string(var_15.as_str());
59    }
60    if let Some(var_16) = &input.enable_statistics {
61        object.key("EnableStatistics").boolean(*var_16);
62    }
63    if let Some(var_17) = &input.include_op_for_full_load {
64        object.key("IncludeOpForFullLoad").boolean(*var_17);
65    }
66    if let Some(var_18) = &input.cdc_inserts_only {
67        object.key("CdcInsertsOnly").boolean(*var_18);
68    }
69    if let Some(var_19) = &input.timestamp_column_name {
70        object.key("TimestampColumnName").string(var_19.as_str());
71    }
72    if let Some(var_20) = &input.parquet_timestamp_in_millisecond {
73        object.key("ParquetTimestampInMillisecond").boolean(*var_20);
74    }
75    if let Some(var_21) = &input.cdc_inserts_and_updates {
76        object.key("CdcInsertsAndUpdates").boolean(*var_21);
77    }
78    if let Some(var_22) = &input.date_partition_enabled {
79        object.key("DatePartitionEnabled").boolean(*var_22);
80    }
81    if let Some(var_23) = &input.date_partition_sequence {
82        object.key("DatePartitionSequence").string(var_23.as_str());
83    }
84    if let Some(var_24) = &input.date_partition_delimiter {
85        object.key("DatePartitionDelimiter").string(var_24.as_str());
86    }
87    if let Some(var_25) = &input.use_csv_no_sup_value {
88        object.key("UseCsvNoSupValue").boolean(*var_25);
89    }
90    if let Some(var_26) = &input.csv_no_sup_value {
91        object.key("CsvNoSupValue").string(var_26.as_str());
92    }
93    if let Some(var_27) = &input.preserve_transactions {
94        object.key("PreserveTransactions").boolean(*var_27);
95    }
96    if let Some(var_28) = &input.cdc_path {
97        object.key("CdcPath").string(var_28.as_str());
98    }
99    if let Some(var_29) = &input.use_task_start_time_for_full_load_timestamp {
100        object.key("UseTaskStartTimeForFullLoadTimestamp").boolean(*var_29);
101    }
102    if let Some(var_30) = &input.canned_acl_for_objects {
103        object.key("CannedAclForObjects").string(var_30.as_str());
104    }
105    if let Some(var_31) = &input.add_column_name {
106        object.key("AddColumnName").boolean(*var_31);
107    }
108    if let Some(var_32) = &input.cdc_max_batch_interval {
109        object.key("CdcMaxBatchInterval").number(
110            #[allow(clippy::useless_conversion)]
111            ::aws_smithy_types::Number::NegInt((*var_32).into()),
112        );
113    }
114    if let Some(var_33) = &input.cdc_min_file_size {
115        object.key("CdcMinFileSize").number(
116            #[allow(clippy::useless_conversion)]
117            ::aws_smithy_types::Number::NegInt((*var_33).into()),
118        );
119    }
120    if let Some(var_34) = &input.csv_null_value {
121        object.key("CsvNullValue").string(var_34.as_str());
122    }
123    if let Some(var_35) = &input.ignore_header_rows {
124        object.key("IgnoreHeaderRows").number(
125            #[allow(clippy::useless_conversion)]
126            ::aws_smithy_types::Number::NegInt((*var_35).into()),
127        );
128    }
129    if let Some(var_36) = &input.max_file_size {
130        object.key("MaxFileSize").number(
131            #[allow(clippy::useless_conversion)]
132            ::aws_smithy_types::Number::NegInt((*var_36).into()),
133        );
134    }
135    if let Some(var_37) = &input.rfc4180 {
136        object.key("Rfc4180").boolean(*var_37);
137    }
138    if let Some(var_38) = &input.date_partition_timezone {
139        object.key("DatePartitionTimezone").string(var_38.as_str());
140    }
141    if let Some(var_39) = &input.add_trailing_padding_character {
142        object.key("AddTrailingPaddingCharacter").boolean(*var_39);
143    }
144    if let Some(var_40) = &input.expected_bucket_owner {
145        object.key("ExpectedBucketOwner").string(var_40.as_str());
146    }
147    if let Some(var_41) = &input.glue_catalog_generation {
148        object.key("GlueCatalogGeneration").boolean(*var_41);
149    }
150    Ok(())
151}
152
153pub(crate) fn de_s3_settings<'a, I>(
154    tokens: &mut ::std::iter::Peekable<I>,
155) -> ::std::result::Result<Option<crate::types::S3Settings>, ::aws_smithy_json::deserialize::error::DeserializeError>
156where
157    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
158{
159    match tokens.next().transpose()? {
160        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
161        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
162            #[allow(unused_mut)]
163            let mut builder = crate::types::builders::S3SettingsBuilder::default();
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                        "ServiceAccessRoleArn" => {
169                            builder = builder.set_service_access_role_arn(
170                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
171                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
172                                    .transpose()?,
173                            );
174                        }
175                        "ExternalTableDefinition" => {
176                            builder = builder.set_external_table_definition(
177                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
178                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
179                                    .transpose()?,
180                            );
181                        }
182                        "CsvRowDelimiter" => {
183                            builder = builder.set_csv_row_delimiter(
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                        "CsvDelimiter" => {
190                            builder = builder.set_csv_delimiter(
191                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
192                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
193                                    .transpose()?,
194                            );
195                        }
196                        "BucketFolder" => {
197                            builder = builder.set_bucket_folder(
198                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
199                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
200                                    .transpose()?,
201                            );
202                        }
203                        "BucketName" => {
204                            builder = builder.set_bucket_name(
205                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
206                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
207                                    .transpose()?,
208                            );
209                        }
210                        "CompressionType" => {
211                            builder = builder.set_compression_type(
212                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
213                                    .map(|s| s.to_unescaped().map(|u| crate::types::CompressionTypeValue::from(u.as_ref())))
214                                    .transpose()?,
215                            );
216                        }
217                        "EncryptionMode" => {
218                            builder = builder.set_encryption_mode(
219                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
220                                    .map(|s| s.to_unescaped().map(|u| crate::types::EncryptionModeValue::from(u.as_ref())))
221                                    .transpose()?,
222                            );
223                        }
224                        "ServerSideEncryptionKmsKeyId" => {
225                            builder = builder.set_server_side_encryption_kms_key_id(
226                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
227                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
228                                    .transpose()?,
229                            );
230                        }
231                        "DataFormat" => {
232                            builder = builder.set_data_format(
233                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
234                                    .map(|s| s.to_unescaped().map(|u| crate::types::DataFormatValue::from(u.as_ref())))
235                                    .transpose()?,
236                            );
237                        }
238                        "EncodingType" => {
239                            builder = builder.set_encoding_type(
240                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
241                                    .map(|s| s.to_unescaped().map(|u| crate::types::EncodingTypeValue::from(u.as_ref())))
242                                    .transpose()?,
243                            );
244                        }
245                        "DictPageSizeLimit" => {
246                            builder = builder.set_dict_page_size_limit(
247                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
248                                    .map(i32::try_from)
249                                    .transpose()?,
250                            );
251                        }
252                        "RowGroupLength" => {
253                            builder = builder.set_row_group_length(
254                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
255                                    .map(i32::try_from)
256                                    .transpose()?,
257                            );
258                        }
259                        "DataPageSize" => {
260                            builder = builder.set_data_page_size(
261                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
262                                    .map(i32::try_from)
263                                    .transpose()?,
264                            );
265                        }
266                        "ParquetVersion" => {
267                            builder = builder.set_parquet_version(
268                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
269                                    .map(|s| s.to_unescaped().map(|u| crate::types::ParquetVersionValue::from(u.as_ref())))
270                                    .transpose()?,
271                            );
272                        }
273                        "EnableStatistics" => {
274                            builder = builder.set_enable_statistics(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
275                        }
276                        "IncludeOpForFullLoad" => {
277                            builder =
278                                builder.set_include_op_for_full_load(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
279                        }
280                        "CdcInsertsOnly" => {
281                            builder = builder.set_cdc_inserts_only(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
282                        }
283                        "TimestampColumnName" => {
284                            builder = builder.set_timestamp_column_name(
285                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
286                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
287                                    .transpose()?,
288                            );
289                        }
290                        "ParquetTimestampInMillisecond" => {
291                            builder = builder
292                                .set_parquet_timestamp_in_millisecond(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
293                        }
294                        "CdcInsertsAndUpdates" => {
295                            builder = builder.set_cdc_inserts_and_updates(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
296                        }
297                        "DatePartitionEnabled" => {
298                            builder = builder.set_date_partition_enabled(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
299                        }
300                        "DatePartitionSequence" => {
301                            builder = builder.set_date_partition_sequence(
302                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
303                                    .map(|s| s.to_unescaped().map(|u| crate::types::DatePartitionSequenceValue::from(u.as_ref())))
304                                    .transpose()?,
305                            );
306                        }
307                        "DatePartitionDelimiter" => {
308                            builder = builder.set_date_partition_delimiter(
309                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
310                                    .map(|s| s.to_unescaped().map(|u| crate::types::DatePartitionDelimiterValue::from(u.as_ref())))
311                                    .transpose()?,
312                            );
313                        }
314                        "UseCsvNoSupValue" => {
315                            builder = builder.set_use_csv_no_sup_value(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
316                        }
317                        "CsvNoSupValue" => {
318                            builder = builder.set_csv_no_sup_value(
319                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
320                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
321                                    .transpose()?,
322                            );
323                        }
324                        "PreserveTransactions" => {
325                            builder = builder.set_preserve_transactions(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
326                        }
327                        "CdcPath" => {
328                            builder = builder.set_cdc_path(
329                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
330                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
331                                    .transpose()?,
332                            );
333                        }
334                        "UseTaskStartTimeForFullLoadTimestamp" => {
335                            builder = builder.set_use_task_start_time_for_full_load_timestamp(
336                                ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?,
337                            );
338                        }
339                        "CannedAclForObjects" => {
340                            builder = builder.set_canned_acl_for_objects(
341                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
342                                    .map(|s| s.to_unescaped().map(|u| crate::types::CannedAclForObjectsValue::from(u.as_ref())))
343                                    .transpose()?,
344                            );
345                        }
346                        "AddColumnName" => {
347                            builder = builder.set_add_column_name(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
348                        }
349                        "CdcMaxBatchInterval" => {
350                            builder = builder.set_cdc_max_batch_interval(
351                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
352                                    .map(i32::try_from)
353                                    .transpose()?,
354                            );
355                        }
356                        "CdcMinFileSize" => {
357                            builder = builder.set_cdc_min_file_size(
358                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
359                                    .map(i32::try_from)
360                                    .transpose()?,
361                            );
362                        }
363                        "CsvNullValue" => {
364                            builder = builder.set_csv_null_value(
365                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
366                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
367                                    .transpose()?,
368                            );
369                        }
370                        "IgnoreHeaderRows" => {
371                            builder = builder.set_ignore_header_rows(
372                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
373                                    .map(i32::try_from)
374                                    .transpose()?,
375                            );
376                        }
377                        "MaxFileSize" => {
378                            builder = builder.set_max_file_size(
379                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
380                                    .map(i32::try_from)
381                                    .transpose()?,
382                            );
383                        }
384                        "Rfc4180" => {
385                            builder = builder.set_rfc4180(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
386                        }
387                        "DatePartitionTimezone" => {
388                            builder = builder.set_date_partition_timezone(
389                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
390                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
391                                    .transpose()?,
392                            );
393                        }
394                        "AddTrailingPaddingCharacter" => {
395                            builder = builder
396                                .set_add_trailing_padding_character(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
397                        }
398                        "ExpectedBucketOwner" => {
399                            builder = builder.set_expected_bucket_owner(
400                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
401                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
402                                    .transpose()?,
403                            );
404                        }
405                        "GlueCatalogGeneration" => {
406                            builder = builder.set_glue_catalog_generation(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
407                        }
408                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
409                    },
410                    other => {
411                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
412                            "expected object key or end object, found: {:?}",
413                            other
414                        )))
415                    }
416                }
417            }
418            Ok(Some(builder.build()))
419        }
420        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
421            "expected start object or null",
422        )),
423    }
424}