datadog_api_client/datadogV1/model/
model_signal_state_update_request.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/// Attributes describing the change of state for a given state.
10#[non_exhaustive]
11#[skip_serializing_none]
12#[derive(Clone, Debug, PartialEq, Serialize)]
13pub struct SignalStateUpdateRequest {
14    /// Optional comment to explain why a signal is being archived.
15    #[serde(rename = "archiveComment")]
16    pub archive_comment: Option<String>,
17    /// Reason why a signal has been archived.
18    #[serde(rename = "archiveReason")]
19    pub archive_reason: Option<crate::datadogV1::model::SignalArchiveReason>,
20    /// The new triage state of the signal.
21    #[serde(rename = "state")]
22    pub state: crate::datadogV1::model::SignalTriageState,
23    /// Version of the updated signal. If server side version is higher, update will be rejected.
24    #[serde(rename = "version")]
25    pub version: Option<i64>,
26    #[serde(flatten)]
27    pub additional_properties: std::collections::BTreeMap<String, serde_json::Value>,
28    #[serde(skip)]
29    #[serde(default)]
30    pub(crate) _unparsed: bool,
31}
32
33impl SignalStateUpdateRequest {
34    pub fn new(state: crate::datadogV1::model::SignalTriageState) -> SignalStateUpdateRequest {
35        SignalStateUpdateRequest {
36            archive_comment: None,
37            archive_reason: None,
38            state,
39            version: None,
40            additional_properties: std::collections::BTreeMap::new(),
41            _unparsed: false,
42        }
43    }
44
45    pub fn archive_comment(mut self, value: String) -> Self {
46        self.archive_comment = Some(value);
47        self
48    }
49
50    pub fn archive_reason(mut self, value: crate::datadogV1::model::SignalArchiveReason) -> Self {
51        self.archive_reason = Some(value);
52        self
53    }
54
55    pub fn version(mut self, value: i64) -> Self {
56        self.version = Some(value);
57        self
58    }
59
60    pub fn additional_properties(
61        mut self,
62        value: std::collections::BTreeMap<String, serde_json::Value>,
63    ) -> Self {
64        self.additional_properties = value;
65        self
66    }
67}
68
69impl<'de> Deserialize<'de> for SignalStateUpdateRequest {
70    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
71    where
72        D: Deserializer<'de>,
73    {
74        struct SignalStateUpdateRequestVisitor;
75        impl<'a> Visitor<'a> for SignalStateUpdateRequestVisitor {
76            type Value = SignalStateUpdateRequest;
77
78            fn expecting(&self, f: &mut Formatter<'_>) -> fmt::Result {
79                f.write_str("a mapping")
80            }
81
82            fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
83            where
84                M: MapAccess<'a>,
85            {
86                let mut archive_comment: Option<String> = None;
87                let mut archive_reason: Option<crate::datadogV1::model::SignalArchiveReason> = None;
88                let mut state: Option<crate::datadogV1::model::SignalTriageState> = None;
89                let mut version: Option<i64> = 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                        "archiveComment" => {
99                            if v.is_null() {
100                                continue;
101                            }
102                            archive_comment =
103                                Some(serde_json::from_value(v).map_err(M::Error::custom)?);
104                        }
105                        "archiveReason" => {
106                            if v.is_null() {
107                                continue;
108                            }
109                            archive_reason =
110                                Some(serde_json::from_value(v).map_err(M::Error::custom)?);
111                            if let Some(ref _archive_reason) = archive_reason {
112                                match _archive_reason {
113                                    crate::datadogV1::model::SignalArchiveReason::UnparsedObject(_archive_reason) => {
114                                        _unparsed = true;
115                                    },
116                                    _ => {}
117                                }
118                            }
119                        }
120                        "state" => {
121                            state = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
122                            if let Some(ref _state) = state {
123                                match _state {
124                                    crate::datadogV1::model::SignalTriageState::UnparsedObject(
125                                        _state,
126                                    ) => {
127                                        _unparsed = true;
128                                    }
129                                    _ => {}
130                                }
131                            }
132                        }
133                        "version" => {
134                            if v.is_null() {
135                                continue;
136                            }
137                            version = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
138                        }
139                        &_ => {
140                            if let Ok(value) = serde_json::from_value(v.clone()) {
141                                additional_properties.insert(k, value);
142                            }
143                        }
144                    }
145                }
146                let state = state.ok_or_else(|| M::Error::missing_field("state"))?;
147
148                let content = SignalStateUpdateRequest {
149                    archive_comment,
150                    archive_reason,
151                    state,
152                    version,
153                    additional_properties,
154                    _unparsed,
155                };
156
157                Ok(content)
158            }
159        }
160
161        deserializer.deserialize_any(SignalStateUpdateRequestVisitor)
162    }
163}