k8s_openapi/v1_35/api/core/v1/
se_linux_options.rs1#[derive(Clone, Debug, Default, PartialEq)]
5pub struct SELinuxOptions {
6 pub level: Option<std::string::String>,
8
9 pub role: Option<std::string::String>,
11
12 pub type_: Option<std::string::String>,
14
15 pub user: Option<std::string::String>,
17}
18
19impl crate::DeepMerge for SELinuxOptions {
20 fn merge_from(&mut self, other: Self) {
21 crate::DeepMerge::merge_from(&mut self.level, other.level);
22 crate::DeepMerge::merge_from(&mut self.role, other.role);
23 crate::DeepMerge::merge_from(&mut self.type_, other.type_);
24 crate::DeepMerge::merge_from(&mut self.user, other.user);
25 }
26}
27
28impl<'de> crate::serde::Deserialize<'de> for SELinuxOptions {
29 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
30 #[allow(non_camel_case_types)]
31 enum Field {
32 Key_level,
33 Key_role,
34 Key_type_,
35 Key_user,
36 Other,
37 }
38
39 impl<'de> crate::serde::Deserialize<'de> for Field {
40 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
41 struct Visitor;
42
43 impl crate::serde::de::Visitor<'_> for Visitor {
44 type Value = Field;
45
46 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
47 f.write_str("field identifier")
48 }
49
50 fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: crate::serde::de::Error {
51 Ok(match v {
52 "level" => Field::Key_level,
53 "role" => Field::Key_role,
54 "type" => Field::Key_type_,
55 "user" => Field::Key_user,
56 _ => Field::Other,
57 })
58 }
59 }
60
61 deserializer.deserialize_identifier(Visitor)
62 }
63 }
64
65 struct Visitor;
66
67 impl<'de> crate::serde::de::Visitor<'de> for Visitor {
68 type Value = SELinuxOptions;
69
70 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
71 f.write_str("SELinuxOptions")
72 }
73
74 fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: crate::serde::de::MapAccess<'de> {
75 let mut value_level: Option<std::string::String> = None;
76 let mut value_role: Option<std::string::String> = None;
77 let mut value_type_: Option<std::string::String> = None;
78 let mut value_user: Option<std::string::String> = None;
79
80 while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
81 match key {
82 Field::Key_level => value_level = crate::serde::de::MapAccess::next_value(&mut map)?,
83 Field::Key_role => value_role = crate::serde::de::MapAccess::next_value(&mut map)?,
84 Field::Key_type_ => value_type_ = crate::serde::de::MapAccess::next_value(&mut map)?,
85 Field::Key_user => value_user = crate::serde::de::MapAccess::next_value(&mut map)?,
86 Field::Other => { let _: crate::serde::de::IgnoredAny = crate::serde::de::MapAccess::next_value(&mut map)?; },
87 }
88 }
89
90 Ok(SELinuxOptions {
91 level: value_level,
92 role: value_role,
93 type_: value_type_,
94 user: value_user,
95 })
96 }
97 }
98
99 deserializer.deserialize_struct(
100 "SELinuxOptions",
101 &[
102 "level",
103 "role",
104 "type",
105 "user",
106 ],
107 Visitor,
108 )
109 }
110}
111
112impl crate::serde::Serialize for SELinuxOptions {
113 fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
114 let mut state = serializer.serialize_struct(
115 "SELinuxOptions",
116 self.level.as_ref().map_or(0, |_| 1) +
117 self.role.as_ref().map_or(0, |_| 1) +
118 self.type_.as_ref().map_or(0, |_| 1) +
119 self.user.as_ref().map_or(0, |_| 1),
120 )?;
121 if let Some(value) = &self.level {
122 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "level", value)?;
123 }
124 if let Some(value) = &self.role {
125 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "role", value)?;
126 }
127 if let Some(value) = &self.type_ {
128 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "type", value)?;
129 }
130 if let Some(value) = &self.user {
131 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "user", value)?;
132 }
133 crate::serde::ser::SerializeStruct::end(state)
134 }
135}
136
137#[cfg(feature = "schemars")]
138impl crate::schemars::JsonSchema for SELinuxOptions {
139 fn schema_name() -> std::borrow::Cow<'static, str> {
140 "io.k8s.api.core.v1.SELinuxOptions".into()
141 }
142
143 fn json_schema(__gen: &mut crate::schemars::SchemaGenerator) -> crate::schemars::Schema {
144 crate::schemars::json_schema!({
145 "description": "SELinuxOptions are the labels to be applied to the container",
146 "type": "object",
147 "properties": {
148 "level": {
149 "description": "Level is SELinux level label that applies to the container.",
150 "type": "string",
151 },
152 "role": {
153 "description": "Role is a SELinux role label that applies to the container.",
154 "type": "string",
155 },
156 "type": {
157 "description": "Type is a SELinux type label that applies to the container.",
158 "type": "string",
159 },
160 "user": {
161 "description": "User is a SELinux user label that applies to the container.",
162 "type": "string",
163 },
164 },
165 })
166 }
167}