datadog_api_client/datadogV2/model/
model_zoom_configuration_reference_data.rs

1// Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License.
2// This product includes software developed at Datadog (https://www.datadoghq.com/).
3// Copyright 2019-Present Datadog, Inc.
4use serde::de::{Error, MapAccess, Visitor};
5use serde::{Deserialize, Deserializer, Serialize};
6use serde_with::skip_serializing_none;
7use std::fmt::{self, Formatter};
8
9/// The Zoom configuration relationship data object.
10#[non_exhaustive]
11#[skip_serializing_none]
12#[derive(Clone, Debug, PartialEq, Serialize)]
13pub struct ZoomConfigurationReferenceData {
14    /// The unique identifier of the Zoom configuration.
15    #[serde(rename = "id")]
16    pub id: String,
17    /// The type of the Zoom configuration.
18    #[serde(rename = "type")]
19    pub type_: String,
20    #[serde(flatten)]
21    pub additional_properties: std::collections::BTreeMap<String, serde_json::Value>,
22    #[serde(skip)]
23    #[serde(default)]
24    pub(crate) _unparsed: bool,
25}
26
27impl ZoomConfigurationReferenceData {
28    pub fn new(id: String, type_: String) -> ZoomConfigurationReferenceData {
29        ZoomConfigurationReferenceData {
30            id,
31            type_,
32            additional_properties: std::collections::BTreeMap::new(),
33            _unparsed: false,
34        }
35    }
36
37    pub fn additional_properties(
38        mut self,
39        value: std::collections::BTreeMap<String, serde_json::Value>,
40    ) -> Self {
41        self.additional_properties = value;
42        self
43    }
44}
45
46impl<'de> Deserialize<'de> for ZoomConfigurationReferenceData {
47    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
48    where
49        D: Deserializer<'de>,
50    {
51        struct ZoomConfigurationReferenceDataVisitor;
52        impl<'a> Visitor<'a> for ZoomConfigurationReferenceDataVisitor {
53            type Value = ZoomConfigurationReferenceData;
54
55            fn expecting(&self, f: &mut Formatter<'_>) -> fmt::Result {
56                f.write_str("a mapping")
57            }
58
59            fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
60            where
61                M: MapAccess<'a>,
62            {
63                let mut id: Option<String> = None;
64                let mut type_: Option<String> = None;
65                let mut additional_properties: std::collections::BTreeMap<
66                    String,
67                    serde_json::Value,
68                > = std::collections::BTreeMap::new();
69                let mut _unparsed = false;
70
71                while let Some((k, v)) = map.next_entry::<String, serde_json::Value>()? {
72                    match k.as_str() {
73                        "id" => {
74                            id = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
75                        }
76                        "type" => {
77                            type_ = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
78                        }
79                        &_ => {
80                            if let Ok(value) = serde_json::from_value(v.clone()) {
81                                additional_properties.insert(k, value);
82                            }
83                        }
84                    }
85                }
86                let id = id.ok_or_else(|| M::Error::missing_field("id"))?;
87                let type_ = type_.ok_or_else(|| M::Error::missing_field("type_"))?;
88
89                let content = ZoomConfigurationReferenceData {
90                    id,
91                    type_,
92                    additional_properties,
93                    _unparsed,
94                };
95
96                Ok(content)
97            }
98        }
99
100        deserializer.deserialize_any(ZoomConfigurationReferenceDataVisitor)
101    }
102}