aws_sdk_databasemigration/protocol_serde/
shape_s3_settings.rs1pub 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}