k8s_openapi/v1_35/api/core/v1/
key_to_path.rs1#[derive(Clone, Debug, Default, PartialEq)]
5pub struct KeyToPath {
6 pub key: std::string::String,
8
9 pub mode: Option<i32>,
11
12 pub path: std::string::String,
14}
15
16impl crate::DeepMerge for KeyToPath {
17 fn merge_from(&mut self, other: Self) {
18 crate::DeepMerge::merge_from(&mut self.key, other.key);
19 crate::DeepMerge::merge_from(&mut self.mode, other.mode);
20 crate::DeepMerge::merge_from(&mut self.path, other.path);
21 }
22}
23
24impl<'de> crate::serde::Deserialize<'de> for KeyToPath {
25 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
26 #[allow(non_camel_case_types)]
27 enum Field {
28 Key_key,
29 Key_mode,
30 Key_path,
31 Other,
32 }
33
34 impl<'de> crate::serde::Deserialize<'de> for Field {
35 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
36 struct Visitor;
37
38 impl crate::serde::de::Visitor<'_> for Visitor {
39 type Value = Field;
40
41 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
42 f.write_str("field identifier")
43 }
44
45 fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: crate::serde::de::Error {
46 Ok(match v {
47 "key" => Field::Key_key,
48 "mode" => Field::Key_mode,
49 "path" => Field::Key_path,
50 _ => Field::Other,
51 })
52 }
53 }
54
55 deserializer.deserialize_identifier(Visitor)
56 }
57 }
58
59 struct Visitor;
60
61 impl<'de> crate::serde::de::Visitor<'de> for Visitor {
62 type Value = KeyToPath;
63
64 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
65 f.write_str("KeyToPath")
66 }
67
68 fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: crate::serde::de::MapAccess<'de> {
69 let mut value_key: Option<std::string::String> = None;
70 let mut value_mode: Option<i32> = None;
71 let mut value_path: Option<std::string::String> = None;
72
73 while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
74 match key {
75 Field::Key_key => value_key = crate::serde::de::MapAccess::next_value(&mut map)?,
76 Field::Key_mode => value_mode = crate::serde::de::MapAccess::next_value(&mut map)?,
77 Field::Key_path => value_path = crate::serde::de::MapAccess::next_value(&mut map)?,
78 Field::Other => { let _: crate::serde::de::IgnoredAny = crate::serde::de::MapAccess::next_value(&mut map)?; },
79 }
80 }
81
82 Ok(KeyToPath {
83 key: value_key.unwrap_or_default(),
84 mode: value_mode,
85 path: value_path.unwrap_or_default(),
86 })
87 }
88 }
89
90 deserializer.deserialize_struct(
91 "KeyToPath",
92 &[
93 "key",
94 "mode",
95 "path",
96 ],
97 Visitor,
98 )
99 }
100}
101
102impl crate::serde::Serialize for KeyToPath {
103 fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
104 let mut state = serializer.serialize_struct(
105 "KeyToPath",
106 2 +
107 self.mode.as_ref().map_or(0, |_| 1),
108 )?;
109 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "key", &self.key)?;
110 if let Some(value) = &self.mode {
111 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "mode", value)?;
112 }
113 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "path", &self.path)?;
114 crate::serde::ser::SerializeStruct::end(state)
115 }
116}
117
118#[cfg(feature = "schemars")]
119impl crate::schemars::JsonSchema for KeyToPath {
120 fn schema_name() -> std::borrow::Cow<'static, str> {
121 "io.k8s.api.core.v1.KeyToPath".into()
122 }
123
124 fn json_schema(__gen: &mut crate::schemars::SchemaGenerator) -> crate::schemars::Schema {
125 crate::schemars::json_schema!({
126 "description": "Maps a string key to a path within a volume.",
127 "type": "object",
128 "properties": {
129 "key": {
130 "description": "key is the key to project.",
131 "type": "string",
132 },
133 "mode": {
134 "description": "mode is Optional: mode bits used to set permissions on this file. Must be an octal value between 0000 and 0777 or a decimal value between 0 and 511. YAML accepts both octal and decimal values, JSON requires decimal values for mode bits. If not specified, the volume defaultMode will be used. This might be in conflict with other options that affect the file mode, like fsGroup, and the result can be other mode bits set.",
135 "type": "integer",
136 "format": "int32",
137 },
138 "path": {
139 "description": "path is the relative path of the file to map the key to. May not be an absolute path. May not contain the path element '..'. May not start with the string '..'.",
140 "type": "string",
141 },
142 },
143 "required": [
144 "key",
145 "path",
146 ],
147 })
148 }
149}