k8s_openapi/v1_36/api/apps/v1/
replica_set_spec.rs1#[derive(Clone, Debug, Default, PartialEq)]
5pub struct ReplicaSetSpec {
6 pub min_ready_seconds: Option<i32>,
8
9 pub replicas: Option<i32>,
11
12 pub selector: crate::apimachinery::pkg::apis::meta::v1::LabelSelector,
14
15 pub template: Option<crate::api::core::v1::PodTemplateSpec>,
17}
18
19impl crate::DeepMerge for ReplicaSetSpec {
20 fn merge_from(&mut self, other: Self) {
21 crate::DeepMerge::merge_from(&mut self.min_ready_seconds, other.min_ready_seconds);
22 crate::DeepMerge::merge_from(&mut self.replicas, other.replicas);
23 crate::DeepMerge::merge_from(&mut self.selector, other.selector);
24 crate::DeepMerge::merge_from(&mut self.template, other.template);
25 }
26}
27
28impl<'de> crate::serde::Deserialize<'de> for ReplicaSetSpec {
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_min_ready_seconds,
33 Key_replicas,
34 Key_selector,
35 Key_template,
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 "minReadySeconds" => Field::Key_min_ready_seconds,
53 "replicas" => Field::Key_replicas,
54 "selector" => Field::Key_selector,
55 "template" => Field::Key_template,
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 = ReplicaSetSpec;
69
70 fn expecting(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
71 f.write_str("ReplicaSetSpec")
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_min_ready_seconds: Option<i32> = None;
76 let mut value_replicas: Option<i32> = None;
77 let mut value_selector: Option<crate::apimachinery::pkg::apis::meta::v1::LabelSelector> = None;
78 let mut value_template: Option<crate::api::core::v1::PodTemplateSpec> = None;
79
80 while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
81 match key {
82 Field::Key_min_ready_seconds => value_min_ready_seconds = crate::serde::de::MapAccess::next_value(&mut map)?,
83 Field::Key_replicas => value_replicas = crate::serde::de::MapAccess::next_value(&mut map)?,
84 Field::Key_selector => value_selector = crate::serde::de::MapAccess::next_value(&mut map)?,
85 Field::Key_template => value_template = 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(ReplicaSetSpec {
91 min_ready_seconds: value_min_ready_seconds,
92 replicas: value_replicas,
93 selector: value_selector.unwrap_or_default(),
94 template: value_template,
95 })
96 }
97 }
98
99 deserializer.deserialize_struct(
100 "ReplicaSetSpec",
101 &[
102 "minReadySeconds",
103 "replicas",
104 "selector",
105 "template",
106 ],
107 Visitor,
108 )
109 }
110}
111
112impl crate::serde::Serialize for ReplicaSetSpec {
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 "ReplicaSetSpec",
116 1 +
117 self.min_ready_seconds.as_ref().map_or(0, |_| 1) +
118 self.replicas.as_ref().map_or(0, |_| 1) +
119 self.template.as_ref().map_or(0, |_| 1),
120 )?;
121 if let Some(value) = &self.min_ready_seconds {
122 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "minReadySeconds", value)?;
123 }
124 if let Some(value) = &self.replicas {
125 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "replicas", value)?;
126 }
127 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "selector", &self.selector)?;
128 if let Some(value) = &self.template {
129 crate::serde::ser::SerializeStruct::serialize_field(&mut state, "template", value)?;
130 }
131 crate::serde::ser::SerializeStruct::end(state)
132 }
133}
134
135#[cfg(feature = "schemars")]
136impl crate::schemars::JsonSchema for ReplicaSetSpec {
137 fn schema_name() -> std::borrow::Cow<'static, str> {
138 "io.k8s.api.apps.v1.ReplicaSetSpec".into()
139 }
140
141 fn json_schema(__gen: &mut crate::schemars::SchemaGenerator) -> crate::schemars::Schema {
142 crate::schemars::json_schema!({
143 "description": "ReplicaSetSpec is the specification of a ReplicaSet.",
144 "type": "object",
145 "properties": {
146 "minReadySeconds": {
147 "description": "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)",
148 "type": "integer",
149 "format": "int32",
150 },
151 "replicas": {
152 "description": "Replicas is the number of desired pods. This is a pointer to distinguish between explicit zero and unspecified. Defaults to 1. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicaset",
153 "type": "integer",
154 "format": "int32",
155 },
156 "selector": ({
157 let mut schema_obj = __gen.subschema_for::<crate::apimachinery::pkg::apis::meta::v1::LabelSelector>();
158 schema_obj.ensure_object().insert("description".into(), "Selector is a label query over pods that should match the replica count. Label keys and values that must match in order to be controlled by this replica set. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors".into());
159 schema_obj
160 }),
161 "template": ({
162 let mut schema_obj = __gen.subschema_for::<crate::api::core::v1::PodTemplateSpec>();
163 schema_obj.ensure_object().insert("description".into(), "Template is the object that describes the pod that will be created if insufficient replicas are detected. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicaset/#pod-template".into());
164 schema_obj
165 }),
166 },
167 "required": [
168 "selector",
169 ],
170 })
171 }
172}
173
174#[cfg(feature = "schemars08")]
175impl crate::schemars08::JsonSchema for ReplicaSetSpec {
176 fn schema_name() -> std::string::String {
177 "io.k8s.api.apps.v1.ReplicaSetSpec".into()
178 }
179
180 fn json_schema(__gen: &mut crate::schemars08::gen::SchemaGenerator) -> crate::schemars08::schema::Schema {
181 crate::schemars08::schema::Schema::Object(crate::schemars08::schema::SchemaObject {
182 metadata: Some(std::boxed::Box::new(crate::schemars08::schema::Metadata {
183 description: Some("ReplicaSetSpec is the specification of a ReplicaSet.".into()),
184 ..Default::default()
185 })),
186 instance_type: Some(crate::schemars08::schema::SingleOrVec::Single(std::boxed::Box::new(crate::schemars08::schema::InstanceType::Object))),
187 object: Some(std::boxed::Box::new(crate::schemars08::schema::ObjectValidation {
188 properties: [
189 (
190 "minReadySeconds".into(),
191 crate::schemars08::schema::Schema::Object(crate::schemars08::schema::SchemaObject {
192 metadata: Some(std::boxed::Box::new(crate::schemars08::schema::Metadata {
193 description: Some("Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)".into()),
194 ..Default::default()
195 })),
196 instance_type: Some(crate::schemars08::schema::SingleOrVec::Single(std::boxed::Box::new(crate::schemars08::schema::InstanceType::Integer))),
197 format: Some("int32".into()),
198 ..Default::default()
199 }),
200 ),
201 (
202 "replicas".into(),
203 crate::schemars08::schema::Schema::Object(crate::schemars08::schema::SchemaObject {
204 metadata: Some(std::boxed::Box::new(crate::schemars08::schema::Metadata {
205 description: Some("Replicas is the number of desired pods. This is a pointer to distinguish between explicit zero and unspecified. Defaults to 1. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicaset".into()),
206 ..Default::default()
207 })),
208 instance_type: Some(crate::schemars08::schema::SingleOrVec::Single(std::boxed::Box::new(crate::schemars08::schema::InstanceType::Integer))),
209 format: Some("int32".into()),
210 ..Default::default()
211 }),
212 ),
213 (
214 "selector".into(),
215 {
216 let mut schema_obj = __gen.subschema_for::<crate::apimachinery::pkg::apis::meta::v1::LabelSelector>().into_object();
217 schema_obj.metadata = Some(std::boxed::Box::new(crate::schemars08::schema::Metadata {
218 description: Some("Selector is a label query over pods that should match the replica count. Label keys and values that must match in order to be controlled by this replica set. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors".into()),
219 ..Default::default()
220 }));
221 crate::schemars08::schema::Schema::Object(schema_obj)
222 },
223 ),
224 (
225 "template".into(),
226 {
227 let mut schema_obj = __gen.subschema_for::<crate::api::core::v1::PodTemplateSpec>().into_object();
228 schema_obj.metadata = Some(std::boxed::Box::new(crate::schemars08::schema::Metadata {
229 description: Some("Template is the object that describes the pod that will be created if insufficient replicas are detected. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicaset/#pod-template".into()),
230 ..Default::default()
231 }));
232 crate::schemars08::schema::Schema::Object(schema_obj)
233 },
234 ),
235 ].into(),
236 required: [
237 "selector".into(),
238 ].into(),
239 ..Default::default()
240 })),
241 ..Default::default()
242 })
243 }
244}