Skip to main content

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

1// Generated from definition com.github.openshift.api.build.v1.GitLabWebHookCause
2
3/// GitLabWebHookCause has information about a GitLab webhook that triggered a build.
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct GitLabWebHookCause {
6    /// Revision is the git source revision information of the trigger.
7    pub revision: Option<crate::api::build::v1::SourceRevision>,
8
9    /// Secret is the obfuscated webhook secret that triggered a build.
10    pub secret: Option<String>,
11}
12
13impl<'de> serde::Deserialize<'de> for GitLabWebHookCause {
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_revision,
18            Key_secret,
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                            "revision" => Field::Key_revision,
36                            "secret" => Field::Key_secret,
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 = GitLabWebHookCause;
50
51            fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
52                f.write_str("GitLabWebHookCause")
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_revision: Option<crate::api::build::v1::SourceRevision> = None;
57                let mut value_secret: Option<String> = None;
58
59                while let Some(key) = serde::de::MapAccess::next_key::<Field>(&mut map)? {
60                    match key {
61                        Field::Key_revision => value_revision = serde::de::MapAccess::next_value(&mut map)?,
62                        Field::Key_secret => value_secret = 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(GitLabWebHookCause {
68                    revision: value_revision,
69                    secret: value_secret,
70                })
71            }
72        }
73
74        deserializer.deserialize_struct(
75            "GitLabWebHookCause",
76            &[
77                "revision",
78                "secret",
79            ],
80            Visitor,
81        )
82    }
83}
84
85impl serde::Serialize for GitLabWebHookCause {
86    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
87        let mut state = serializer.serialize_struct(
88            "GitLabWebHookCause",
89            self.revision.as_ref().map_or(0, |_| 1) +
90            self.secret.as_ref().map_or(0, |_| 1),
91        )?;
92        if let Some(value) = &self.revision {
93            serde::ser::SerializeStruct::serialize_field(&mut state, "revision", value)?;
94        }
95        if let Some(value) = &self.secret {
96            serde::ser::SerializeStruct::serialize_field(&mut state, "secret", value)?;
97        }
98        serde::ser::SerializeStruct::end(state)
99    }
100}