pub fn ser_generate_auth_request_cryptogram_input_input(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::operation::generate_auth_request_cryptogram::GenerateAuthRequestCryptogramInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
if let Some(var_1) = &input.key_identifier {
object.key("KeyIdentifier").string(var_1.as_str());
}
if let Some(var_2) = &input.major_key_derivation_mode {
object.key("MajorKeyDerivationMode").string(var_2.as_str());
}
if let Some(var_3) = &input.session_key_derivation_attributes {
#[allow(unused_mut)]
let mut object_4 = object.key("SessionKeyDerivationAttributes").start_object();
crate::protocol_serde::shape_session_key_derivation::ser_session_key_derivation(&mut object_4, var_3)?;
object_4.finish();
}
if let Some(var_5) = &input.transaction_data {
object.key("TransactionData").string(var_5.as_str());
}
Ok(())
}