k8s_openapi/v1_32/api/admissionregistration/v1/
service_reference.rs1#[derive(Clone, Debug, Default, PartialEq)]
5pub struct ServiceReference {
6 pub name: String,
8
9 pub namespace: String,
11
12 pub path: Option<String>,
14
15 pub port: Option<i32>,
17}
18
19impl crate::DeepMerge for ServiceReference {
20 fn merge_from(&mut self, other: Self) {
21 crate::DeepMerge::merge_from(&mut self.name, other.name);
22 crate::DeepMerge::merge_from(&mut self.namespace, other.namespace);
23 crate::DeepMerge::merge_from(&mut self.path, other.path);
24 crate::DeepMerge::merge_from(&mut self.port, other.port);
25 }
26}
27
28impl<'de> crate::serde::Deserialize<'de> for ServiceReference {
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_name,
33 Key_namespace,
34 Key_path,
35 Key_port,
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 std::fmt::Formatter<'_>) -> std::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 "name" => Field::Key_name,
53 "namespace" => Field::Key_namespace,
54 "path" => Field::Key_path,
55 "port" => Field::Key_port,
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 = ServiceReference;
69
70 fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
71 f.write_str("ServiceReference")
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_name: Option<String> = None;
76 let mut value_namespace: Option<String> = None;
77 let mut value_path: Option<String> = None;
78 let mut value_port: Option<i32> = None;
79
80 while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
81 match key {
82 Field::Key_name => value_name = crate::serde::de::MapAccess::next_value(&mut map)?,
83 Field::Key_namespace => value_namespace = crate::serde::de::MapAccess::next_value(&mut map)?,
84 Field::Key_path => value_path = crate::serde::de::MapAccess::next_value(&mut map)?,
85 Field::Key_port => value_port = 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(ServiceReference {
91 name: value_name.unwrap_or_default(),
92 namespace: value_namespace.unwrap_or_default(),
93 path: value_path,
94 port: value_port,
95 })
96 }
97 }
98
99 deserializer.deserialize_struct(
100 "ServiceReference",
101 &[
102 "name",
103 "namespace",
104 "path",
105 "port",
106 ],
107 Visitor,
108 )
109 }
110}
111
112impl crate::serde::Serialize for ServiceReference {
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 "ServiceReference",
116 2 +
117 self.path.as_ref().map_or(0, |_| 1) +
118 self.port.as_ref().map_or(0, |_| 1),
119 )?;
120 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "name", &self.name)?;
121 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "namespace", &self.namespace)?;
122 if let Some(value) = &self.path {
123 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "path", value)?;
124 }
125 if let Some(value) = &self.port {
126 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "port", value)?;
127 }
128 crate::serde::ser::SerializeStruct::end(state)
129 }
130}
131
132#[cfg(feature = "schemars")]
133impl crate::schemars::JsonSchema for ServiceReference {
134 fn schema_name() -> String {
135 "io.k8s.api.admissionregistration.v1.ServiceReference".to_owned()
136 }
137
138 fn json_schema(__gen: &mut crate::schemars::gen::SchemaGenerator) -> crate::schemars::schema::Schema {
139 crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
140 metadata: Some(Box::new(crate::schemars::schema::Metadata {
141 description: Some("ServiceReference holds a reference to Service.legacy.k8s.io".to_owned()),
142 ..Default::default()
143 })),
144 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Object))),
145 object: Some(Box::new(crate::schemars::schema::ObjectValidation {
146 properties: [
147 (
148 "name".to_owned(),
149 crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
150 metadata: Some(Box::new(crate::schemars::schema::Metadata {
151 description: Some("`name` is the name of the service. Required".to_owned()),
152 ..Default::default()
153 })),
154 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
155 ..Default::default()
156 }),
157 ),
158 (
159 "namespace".to_owned(),
160 crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
161 metadata: Some(Box::new(crate::schemars::schema::Metadata {
162 description: Some("`namespace` is the namespace of the service. Required".to_owned()),
163 ..Default::default()
164 })),
165 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
166 ..Default::default()
167 }),
168 ),
169 (
170 "path".to_owned(),
171 crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
172 metadata: Some(Box::new(crate::schemars::schema::Metadata {
173 description: Some("`path` is an optional URL path which will be sent in any request to this service.".to_owned()),
174 ..Default::default()
175 })),
176 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
177 ..Default::default()
178 }),
179 ),
180 (
181 "port".to_owned(),
182 crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
183 metadata: Some(Box::new(crate::schemars::schema::Metadata {
184 description: Some("If specified, the port on the service that hosting webhook. Default to 443 for backward compatibility. `port` should be a valid port number (1-65535, inclusive).".to_owned()),
185 ..Default::default()
186 })),
187 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Integer))),
188 format: Some("int32".to_owned()),
189 ..Default::default()
190 }),
191 ),
192 ].into(),
193 required: [
194 "name".to_owned(),
195 "namespace".to_owned(),
196 ].into(),
197 ..Default::default()
198 })),
199 ..Default::default()
200 })
201 }
202}