datadog_api_client/datadogV2/model/
model_case_assign.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/// Case assign
10#[non_exhaustive]
11#[skip_serializing_none]
12#[derive(Clone, Debug, PartialEq, Serialize)]
13pub struct CaseAssign {
14    /// Case assign attributes
15    #[serde(rename = "attributes")]
16    pub attributes: crate::datadogV2::model::CaseAssignAttributes,
17    /// Case resource type
18    #[serde(rename = "type")]
19    pub type_: crate::datadogV2::model::CaseResourceType,
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 CaseAssign {
28    pub fn new(
29        attributes: crate::datadogV2::model::CaseAssignAttributes,
30        type_: crate::datadogV2::model::CaseResourceType,
31    ) -> CaseAssign {
32        CaseAssign {
33            attributes,
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 CaseAssign {
50    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
51    where
52        D: Deserializer<'de>,
53    {
54        struct CaseAssignVisitor;
55        impl<'a> Visitor<'a> for CaseAssignVisitor {
56            type Value = CaseAssign;
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 attributes: Option<crate::datadogV2::model::CaseAssignAttributes> = None;
67                let mut type_: Option<crate::datadogV2::model::CaseResourceType> = 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                        "attributes" => {
77                            attributes = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
78                        }
79                        "type" => {
80                            type_ = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
81                            if let Some(ref _type_) = type_ {
82                                match _type_ {
83                                    crate::datadogV2::model::CaseResourceType::UnparsedObject(
84                                        _type_,
85                                    ) => {
86                                        _unparsed = true;
87                                    }
88                                    _ => {}
89                                }
90                            }
91                        }
92                        &_ => {
93                            if let Ok(value) = serde_json::from_value(v.clone()) {
94                                additional_properties.insert(k, value);
95                            }
96                        }
97                    }
98                }
99                let attributes = attributes.ok_or_else(|| M::Error::missing_field("attributes"))?;
100                let type_ = type_.ok_or_else(|| M::Error::missing_field("type_"))?;
101
102                let content = CaseAssign {
103                    attributes,
104                    type_,
105                    additional_properties,
106                    _unparsed,
107                };
108
109                Ok(content)
110            }
111        }
112
113        deserializer.deserialize_any(CaseAssignVisitor)
114    }
115}