datadog_api_client/datadogV1/model/
model_logs_schema_processor.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 LogsSchemaProcessor {
14 #[serde(rename = "is_enabled")]
16 pub is_enabled: Option<bool>,
17 #[serde(rename = "mappers")]
19 pub mappers: Vec<crate::datadogV1::model::LogsSchemaMapper>,
20 #[serde(rename = "name")]
22 pub name: String,
23 #[serde(rename = "schema")]
25 pub schema: crate::datadogV1::model::LogsSchemaData,
26 #[serde(rename = "type")]
28 pub type_: crate::datadogV1::model::LogsSchemaProcessorType,
29 #[serde(flatten)]
30 pub additional_properties: std::collections::BTreeMap<String, serde_json::Value>,
31 #[serde(skip)]
32 #[serde(default)]
33 pub(crate) _unparsed: bool,
34}
35
36impl LogsSchemaProcessor {
37 pub fn new(
38 mappers: Vec<crate::datadogV1::model::LogsSchemaMapper>,
39 name: String,
40 schema: crate::datadogV1::model::LogsSchemaData,
41 type_: crate::datadogV1::model::LogsSchemaProcessorType,
42 ) -> LogsSchemaProcessor {
43 LogsSchemaProcessor {
44 is_enabled: None,
45 mappers,
46 name,
47 schema,
48 type_,
49 additional_properties: std::collections::BTreeMap::new(),
50 _unparsed: false,
51 }
52 }
53
54 pub fn is_enabled(mut self, value: bool) -> Self {
55 self.is_enabled = Some(value);
56 self
57 }
58
59 pub fn additional_properties(
60 mut self,
61 value: std::collections::BTreeMap<String, serde_json::Value>,
62 ) -> Self {
63 self.additional_properties = value;
64 self
65 }
66}
67
68impl<'de> Deserialize<'de> for LogsSchemaProcessor {
69 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
70 where
71 D: Deserializer<'de>,
72 {
73 struct LogsSchemaProcessorVisitor;
74 impl<'a> Visitor<'a> for LogsSchemaProcessorVisitor {
75 type Value = LogsSchemaProcessor;
76
77 fn expecting(&self, f: &mut Formatter<'_>) -> fmt::Result {
78 f.write_str("a mapping")
79 }
80
81 fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
82 where
83 M: MapAccess<'a>,
84 {
85 let mut is_enabled: Option<bool> = None;
86 let mut mappers: Option<Vec<crate::datadogV1::model::LogsSchemaMapper>> = None;
87 let mut name: Option<String> = None;
88 let mut schema: Option<crate::datadogV1::model::LogsSchemaData> = None;
89 let mut type_: Option<crate::datadogV1::model::LogsSchemaProcessorType> = None;
90 let mut additional_properties: std::collections::BTreeMap<
91 String,
92 serde_json::Value,
93 > = std::collections::BTreeMap::new();
94 let mut _unparsed = false;
95
96 while let Some((k, v)) = map.next_entry::<String, serde_json::Value>()? {
97 match k.as_str() {
98 "is_enabled" => {
99 if v.is_null() {
100 continue;
101 }
102 is_enabled = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
103 }
104 "mappers" => {
105 mappers = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
106 }
107 "name" => {
108 name = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
109 }
110 "schema" => {
111 schema = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
112 }
113 "type" => {
114 type_ = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
115 if let Some(ref _type_) = type_ {
116 match _type_ {
117 crate::datadogV1::model::LogsSchemaProcessorType::UnparsedObject(_type_) => {
118 _unparsed = true;
119 },
120 _ => {}
121 }
122 }
123 }
124 &_ => {
125 if let Ok(value) = serde_json::from_value(v.clone()) {
126 additional_properties.insert(k, value);
127 }
128 }
129 }
130 }
131 let mappers = mappers.ok_or_else(|| M::Error::missing_field("mappers"))?;
132 let name = name.ok_or_else(|| M::Error::missing_field("name"))?;
133 let schema = schema.ok_or_else(|| M::Error::missing_field("schema"))?;
134 let type_ = type_.ok_or_else(|| M::Error::missing_field("type_"))?;
135
136 let content = LogsSchemaProcessor {
137 is_enabled,
138 mappers,
139 name,
140 schema,
141 type_,
142 additional_properties,
143 _unparsed,
144 };
145
146 Ok(content)
147 }
148 }
149
150 deserializer.deserialize_any(LogsSchemaProcessorVisitor)
151 }
152}