1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
// Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License.
// This product includes software developed at Datadog (https://www.datadoghq.com/).
// Copyright 2019-Present Datadog, Inc.
use serde::de::{Error, MapAccess, Visitor};
use serde::{Deserialize, Deserializer, Serialize};
use serde_with::skip_serializing_none;
use std::fmt::{self, Formatter};
/// Calendar interval definition.
#[non_exhaustive]
#[skip_serializing_none]
#[derive(Clone, Debug, PartialEq, Serialize)]
pub struct CalendarInterval {
/// Alignment of the interval. Valid values depend on the interval type. For `day`, use hours (for example, `1am`, `2pm`, or `14`). For `week`, use day names (for example, `monday`). For `month`, use day-of-month ordinals (for example, `1st`, `15th`). For `year` or `quarter`, use month names (for example, `january`).
#[serde(rename = "alignment")]
pub alignment: Option<String>,
/// Quantity of the interval.
#[serde(rename = "quantity")]
pub quantity: Option<i64>,
/// Timezone for the interval.
#[serde(rename = "timezone")]
pub timezone: Option<String>,
/// Type of calendar interval.
#[serde(rename = "type")]
pub type_: crate::datadogV1::model::CalendarIntervalType,
#[serde(skip)]
#[serde(default)]
pub(crate) _unparsed: bool,
}
impl CalendarInterval {
pub fn new(type_: crate::datadogV1::model::CalendarIntervalType) -> CalendarInterval {
CalendarInterval {
alignment: None,
quantity: None,
timezone: None,
type_,
_unparsed: false,
}
}
pub fn alignment(mut self, value: String) -> Self {
self.alignment = Some(value);
self
}
pub fn quantity(mut self, value: i64) -> Self {
self.quantity = Some(value);
self
}
pub fn timezone(mut self, value: String) -> Self {
self.timezone = Some(value);
self
}
}
impl<'de> Deserialize<'de> for CalendarInterval {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: Deserializer<'de>,
{
struct CalendarIntervalVisitor;
impl<'a> Visitor<'a> for CalendarIntervalVisitor {
type Value = CalendarInterval;
fn expecting(&self, f: &mut Formatter<'_>) -> fmt::Result {
f.write_str("a mapping")
}
fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
where
M: MapAccess<'a>,
{
let mut alignment: Option<String> = None;
let mut quantity: Option<i64> = None;
let mut timezone: Option<String> = None;
let mut type_: Option<crate::datadogV1::model::CalendarIntervalType> = None;
let mut _unparsed = false;
while let Some((k, v)) = map.next_entry::<String, serde_json::Value>()? {
match k.as_str() {
"alignment" => {
if v.is_null() {
continue;
}
alignment = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
}
"quantity" => {
if v.is_null() {
continue;
}
quantity = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
}
"timezone" => {
if v.is_null() {
continue;
}
timezone = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
}
"type" => {
type_ = Some(serde_json::from_value(v).map_err(M::Error::custom)?);
if let Some(ref _type_) = type_ {
match _type_ {
crate::datadogV1::model::CalendarIntervalType::UnparsedObject(_type_) => {
_unparsed = true;
},
_ => {}
}
}
}
&_ => {
return Err(serde::de::Error::custom(
"Additional properties not allowed",
));
}
}
}
let type_ = type_.ok_or_else(|| M::Error::missing_field("type_"))?;
let content = CalendarInterval {
alignment,
quantity,
timezone,
type_,
_unparsed,
};
Ok(content)
}
}
deserializer.deserialize_any(CalendarIntervalVisitor)
}
}