pub fn ser_derive_shared_secret_input_input(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::operation::derive_shared_secret::DeriveSharedSecretInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
if let Some(var_1) = &input.key_id {
object.key("KeyId").string(var_1.as_str());
}
if let Some(var_2) = &input.key_agreement_algorithm {
object.key("KeyAgreementAlgorithm").string(var_2.as_str());
}
if let Some(var_3) = &input.public_key {
object.key("PublicKey").string_unchecked(&::aws_smithy_types::base64::encode(var_3));
}
if let Some(var_4) = &input.grant_tokens {
let mut array_5 = object.key("GrantTokens").start_array();
for item_6 in var_4 {
{
array_5.value().string(item_6.as_str());
}
}
array_5.finish();
}
if let Some(var_7) = &input.dry_run {
object.key("DryRun").boolean(*var_7);
}
if let Some(var_8) = &input.recipient {
#[allow(unused_mut)]
let mut object_9 = object.key("Recipient").start_object();
crate::protocol_serde::shape_recipient_info::ser_recipient_info(&mut object_9, var_8)?;
object_9.finish();
}
Ok(())
}