aws-sdk-drs 1.105.0

AWS SDK for Elastic Disaster Recovery Service
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub fn ser_create_replication_configuration_template_input_input(
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    input: &crate::operation::create_replication_configuration_template::CreateReplicationConfigurationTemplateInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    if let Some(var_1) = &input.associate_default_security_group {
        object.key("associateDefaultSecurityGroup").boolean(*var_1);
    }
    if let Some(var_2) = &input.auto_replicate_new_disks {
        object.key("autoReplicateNewDisks").boolean(*var_2);
    }
    if let Some(var_3) = &input.bandwidth_throttling {
        object.key("bandwidthThrottling").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_3).into()),
        );
    }
    if let Some(var_4) = &input.create_public_ip {
        object.key("createPublicIP").boolean(*var_4);
    }
    if let Some(var_5) = &input.data_plane_routing {
        object.key("dataPlaneRouting").string(var_5.as_str());
    }
    if let Some(var_6) = &input.default_large_staging_disk_type {
        object.key("defaultLargeStagingDiskType").string(var_6.as_str());
    }
    if let Some(var_7) = &input.ebs_encryption {
        object.key("ebsEncryption").string(var_7.as_str());
    }
    if let Some(var_8) = &input.ebs_encryption_key_arn {
        object.key("ebsEncryptionKeyArn").string(var_8.as_str());
    }
    if let Some(var_9) = &input.internet_protocol {
        object.key("internetProtocol").string(var_9.as_str());
    }
    if let Some(var_10) = &input.pit_policy {
        let mut array_11 = object.key("pitPolicy").start_array();
        for item_12 in var_10 {
            {
                #[allow(unused_mut)]
                let mut object_13 = array_11.value().start_object();
                crate::protocol_serde::shape_pit_policy_rule::ser_pit_policy_rule(&mut object_13, item_12)?;
                object_13.finish();
            }
        }
        array_11.finish();
    }
    if let Some(var_14) = &input.replication_server_instance_type {
        object.key("replicationServerInstanceType").string(var_14.as_str());
    }
    if let Some(var_15) = &input.replication_servers_security_groups_ids {
        let mut array_16 = object.key("replicationServersSecurityGroupsIDs").start_array();
        for item_17 in var_15 {
            {
                array_16.value().string(item_17.as_str());
            }
        }
        array_16.finish();
    }
    if let Some(var_18) = &input.staging_area_subnet_id {
        object.key("stagingAreaSubnetId").string(var_18.as_str());
    }
    if let Some(var_19) = &input.staging_area_tags {
        #[allow(unused_mut)]
        let mut object_20 = object.key("stagingAreaTags").start_object();
        for (key_21, value_22) in var_19 {
            {
                object_20.key(key_21.as_str()).string(value_22.as_str());
            }
        }
        object_20.finish();
    }
    if let Some(var_23) = &input.tags {
        #[allow(unused_mut)]
        let mut object_24 = object.key("tags").start_object();
        for (key_25, value_26) in var_23 {
            {
                object_24.key(key_25.as_str()).string(value_26.as_str());
            }
        }
        object_24.finish();
    }
    if let Some(var_27) = &input.use_dedicated_replication_server {
        object.key("useDedicatedReplicationServer").boolean(*var_27);
    }
    Ok(())
}