pub fn ser_create_snapshot_copy_grant_input_input_input(
input: &crate::operation::create_snapshot_copy_grant::CreateSnapshotCopyGrantInput,
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
let mut out = String::new();
#[allow(unused_mut)]
let mut writer = ::aws_smithy_query::QueryWriter::new(&mut out, "CreateSnapshotCopyGrant", "2012-12-01");
#[allow(unused_mut)]
let mut scope_1 = writer.prefix("SnapshotCopyGrantName");
if let Some(var_2) = &input.snapshot_copy_grant_name {
scope_1.string(var_2);
}
#[allow(unused_mut)]
let mut scope_3 = writer.prefix("KmsKeyId");
if let Some(var_4) = &input.kms_key_id {
scope_3.string(var_4);
}
#[allow(unused_mut)]
let mut scope_5 = writer.prefix("Tags");
if let Some(var_6) = &input.tags {
let mut list_8 = scope_5.start_list(false, Some("Tag"));
for item_7 in var_6 {
#[allow(unused_mut)]
let mut entry_9 = list_8.entry();
crate::protocol_serde::shape_tag::ser_tag(entry_9, item_7)?;
}
list_8.finish();
}
writer.finish();
Ok(::aws_smithy_types::body::SdkBody::from(out))
}