aws_sdk_s3/protocol_serde/
shape_server_side_encryption_rule.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub fn ser_server_side_encryption_rule(
3    input: &crate::types::ServerSideEncryptionRule,
4    writer: ::aws_smithy_xml::encode::ElWriter,
5) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
6    #[allow(unused_mut)]
7    let mut scope = writer.finish();
8    if let Some(var_1) = &input.apply_server_side_encryption_by_default {
9        let inner_writer = scope.start_el("ApplyServerSideEncryptionByDefault");
10        crate::protocol_serde::shape_server_side_encryption_by_default::ser_server_side_encryption_by_default(var_1, inner_writer)?
11    }
12    if let Some(var_2) = &input.bucket_key_enabled {
13        let mut inner_writer = scope.start_el("BucketKeyEnabled").finish();
14        inner_writer.data(::aws_smithy_types::primitive::Encoder::from(*var_2).encode());
15    }
16    if let Some(var_3) = &input.blocked_encryption_types {
17        let inner_writer = scope.start_el("BlockedEncryptionTypes");
18        crate::protocol_serde::shape_blocked_encryption_types::ser_blocked_encryption_types(var_3, inner_writer)?
19    }
20    scope.finish();
21    Ok(())
22}
23
24#[allow(clippy::needless_question_mark)]
25pub fn de_server_side_encryption_rule(
26    decoder: &mut ::aws_smithy_xml::decode::ScopedDecoder,
27) -> ::std::result::Result<crate::types::ServerSideEncryptionRule, ::aws_smithy_xml::decode::XmlDecodeError> {
28    #[allow(unused_mut)]
29    let mut builder = crate::types::ServerSideEncryptionRule::builder();
30    while let Some(mut tag) = decoder.next_tag() {
31        match tag.start_el() {
32            s if s.matches("ApplyServerSideEncryptionByDefault") /* ApplyServerSideEncryptionByDefault com.amazonaws.s3#ServerSideEncryptionRule$ApplyServerSideEncryptionByDefault */ =>  {
33                let var_4 =
34                    Some(
35                        crate::protocol_serde::shape_server_side_encryption_by_default::de_server_side_encryption_by_default(&mut tag)
36                        ?
37                    )
38                ;
39                builder = builder.set_apply_server_side_encryption_by_default(var_4);
40            }
41            ,
42            s if s.matches("BucketKeyEnabled") /* BucketKeyEnabled com.amazonaws.s3#ServerSideEncryptionRule$BucketKeyEnabled */ =>  {
43                let var_5 =
44                    Some(
45                         {
46                            <bool as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
47                                ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
48                            )
49                            .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (boolean: `com.amazonaws.s3#BucketKeyEnabled`)"))
50                        }
51                        ?
52                    )
53                ;
54                builder = builder.set_bucket_key_enabled(var_5);
55            }
56            ,
57            s if s.matches("BlockedEncryptionTypes") /* BlockedEncryptionTypes com.amazonaws.s3#ServerSideEncryptionRule$BlockedEncryptionTypes */ =>  {
58                let var_6 =
59                    Some(
60                        crate::protocol_serde::shape_blocked_encryption_types::de_blocked_encryption_types(&mut tag)
61                        ?
62                    )
63                ;
64                builder = builder.set_blocked_encryption_types(var_6);
65            }
66            ,
67            _ => {}
68        }
69    }
70    Ok(builder.build())
71}