1// Generated from definition io.k8s.api.autoscaling.v2.ResourceMetricSource
23/// ResourceMetricSource indicates how to scale on a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory). The values will be averaged together before being compared to the target. Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the "pods" source. Only one "target" type should be set.
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct ResourceMetricSource {
6/// name is the name of the resource in question.
7pub name: String,
89/// target specifies the target value for the given metric
10pub target: crate::api::autoscaling::v2::MetricTarget,
11}
1213impl crate::DeepMerge for ResourceMetricSource {
14fn merge_from(&mut self, other: Self) {
15crate::DeepMerge::merge_from(&mut self.name, other.name);
16crate::DeepMerge::merge_from(&mut self.target, other.target);
17 }
18}
1920impl<'de> crate::serde::Deserialize<'de> for ResourceMetricSource {
21fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
22#[allow(non_camel_case_types)]
23enum Field {
24 Key_name,
25 Key_target,
26 Other,
27 }
2829impl<'de> crate::serde::Deserialize<'de> for Field {
30fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
31struct Visitor;
3233impl<'de> crate::serde::de::Visitor<'de> for Visitor {
34type Value = Field;
3536fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
37 f.write_str("field identifier")
38 }
3940fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: crate::serde::de::Error {
41Ok(match v {
42"name" => Field::Key_name,
43"target" => Field::Key_target,
44_ => Field::Other,
45 })
46 }
47 }
4849 deserializer.deserialize_identifier(Visitor)
50 }
51 }
5253struct Visitor;
5455impl<'de> crate::serde::de::Visitor<'de> for Visitor {
56type Value = ResourceMetricSource;
5758fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
59 f.write_str("ResourceMetricSource")
60 }
6162fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: crate::serde::de::MapAccess<'de> {
63let mut value_name: Option<String> = None;
64let mut value_target: Option<crate::api::autoscaling::v2::MetricTarget> = None;
6566while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
67match key {
68 Field::Key_name => value_name = crate::serde::de::MapAccess::next_value(&mut map)?,
69 Field::Key_target => value_target = 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 }
7374Ok(ResourceMetricSource {
75 name: value_name.unwrap_or_default(),
76 target: value_target.unwrap_or_default(),
77 })
78 }
79 }
8081 deserializer.deserialize_struct(
82"ResourceMetricSource",
83&[
84"name",
85"target",
86 ],
87 Visitor,
88 )
89 }
90}
9192impl crate::serde::Serialize for ResourceMetricSource {
93fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
94let mut state = serializer.serialize_struct(
95"ResourceMetricSource",
962,
97 )?;
98crate::serde::ser::SerializeStruct::serialize_field(&mut state, "name", &self.name)?;
99crate::serde::ser::SerializeStruct::serialize_field(&mut state, "target", &self.target)?;
100crate::serde::ser::SerializeStruct::end(state)
101 }
102}
103104#[cfg(feature = "schemars")]
105impl crate::schemars::JsonSchema for ResourceMetricSource {
106fn schema_name() -> String {
107"io.k8s.api.autoscaling.v2.ResourceMetricSource".to_owned()
108 }
109110fn json_schema(__gen: &mut crate::schemars::gen::SchemaGenerator) -> crate::schemars::schema::Schema {
111crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
112 metadata: Some(Box::new(crate::schemars::schema::Metadata {
113 description: Some("ResourceMetricSource indicates how to scale on a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory). The values will be averaged together before being compared to the target. Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source. Only one \"target\" type should be set.".to_owned()),
114 ..Default::default()
115 })),
116 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Object))),
117 object: Some(Box::new(crate::schemars::schema::ObjectValidation {
118 properties: [
119 (
120"name".to_owned(),
121crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
122 metadata: Some(Box::new(crate::schemars::schema::Metadata {
123 description: Some("name is the name of the resource in question.".to_owned()),
124 ..Default::default()
125 })),
126 instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
127 ..Default::default()
128 }),
129 ),
130 (
131"target".to_owned(),
132 {
133let mut schema_obj = __gen.subschema_for::<crate::api::autoscaling::v2::MetricTarget>().into_object();
134 schema_obj.metadata = Some(Box::new(crate::schemars::schema::Metadata {
135 description: Some("target specifies the target value for the given metric".to_owned()),
136 ..Default::default()
137 }));
138crate::schemars::schema::Schema::Object(schema_obj)
139 },
140 ),
141 ].into(),
142 required: [
143"name".to_owned(),
144"target".to_owned(),
145 ].into(),
146 ..Default::default()
147 })),
148 ..Default::default()
149 })
150 }
151}