aws-sdk-datasync 1.109.0

AWS SDK for AWS DataSync
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub fn ser_update_location_smb_input_input(
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    input: &crate::operation::update_location_smb::UpdateLocationSmbInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    if let Some(var_1) = &input.location_arn {
        object.key("LocationArn").string(var_1.as_str());
    }
    if let Some(var_2) = &input.subdirectory {
        object.key("Subdirectory").string(var_2.as_str());
    }
    if let Some(var_3) = &input.server_hostname {
        object.key("ServerHostname").string(var_3.as_str());
    }
    if let Some(var_4) = &input.user {
        object.key("User").string(var_4.as_str());
    }
    if let Some(var_5) = &input.domain {
        object.key("Domain").string(var_5.as_str());
    }
    if let Some(var_6) = &input.password {
        object.key("Password").string(var_6.as_str());
    }
    if let Some(var_7) = &input.cmk_secret_config {
        #[allow(unused_mut)]
        let mut object_8 = object.key("CmkSecretConfig").start_object();
        crate::protocol_serde::shape_cmk_secret_config::ser_cmk_secret_config(&mut object_8, var_7)?;
        object_8.finish();
    }
    if let Some(var_9) = &input.custom_secret_config {
        #[allow(unused_mut)]
        let mut object_10 = object.key("CustomSecretConfig").start_object();
        crate::protocol_serde::shape_custom_secret_config::ser_custom_secret_config(&mut object_10, var_9)?;
        object_10.finish();
    }
    if let Some(var_11) = &input.agent_arns {
        let mut array_12 = object.key("AgentArns").start_array();
        for item_13 in var_11 {
            {
                array_12.value().string(item_13.as_str());
            }
        }
        array_12.finish();
    }
    if let Some(var_14) = &input.mount_options {
        #[allow(unused_mut)]
        let mut object_15 = object.key("MountOptions").start_object();
        crate::protocol_serde::shape_smb_mount_options::ser_smb_mount_options(&mut object_15, var_14)?;
        object_15.finish();
    }
    if let Some(var_16) = &input.authentication_type {
        object.key("AuthenticationType").string(var_16.as_str());
    }
    if let Some(var_17) = &input.dns_ip_addresses {
        let mut array_18 = object.key("DnsIpAddresses").start_array();
        for item_19 in var_17 {
            {
                array_18.value().string(item_19.as_str());
            }
        }
        array_18.finish();
    }
    if let Some(var_20) = &input.kerberos_principal {
        object.key("KerberosPrincipal").string(var_20.as_str());
    }
    if let Some(var_21) = &input.kerberos_keytab {
        object.key("KerberosKeytab").string_unchecked(&::aws_smithy_types::base64::encode(var_21));
    }
    if let Some(var_22) = &input.kerberos_krb5_conf {
        object
            .key("KerberosKrb5Conf")
            .string_unchecked(&::aws_smithy_types::base64::encode(var_22));
    }
    Ok(())
}