k8s_openapi/v1_35/api/core/v1/
key_to_path.rs

1// Generated from definition io.k8s.api.core.v1.KeyToPath
2
3/// Maps a string key to a path within a volume.
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct KeyToPath {
6    /// key is the key to project.
7    pub key: std::string::String,
8
9    /// 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.
10    pub mode: Option<i32>,
11
12    /// 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 '..'.
13    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}