pub fn ser_create_certificate_authority_input_input(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::operation::create_certificate_authority::CreateCertificateAuthorityInput,
) -> Result<(), ::aws_smithy_types::error::operation::SerializationError> {
if let Some(var_1) = &input.certificate_authority_configuration {
#[allow(unused_mut)]
let mut object_2 = object.key("CertificateAuthorityConfiguration").start_object();
crate::protocol_serde::shape_certificate_authority_configuration::ser_certificate_authority_configuration(&mut object_2, var_1)?;
object_2.finish();
}
if let Some(var_3) = &input.revocation_configuration {
#[allow(unused_mut)]
let mut object_4 = object.key("RevocationConfiguration").start_object();
crate::protocol_serde::shape_revocation_configuration::ser_revocation_configuration(&mut object_4, var_3)?;
object_4.finish();
}
if let Some(var_5) = &input.certificate_authority_type {
object.key("CertificateAuthorityType").string(var_5.as_str());
}
if let Some(var_6) = &input.idempotency_token {
object.key("IdempotencyToken").string(var_6.as_str());
}
if let Some(var_7) = &input.key_storage_security_standard {
object.key("KeyStorageSecurityStandard").string(var_7.as_str());
}
if let Some(var_8) = &input.tags {
let mut array_9 = object.key("Tags").start_array();
for item_10 in var_8 {
{
#[allow(unused_mut)]
let mut object_11 = array_9.value().start_object();
crate::protocol_serde::shape_tag::ser_tag(&mut object_11, item_10)?;
object_11.finish();
}
}
array_9.finish();
}
if let Some(var_12) = &input.usage_mode {
object.key("UsageMode").string(var_12.as_str());
}
Ok(())
}