openshift_openapi/v4_5/api/build/v1/
image_change_cause.rs

1// Generated from definition com.github.openshift.api.build.v1.ImageChangeCause
2
3/// ImageChangeCause contains information about the image that triggered a build
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct ImageChangeCause {
6    /// fromRef contains detailed information about an image that triggered a build.
7    pub from_ref: Option<k8s_openapi::api::core::v1::ObjectReference>,
8
9    /// imageID is the ID of the image that triggered a a new build.
10    pub image_id: Option<String>,
11}
12
13impl<'de> serde::Deserialize<'de> for ImageChangeCause {
14    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
15        #[allow(non_camel_case_types)]
16        enum Field {
17            Key_from_ref,
18            Key_image_id,
19            Other,
20        }
21
22        impl<'de> serde::Deserialize<'de> for Field {
23            fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
24                struct Visitor;
25
26                impl<'de> serde::de::Visitor<'de> for Visitor {
27                    type Value = Field;
28
29                    fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
30                        f.write_str("field identifier")
31                    }
32
33                    fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: serde::de::Error {
34                        Ok(match v {
35                            "fromRef" => Field::Key_from_ref,
36                            "imageID" => Field::Key_image_id,
37                            _ => Field::Other,
38                        })
39                    }
40                }
41
42                deserializer.deserialize_identifier(Visitor)
43            }
44        }
45
46        struct Visitor;
47
48        impl<'de> serde::de::Visitor<'de> for Visitor {
49            type Value = ImageChangeCause;
50
51            fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
52                f.write_str("ImageChangeCause")
53            }
54
55            fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: serde::de::MapAccess<'de> {
56                let mut value_from_ref: Option<k8s_openapi::api::core::v1::ObjectReference> = None;
57                let mut value_image_id: Option<String> = None;
58
59                while let Some(key) = serde::de::MapAccess::next_key::<Field>(&mut map)? {
60                    match key {
61                        Field::Key_from_ref => value_from_ref = serde::de::MapAccess::next_value(&mut map)?,
62                        Field::Key_image_id => value_image_id = serde::de::MapAccess::next_value(&mut map)?,
63                        Field::Other => { let _: serde::de::IgnoredAny = serde::de::MapAccess::next_value(&mut map)?; },
64                    }
65                }
66
67                Ok(ImageChangeCause {
68                    from_ref: value_from_ref,
69                    image_id: value_image_id,
70                })
71            }
72        }
73
74        deserializer.deserialize_struct(
75            "ImageChangeCause",
76            &[
77                "fromRef",
78                "imageID",
79            ],
80            Visitor,
81        )
82    }
83}
84
85impl serde::Serialize for ImageChangeCause {
86    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
87        let mut state = serializer.serialize_struct(
88            "ImageChangeCause",
89            self.from_ref.as_ref().map_or(0, |_| 1) +
90            self.image_id.as_ref().map_or(0, |_| 1),
91        )?;
92        if let Some(value) = &self.from_ref {
93            serde::ser::SerializeStruct::serialize_field(&mut state, "fromRef", value)?;
94        }
95        if let Some(value) = &self.image_id {
96            serde::ser::SerializeStruct::serialize_field(&mut state, "imageID", value)?;
97        }
98        serde::ser::SerializeStruct::end(state)
99    }
100}