aws_sdk_ec2/protocol_serde/
shape_ip_permission.rs1#[allow(unused_mut)]
3pub fn ser_ip_permission(
4 mut writer: ::aws_smithy_query::QueryValueWriter,
5 input: &crate::types::IpPermission,
6) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
7 #[allow(unused_mut)]
8 let mut scope_1 = writer.prefix("IpProtocol");
9 if let Some(var_2) = &input.ip_protocol {
10 scope_1.string(var_2);
11 }
12 #[allow(unused_mut)]
13 let mut scope_3 = writer.prefix("FromPort");
14 if let Some(var_4) = &input.from_port {
15 scope_3.number(
16 #[allow(clippy::useless_conversion)]
17 ::aws_smithy_types::Number::NegInt((*var_4).into()),
18 );
19 }
20 #[allow(unused_mut)]
21 let mut scope_5 = writer.prefix("ToPort");
22 if let Some(var_6) = &input.to_port {
23 scope_5.number(
24 #[allow(clippy::useless_conversion)]
25 ::aws_smithy_types::Number::NegInt((*var_6).into()),
26 );
27 }
28 #[allow(unused_mut)]
29 let mut scope_7 = writer.prefix("Groups");
30 if let Some(var_8) = &input.user_id_group_pairs {
31 if !var_8.is_empty() {
32 let mut list_10 = scope_7.start_list(true, Some("item"));
33 for item_9 in var_8 {
34 #[allow(unused_mut)]
35 let mut entry_11 = list_10.entry();
36 crate::protocol_serde::shape_user_id_group_pair::ser_user_id_group_pair(entry_11, item_9)?;
37 }
38 list_10.finish();
39 }
40 }
41 #[allow(unused_mut)]
42 let mut scope_12 = writer.prefix("IpRanges");
43 if let Some(var_13) = &input.ip_ranges {
44 if !var_13.is_empty() {
45 let mut list_15 = scope_12.start_list(true, Some("item"));
46 for item_14 in var_13 {
47 #[allow(unused_mut)]
48 let mut entry_16 = list_15.entry();
49 crate::protocol_serde::shape_ip_range::ser_ip_range(entry_16, item_14)?;
50 }
51 list_15.finish();
52 }
53 }
54 #[allow(unused_mut)]
55 let mut scope_17 = writer.prefix("Ipv6Ranges");
56 if let Some(var_18) = &input.ipv6_ranges {
57 if !var_18.is_empty() {
58 let mut list_20 = scope_17.start_list(true, Some("item"));
59 for item_19 in var_18 {
60 #[allow(unused_mut)]
61 let mut entry_21 = list_20.entry();
62 crate::protocol_serde::shape_ipv6_range::ser_ipv6_range(entry_21, item_19)?;
63 }
64 list_20.finish();
65 }
66 }
67 #[allow(unused_mut)]
68 let mut scope_22 = writer.prefix("PrefixListIds");
69 if let Some(var_23) = &input.prefix_list_ids {
70 if !var_23.is_empty() {
71 let mut list_25 = scope_22.start_list(true, Some("item"));
72 for item_24 in var_23 {
73 #[allow(unused_mut)]
74 let mut entry_26 = list_25.entry();
75 crate::protocol_serde::shape_prefix_list_id::ser_prefix_list_id(entry_26, item_24)?;
76 }
77 list_25.finish();
78 }
79 }
80 Ok(())
81}
82
83#[allow(clippy::needless_question_mark)]
84pub fn de_ip_permission(
85 decoder: &mut ::aws_smithy_xml::decode::ScopedDecoder,
86) -> ::std::result::Result<crate::types::IpPermission, ::aws_smithy_xml::decode::XmlDecodeError> {
87 #[allow(unused_mut)]
88 let mut builder = crate::types::IpPermission::builder();
89 while let Some(mut tag) = decoder.next_tag() {
90 match tag.start_el() {
91 s if s.matches("ipProtocol") => {
92 let var_27 =
93 Some(
94 Result::<::std::string::String, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
95 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
96 .into()
97 )
98 ?
99 )
100 ;
101 builder = builder.set_ip_protocol(var_27);
102 }
103 ,
104 s if s.matches("fromPort") => {
105 let var_28 =
106 Some(
107 {
108 <i32 as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
109 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
110 )
111 .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (integer: `com.amazonaws.ec2#Integer`)"))
112 }
113 ?
114 )
115 ;
116 builder = builder.set_from_port(var_28);
117 }
118 ,
119 s if s.matches("toPort") => {
120 let var_29 =
121 Some(
122 {
123 <i32 as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
124 ::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
125 )
126 .map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (integer: `com.amazonaws.ec2#Integer`)"))
127 }
128 ?
129 )
130 ;
131 builder = builder.set_to_port(var_29);
132 }
133 ,
134 s if s.matches("groups") => {
135 let var_30 =
136 Some(
137 crate::protocol_serde::shape_user_id_group_pair_list::de_user_id_group_pair_list(&mut tag)
138 ?
139 )
140 ;
141 builder = builder.set_user_id_group_pairs(var_30);
142 }
143 ,
144 s if s.matches("ipRanges") => {
145 let var_31 =
146 Some(
147 crate::protocol_serde::shape_ip_range_list::de_ip_range_list(&mut tag)
148 ?
149 )
150 ;
151 builder = builder.set_ip_ranges(var_31);
152 }
153 ,
154 s if s.matches("ipv6Ranges") => {
155 let var_32 =
156 Some(
157 crate::protocol_serde::shape_ipv6_range_list::de_ipv6_range_list(&mut tag)
158 ?
159 )
160 ;
161 builder = builder.set_ipv6_ranges(var_32);
162 }
163 ,
164 s if s.matches("prefixListIds") => {
165 let var_33 =
166 Some(
167 crate::protocol_serde::shape_prefix_list_id_list::de_prefix_list_id_list(&mut tag)
168 ?
169 )
170 ;
171 builder = builder.set_prefix_list_ids(var_33);
172 }
173 ,
174 _ => {}
175 }
176 }
177 Ok(builder.build())
178}