openshift_openapi/v4_5/api/authorization/v1/
user_restriction.rs

1// Generated from definition com.github.openshift.api.authorization.v1.UserRestriction
2
3/// UserRestriction matches a user either by a string match on the user name, a string match on the name of a group to which the user belongs, or a label selector applied to the user labels.
4#[derive(Clone, Debug, Default, PartialEq)]
5pub struct UserRestriction {
6    /// Groups specifies a list of literal group names.
7    pub groups: Vec<String>,
8
9    /// Selectors specifies a list of label selectors over user labels.
10    pub labels: Vec<k8s_openapi::apimachinery::pkg::apis::meta::v1::LabelSelector>,
11
12    /// Users specifies a list of literal user names.
13    pub users: Vec<String>,
14}
15
16impl<'de> serde::Deserialize<'de> for UserRestriction {
17    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
18        #[allow(non_camel_case_types)]
19        enum Field {
20            Key_groups,
21            Key_labels,
22            Key_users,
23            Other,
24        }
25
26        impl<'de> serde::Deserialize<'de> for Field {
27            fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
28                struct Visitor;
29
30                impl<'de> serde::de::Visitor<'de> for Visitor {
31                    type Value = Field;
32
33                    fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
34                        f.write_str("field identifier")
35                    }
36
37                    fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: serde::de::Error {
38                        Ok(match v {
39                            "groups" => Field::Key_groups,
40                            "labels" => Field::Key_labels,
41                            "users" => Field::Key_users,
42                            _ => Field::Other,
43                        })
44                    }
45                }
46
47                deserializer.deserialize_identifier(Visitor)
48            }
49        }
50
51        struct Visitor;
52
53        impl<'de> serde::de::Visitor<'de> for Visitor {
54            type Value = UserRestriction;
55
56            fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
57                f.write_str("UserRestriction")
58            }
59
60            fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: serde::de::MapAccess<'de> {
61                let mut value_groups: Option<Vec<String>> = None;
62                let mut value_labels: Option<Vec<k8s_openapi::apimachinery::pkg::apis::meta::v1::LabelSelector>> = None;
63                let mut value_users: Option<Vec<String>> = None;
64
65                while let Some(key) = serde::de::MapAccess::next_key::<Field>(&mut map)? {
66                    match key {
67                        Field::Key_groups => value_groups = Some(serde::de::MapAccess::next_value(&mut map)?),
68                        Field::Key_labels => value_labels = Some(serde::de::MapAccess::next_value(&mut map)?),
69                        Field::Key_users => value_users = Some(serde::de::MapAccess::next_value(&mut map)?),
70                        Field::Other => { let _: serde::de::IgnoredAny = serde::de::MapAccess::next_value(&mut map)?; },
71                    }
72                }
73
74                Ok(UserRestriction {
75                    groups: value_groups.ok_or_else(|| serde::de::Error::missing_field("groups"))?,
76                    labels: value_labels.ok_or_else(|| serde::de::Error::missing_field("labels"))?,
77                    users: value_users.ok_or_else(|| serde::de::Error::missing_field("users"))?,
78                })
79            }
80        }
81
82        deserializer.deserialize_struct(
83            "UserRestriction",
84            &[
85                "groups",
86                "labels",
87                "users",
88            ],
89            Visitor,
90        )
91    }
92}
93
94impl serde::Serialize for UserRestriction {
95    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
96        let mut state = serializer.serialize_struct(
97            "UserRestriction",
98            3,
99        )?;
100        serde::ser::SerializeStruct::serialize_field(&mut state, "groups", &self.groups)?;
101        serde::ser::SerializeStruct::serialize_field(&mut state, "labels", &self.labels)?;
102        serde::ser::SerializeStruct::serialize_field(&mut state, "users", &self.users)?;
103        serde::ser::SerializeStruct::end(state)
104    }
105}