pub fn ser_viewer_certificate(
input: &crate::types::ViewerCertificate,
writer: ::aws_smithy_xml::encode::ElWriter,
) -> Result<(), ::aws_smithy_types::error::operation::SerializationError> {
#[allow(unused_mut)]
let mut scope = writer.finish();
if let Some(var_1) = &input.cloud_front_default_certificate {
let mut inner_writer = scope.start_el("CloudFrontDefaultCertificate").finish();
inner_writer.data(::aws_smithy_types::primitive::Encoder::from(*var_1).encode());
}
if let Some(var_2) = &input.iam_certificate_id {
let mut inner_writer = scope.start_el("IAMCertificateId").finish();
inner_writer.data(var_2.as_str());
}
if let Some(var_3) = &input.acm_certificate_arn {
let mut inner_writer = scope.start_el("ACMCertificateArn").finish();
inner_writer.data(var_3.as_str());
}
if let Some(var_4) = &input.ssl_support_method {
let mut inner_writer = scope.start_el("SSLSupportMethod").finish();
inner_writer.data(var_4.as_str());
}
if let Some(var_5) = &input.minimum_protocol_version {
let mut inner_writer = scope.start_el("MinimumProtocolVersion").finish();
inner_writer.data(var_5.as_str());
}
if let Some(var_6) = &input.certificate {
let mut inner_writer = scope.start_el("Certificate").finish();
inner_writer.data(var_6.as_str());
}
if let Some(var_7) = &input.certificate_source {
let mut inner_writer = scope.start_el("CertificateSource").finish();
inner_writer.data(var_7.as_str());
}
scope.finish();
Ok(())
}
#[allow(clippy::needless_question_mark)]
pub fn de_viewer_certificate(
decoder: &mut ::aws_smithy_xml::decode::ScopedDecoder,
) -> Result<crate::types::ViewerCertificate, ::aws_smithy_xml::decode::XmlDecodeError> {
#[allow(unused_mut)]
let mut builder = crate::types::ViewerCertificate::builder();
while let Some(mut tag) = decoder.next_tag() {
match tag.start_el() {
s if s.matches("CloudFrontDefaultCertificate") => {
let var_8 =
Some(
{
<bool as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
.map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (boolean: `com.amazonaws.cloudfront#boolean`)"))
}
?
)
;
builder = builder.set_cloud_front_default_certificate(var_8);
}
,
s if s.matches("IAMCertificateId") => {
let var_9 =
Some(
Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
.into()
)
?
)
;
builder = builder.set_iam_certificate_id(var_9);
}
,
s if s.matches("ACMCertificateArn") => {
let var_10 =
Some(
Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
.into()
)
?
)
;
builder = builder.set_acm_certificate_arn(var_10);
}
,
s if s.matches("SSLSupportMethod") => {
let var_11 =
Some(
Result::<crate::types::SslSupportMethod, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
crate::types::SslSupportMethod::from(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
)
?
)
;
builder = builder.set_ssl_support_method(var_11);
}
,
s if s.matches("MinimumProtocolVersion") => {
let var_12 =
Some(
Result::<crate::types::MinimumProtocolVersion, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
crate::types::MinimumProtocolVersion::from(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
)
?
)
;
builder = builder.set_minimum_protocol_version(var_12);
}
,
s if s.matches("Certificate") => {
let var_13 =
Some(
Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
.into()
)
?
)
;
builder = builder.set_certificate(var_13);
}
,
s if s.matches("CertificateSource") => {
let var_14 =
Some(
Result::<crate::types::CertificateSource, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
crate::types::CertificateSource::from(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
)
?
)
;
builder = builder.set_certificate_source(var_14);
}
,
_ => {}
}
}
Ok(builder.build())
}