pub fn ser_add_policy_grant_input_input(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::operation::add_policy_grant::AddPolicyGrantInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
if let Some(var_1) = &input.client_token {
object.key("clientToken").string(var_1.as_str());
}
if let Some(var_2) = &input.detail {
#[allow(unused_mut)]
let mut object_3 = object.key("detail").start_object();
crate::protocol_serde::shape_policy_grant_detail::ser_policy_grant_detail(&mut object_3, var_2)?;
object_3.finish();
}
if let Some(var_4) = &input.policy_type {
object.key("policyType").string(var_4.as_str());
}
if let Some(var_5) = &input.principal {
#[allow(unused_mut)]
let mut object_6 = object.key("principal").start_object();
crate::protocol_serde::shape_policy_grant_principal::ser_policy_grant_principal(&mut object_6, var_5)?;
object_6.finish();
}
Ok(())
}