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
#[derive(Clone, Debug, Default, PartialEq)]
pub struct GlusterfsVolumeSource {
pub endpoints: String,
pub path: String,
pub read_only: Option<bool>,
}
impl<'de> serde::Deserialize<'de> for GlusterfsVolumeSource {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
#[allow(non_camel_case_types)]
enum Field {
Key_endpoints,
Key_path,
Key_read_only,
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 {
"endpoints" => Field::Key_endpoints,
"path" => Field::Key_path,
"readOnly" => Field::Key_read_only,
_ => Field::Other,
})
}
}
deserializer.deserialize_identifier(Visitor)
}
}
struct Visitor;
impl<'de> serde::de::Visitor<'de> for Visitor {
type Value = GlusterfsVolumeSource;
fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str("GlusterfsVolumeSource")
}
fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: serde::de::MapAccess<'de> {
let mut value_endpoints: Option<String> = None;
let mut value_path: Option<String> = None;
let mut value_read_only: Option<bool> = None;
while let Some(key) = serde::de::MapAccess::next_key::<Field>(&mut map)? {
match key {
Field::Key_endpoints => value_endpoints = Some(serde::de::MapAccess::next_value(&mut map)?),
Field::Key_path => value_path = Some(serde::de::MapAccess::next_value(&mut map)?),
Field::Key_read_only => value_read_only = serde::de::MapAccess::next_value(&mut map)?,
Field::Other => { let _: serde::de::IgnoredAny = serde::de::MapAccess::next_value(&mut map)?; },
}
}
Ok(GlusterfsVolumeSource {
endpoints: value_endpoints.ok_or_else(|| serde::de::Error::missing_field("endpoints"))?,
path: value_path.ok_or_else(|| serde::de::Error::missing_field("path"))?,
read_only: value_read_only,
})
}
}
deserializer.deserialize_struct(
"GlusterfsVolumeSource",
&[
"endpoints",
"path",
"readOnly",
],
Visitor,
)
}
}
impl serde::Serialize for GlusterfsVolumeSource {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
let mut state = serializer.serialize_struct(
"GlusterfsVolumeSource",
2 +
self.read_only.as_ref().map_or(0, |_| 1),
)?;
serde::ser::SerializeStruct::serialize_field(&mut state, "endpoints", &self.endpoints)?;
serde::ser::SerializeStruct::serialize_field(&mut state, "path", &self.path)?;
if let Some(value) = &self.read_only {
serde::ser::SerializeStruct::serialize_field(&mut state, "readOnly", value)?;
}
serde::ser::SerializeStruct::end(state)
}
}