aws_sdk_ec2/protocol_serde/
shape_create_flow_logs_input.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub 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}