aws_sdk_cloudfront/protocol_serde/
shape_cache_policy_cookies_config.rs1pub fn ser_cache_policy_cookies_config(
3 input: &crate::types::CachePolicyCookiesConfig,
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 {
9 let mut inner_writer = scope.start_el("CookieBehavior").finish();
10 inner_writer.data(input.cookie_behavior.as_str());
11 }
12 if let Some(var_1) = &input.cookies {
13 let inner_writer = scope.start_el("Cookies");
14 crate::protocol_serde::shape_cookie_names::ser_cookie_names(var_1, inner_writer)?
15 }
16 scope.finish();
17 Ok(())
18}
19
20#[allow(clippy::needless_question_mark)]
21pub fn de_cache_policy_cookies_config(
22 decoder: &mut ::aws_smithy_xml::decode::ScopedDecoder,
23) -> ::std::result::Result<crate::types::CachePolicyCookiesConfig, ::aws_smithy_xml::decode::XmlDecodeError> {
24 #[allow(unused_mut)]
25 let mut builder = crate::types::CachePolicyCookiesConfig::builder();
26 while let Some(mut tag) = decoder.next_tag() {
27 match tag.start_el() {
28 s if s.matches("CookieBehavior") => {
29 let var_2 =
30 Some(
31 Result::<crate::types::CachePolicyCookieBehavior, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
32 crate::types::CachePolicyCookieBehavior::from(
33 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
34 )
35 )
36 ?
37 )
38 ;
39 builder = builder.set_cookie_behavior(var_2);
40 }
41 ,
42 s if s.matches("Cookies") => {
43 let var_3 =
44 Some(
45 crate::protocol_serde::shape_cookie_names::de_cookie_names(&mut tag)
46 ?
47 )
48 ;
49 builder = builder.set_cookies(var_3);
50 }
51 ,
52 _ => {}
53 }
54 }
55 Ok(crate::serde_util::cache_policy_cookies_config_correct_errors(builder)
56 .build()
57 .map_err(|_| ::aws_smithy_xml::decode::XmlDecodeError::custom("missing field"))?)
58}