1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#[derive(Clone, Debug, Default, PartialEq)]
pub struct IngressSpec {
pub backend: Option<crate::api::networking::v1beta1::IngressBackend>,
pub ingress_class_name: Option<String>,
pub rules: Option<Vec<crate::api::networking::v1beta1::IngressRule>>,
pub tls: Option<Vec<crate::api::networking::v1beta1::IngressTLS>>,
}
impl<'de> serde::Deserialize<'de> for IngressSpec {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
#[allow(non_camel_case_types)]
enum Field {
Key_backend,
Key_ingress_class_name,
Key_rules,
Key_tls,
Other,
}
impl<'de> serde::Deserialize<'de> for Field {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
struct Visitor;
impl<'de> serde::de::Visitor<'de> for Visitor {
type Value = Field;
fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str("field identifier")
}
fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: serde::de::Error {
Ok(match v {
"backend" => Field::Key_backend,
"ingressClassName" => Field::Key_ingress_class_name,
"rules" => Field::Key_rules,
"tls" => Field::Key_tls,
_ => Field::Other,
})
}
}
deserializer.deserialize_identifier(Visitor)
}
}
struct Visitor;
impl<'de> serde::de::Visitor<'de> for Visitor {
type Value = IngressSpec;
fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str("IngressSpec")
}
fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: serde::de::MapAccess<'de> {
let mut value_backend: Option<crate::api::networking::v1beta1::IngressBackend> = None;
let mut value_ingress_class_name: Option<String> = None;
let mut value_rules: Option<Vec<crate::api::networking::v1beta1::IngressRule>> = None;
let mut value_tls: Option<Vec<crate::api::networking::v1beta1::IngressTLS>> = None;
while let Some(key) = serde::de::MapAccess::next_key::<Field>(&mut map)? {
match key {
Field::Key_backend => value_backend = serde::de::MapAccess::next_value(&mut map)?,
Field::Key_ingress_class_name => value_ingress_class_name = serde::de::MapAccess::next_value(&mut map)?,
Field::Key_rules => value_rules = serde::de::MapAccess::next_value(&mut map)?,
Field::Key_tls => value_tls = serde::de::MapAccess::next_value(&mut map)?,
Field::Other => { let _: serde::de::IgnoredAny = serde::de::MapAccess::next_value(&mut map)?; },
}
}
Ok(IngressSpec {
backend: value_backend,
ingress_class_name: value_ingress_class_name,
rules: value_rules,
tls: value_tls,
})
}
}
deserializer.deserialize_struct(
"IngressSpec",
&[
"backend",
"ingressClassName",
"rules",
"tls",
],
Visitor,
)
}
}
impl serde::Serialize for IngressSpec {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
let mut state = serializer.serialize_struct(
"IngressSpec",
self.backend.as_ref().map_or(0, |_| 1) +
self.ingress_class_name.as_ref().map_or(0, |_| 1) +
self.rules.as_ref().map_or(0, |_| 1) +
self.tls.as_ref().map_or(0, |_| 1),
)?;
if let Some(value) = &self.backend {
serde::ser::SerializeStruct::serialize_field(&mut state, "backend", value)?;
}
if let Some(value) = &self.ingress_class_name {
serde::ser::SerializeStruct::serialize_field(&mut state, "ingressClassName", value)?;
}
if let Some(value) = &self.rules {
serde::ser::SerializeStruct::serialize_field(&mut state, "rules", value)?;
}
if let Some(value) = &self.tls {
serde::ser::SerializeStruct::serialize_field(&mut state, "tls", value)?;
}
serde::ser::SerializeStruct::end(state)
}
}