k8s_openapi/v1_34/api/admissionregistration/v1alpha1/
variable.rs1#[derive(Clone, Debug, Default, PartialEq)]
5pub struct Variable {
6 pub expression: std::string::String,
8
9 pub name: std::string::String,
11}
12
13impl crate::DeepMerge for Variable {
14 fn merge_from(&mut self, other: Self) {
15 crate::DeepMerge::merge_from(&mut self.expression, other.expression);
16 crate::DeepMerge::merge_from(&mut self.name, other.name);
17 }
18}
19
20impl<'de> crate::serde::Deserialize<'de> for Variable {
21 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
22 #[allow(non_camel_case_types)]
23 enum Field {
24 Key_expression,
25 Key_name,
26 Other,
27 }
28
29 impl<'de> crate::serde::Deserialize<'de> for Field {
30 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
31 struct Visitor;
32
33 impl crate::serde::de::Visitor<'_> for Visitor {
34 type Value = Field;
35
36 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
37 f.write_str("field identifier")
38 }
39
40 fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: crate::serde::de::Error {
41 Ok(match v {
42 "expression" => Field::Key_expression,
43 "name" => Field::Key_name,
44 _ => Field::Other,
45 })
46 }
47 }
48
49 deserializer.deserialize_identifier(Visitor)
50 }
51 }
52
53 struct Visitor;
54
55 impl<'de> crate::serde::de::Visitor<'de> for Visitor {
56 type Value = Variable;
57
58 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
59 f.write_str("Variable")
60 }
61
62 fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: crate::serde::de::MapAccess<'de> {
63 let mut value_expression: Option<std::string::String> = None;
64 let mut value_name: Option<std::string::String> = None;
65
66 while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
67 match key {
68 Field::Key_expression => value_expression = crate::serde::de::MapAccess::next_value(&mut map)?,
69 Field::Key_name => value_name = crate::serde::de::MapAccess::next_value(&mut map)?,
70 Field::Other => { let _: crate::serde::de::IgnoredAny = crate::serde::de::MapAccess::next_value(&mut map)?; },
71 }
72 }
73
74 Ok(Variable {
75 expression: value_expression.unwrap_or_default(),
76 name: value_name.unwrap_or_default(),
77 })
78 }
79 }
80
81 deserializer.deserialize_struct(
82 "Variable",
83 &[
84 "expression",
85 "name",
86 ],
87 Visitor,
88 )
89 }
90}
91
92impl crate::serde::Serialize for Variable {
93 fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
94 let mut state = serializer.serialize_struct(
95 "Variable",
96 2,
97 )?;
98 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "expression", &self.expression)?;
99 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "name", &self.name)?;
100 crate::serde::ser::SerializeStruct::end(state)
101 }
102}
103
104#[cfg(feature = "schemars")]
105impl crate::schemars::JsonSchema for Variable {
106 fn schema_name() -> std::borrow::Cow<'static, str> {
107 "io.k8s.api.admissionregistration.v1alpha1.Variable".into()
108 }
109
110 fn json_schema(__gen: &mut crate::schemars::SchemaGenerator) -> crate::schemars::Schema {
111 crate::schemars::json_schema!({
112 "description": "Variable is the definition of a variable that is used for composition.",
113 "type": "object",
114 "properties": {
115 "expression": {
116 "description": "Expression is the expression that will be evaluated as the value of the variable. The CEL expression has access to the same identifiers as the CEL expressions in Validation.",
117 "type": "string",
118 },
119 "name": {
120 "description": "Name is the name of the variable. The name must be a valid CEL identifier and unique among all variables. The variable can be accessed in other expressions through `variables` For example, if name is \"foo\", the variable will be available as `variables.foo`",
121 "type": "string",
122 },
123 },
124 "required": [
125 "expression",
126 "name",
127 ],
128 })
129 }
130}