aws_sdk_ec2/protocol_serde/
shape_create_flow_logs_input.rs1pub fn ser_create_flow_logs_input_input_input(
3 input: &crate::operation::create_flow_logs::CreateFlowLogsInput,
4) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
5 let mut out = String::new();
6 #[allow(unused_mut)]
7 let mut writer = ::aws_smithy_query::QueryWriter::new(&mut out, "CreateFlowLogs", "2016-11-15");
8 #[allow(unused_mut)]
9 let mut scope_1 = writer.prefix("DryRun");
10 if let Some(var_2) = &input.dry_run {
11 scope_1.boolean(*var_2);
12 }
13 #[allow(unused_mut)]
14 let mut scope_3 = writer.prefix("ClientToken");
15 if let Some(var_4) = &input.client_token {
16 scope_3.string(var_4);
17 }
18 #[allow(unused_mut)]
19 let mut scope_5 = writer.prefix("DeliverLogsPermissionArn");
20 if let Some(var_6) = &input.deliver_logs_permission_arn {
21 scope_5.string(var_6);
22 }
23 #[allow(unused_mut)]
24 let mut scope_7 = writer.prefix("DeliverCrossAccountRole");
25 if let Some(var_8) = &input.deliver_cross_account_role {
26 scope_7.string(var_8);
27 }
28 #[allow(unused_mut)]
29 let mut scope_9 = writer.prefix("LogGroupName");
30 if let Some(var_10) = &input.log_group_name {
31 scope_9.string(var_10);
32 }
33 #[allow(unused_mut)]
34 let mut scope_11 = writer.prefix("ResourceId");
35 if let Some(var_12) = &input.resource_ids {
36 if !var_12.is_empty() {
37 let mut list_14 = scope_11.start_list(true, Some("item"));
38 for item_13 in var_12 {
39 #[allow(unused_mut)]
40 let mut entry_15 = list_14.entry();
41 entry_15.string(item_13);
42 }
43 list_14.finish();
44 }
45 }
46 #[allow(unused_mut)]
47 let mut scope_16 = writer.prefix("ResourceType");
48 if let Some(var_17) = &input.resource_type {
49 scope_16.string(var_17.as_str());
50 }
51 #[allow(unused_mut)]
52 let mut scope_18 = writer.prefix("TrafficType");
53 if let Some(var_19) = &input.traffic_type {
54 scope_18.string(var_19.as_str());
55 }
56 #[allow(unused_mut)]
57 let mut scope_20 = writer.prefix("LogDestinationType");
58 if let Some(var_21) = &input.log_destination_type {
59 scope_20.string(var_21.as_str());
60 }
61 #[allow(unused_mut)]
62 let mut scope_22 = writer.prefix("LogDestination");
63 if let Some(var_23) = &input.log_destination {
64 scope_22.string(var_23);
65 }
66 #[allow(unused_mut)]
67 let mut scope_24 = writer.prefix("LogFormat");
68 if let Some(var_25) = &input.log_format {
69 scope_24.string(var_25);
70 }
71 #[allow(unused_mut)]
72 let mut scope_26 = writer.prefix("TagSpecification");
73 if let Some(var_27) = &input.tag_specifications {
74 if !var_27.is_empty() {
75 let mut list_29 = scope_26.start_list(true, Some("item"));
76 for item_28 in var_27 {
77 #[allow(unused_mut)]
78 let mut entry_30 = list_29.entry();
79 crate::protocol_serde::shape_tag_specification::ser_tag_specification(entry_30, item_28)?;
80 }
81 list_29.finish();
82 }
83 }
84 #[allow(unused_mut)]
85 let mut scope_31 = writer.prefix("MaxAggregationInterval");
86 if let Some(var_32) = &input.max_aggregation_interval {
87 scope_31.number(
88 #[allow(clippy::useless_conversion)]
89 ::aws_smithy_types::Number::NegInt((*var_32).into()),
90 );
91 }
92 #[allow(unused_mut)]
93 let mut scope_33 = writer.prefix("DestinationOptions");
94 if let Some(var_34) = &input.destination_options {
95 crate::protocol_serde::shape_destination_options_request::ser_destination_options_request(scope_33, var_34)?;
96 }
97 writer.finish();
98 Ok(::aws_smithy_types::body::SdkBody::from(out))
99}