datadog_api_client/datadogV1/model/
model_logs_schema_processor.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/// A processor that has additional validations and checks for a given schema. Currently supported schema types include OCSF.
10#[non_exhaustive]
11#[skip_serializing_none]
12#[derive(Clone, Debug, PartialEq, Serialize)]
13pub struct LogsSchemaProcessor {
14    /// Whether or not the processor is enabled.
15    #[serde(rename = "is_enabled")]
16    pub is_enabled: Option<bool>,
17    /// The `LogsSchemaProcessor` `mappers`.
18    #[serde(rename = "mappers")]
19    pub mappers: Vec<crate::datadogV1::model::LogsSchemaMapper>,
20    /// Name of the processor.
21    #[serde(rename = "name")]
22    pub name: String,
23    /// Configuration of the schema data to use.
24    #[serde(rename = "schema")]
25    pub schema: crate::datadogV1::model::LogsSchemaData,
26    /// Type of logs schema processor.
27    #[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}