datadog_api_client/datadogV2/model/
model_datadog_integration.rs1use serde::de::{Error, MapAccess, Visitor};
5use serde::{Deserialize, Deserializer, Serialize};
6use serde_with::skip_serializing_none;
7use std::fmt::{self, Formatter};
8
9#[non_exhaustive]
11#[skip_serializing_none]
12#[derive(Clone, Debug, PartialEq, Serialize)]
13pub struct DatadogIntegration {
14 #[serde(rename = "credentials")]
16 pub credentials: crate::datadogV2::model::DatadogCredentials,
17 #[serde(rename = "type")]
19 pub type_: crate::datadogV2::model::DatadogIntegrationType,
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 DatadogIntegration {
28 pub fn new(
29 credentials: crate::datadogV2::model::DatadogCredentials,
30 type_: crate::datadogV2::model::DatadogIntegrationType,
31 ) -> DatadogIntegration {
32 DatadogIntegration {
33 credentials,
34 type_,
35 additional_properties: std::collections::BTreeMap::new(),
36 _unparsed: false,
37 }
38 }
39
40 pub fn additional_properties(
41 mut self,
42 value: std::collections::BTreeMap<String, serde_json::Value>,
43 ) -> Self {
44 self.additional_properties = value;
45 self
46 }
47}
48
49impl<'de> Deserialize<'de> for DatadogIntegration {
50 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
51 where
52 D: Deserializer<'de>,
53 {
54 struct DatadogIntegrationVisitor;
55 impl<'a> Visitor<'a> for DatadogIntegrationVisitor {
56 type Value = DatadogIntegration;
57
58 fn expecting(&self, f: &mut Formatter<'_>) -> fmt::Result {
59 f.write_str("a mapping")
60 }
61
62 fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
63 where
64 M: MapAccess<'a>,
65 {
66 let mut credentials: Option<crate::datadogV2::model::DatadogCredentials> = None;
67 let mut type_: Option<crate::datadogV2::model::DatadogIntegrationType> = None;
68 let mut additional_properties: std::collections::BTreeMap<
69 String,
70 serde_json::Value,
71 > = std::collections::BTreeMap::new();
72 let mut _unparsed = false;
73
74 while let Some((k, v)) = map.next_entry::<String, serde_json::Value>()? {
75 match k.as_str() {
76 "credentials" => {
77 credentials =
78 Some(serde_json::from_value(v).map_err(M::Error::custom)?);
79 if let Some(ref _credentials) = credentials {
80 match _credentials {
81 crate::datadogV2::model::DatadogCredentials::UnparsedObject(
82 _credentials,
83 ) => {
84 _unparsed = true;
85 }
86 _ => {}
87 }
88 }
89 }
90 "type" => {
91 type_ = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
92 if let Some(ref _type_) = type_ {
93 match _type_ {
94 crate::datadogV2::model::DatadogIntegrationType::UnparsedObject(_type_) => {
95 _unparsed = true;
96 },
97 _ => {}
98 }
99 }
100 }
101 &_ => {
102 if let Ok(value) = serde_json::from_value(v.clone()) {
103 additional_properties.insert(k, value);
104 }
105 }
106 }
107 }
108 let credentials =
109 credentials.ok_or_else(|| M::Error::missing_field("credentials"))?;
110 let type_ = type_.ok_or_else(|| M::Error::missing_field("type_"))?;
111
112 let content = DatadogIntegration {
113 credentials,
114 type_,
115 additional_properties,
116 _unparsed,
117 };
118
119 Ok(content)
120 }
121 }
122
123 deserializer.deserialize_any(DatadogIntegrationVisitor)
124 }
125}