k8s_openapi/v1_32/api/admissionregistration/v1/
service_reference.rs

1// Generated from definition io.k8s.api.admissionregistration.v1.ServiceReference
2
3/// ServiceReference holds a reference to Service.legacy.k8s.io
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct ServiceReference {
6    /// `name` is the name of the service. Required
7    pub name: String,
8
9    /// `namespace` is the namespace of the service. Required
10    pub namespace: String,
11
12    /// `path` is an optional URL path which will be sent in any request to this service.
13    pub path: Option<String>,
14
15    /// 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).
16    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}