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
/// 3.2.13 Object: Site
///
/// This object should be included if the ad supported content is a website as opposed to a
/// non-browser application. A bid request must not contain both a Site and an App object. At a
/// minimum, it is useful to provide a site ID or page URL, but this is not strictly required.
#[derive(serde::Serialize, serde::Deserialize, Default, Debug, PartialEq, Clone)]
pub struct Site {
/// string; recommended
/// Exchange-specific site ID.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
/// string
/// Site name (may be aliased at the publisher’s request).
#[serde(default, skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
/// string
/// Domain of the site (e.g., “mysite.foo.com”).
#[serde(default, skip_serializing_if = "Option::is_none")]
pub domain: Option<String>,
/// string array
/// Array of IAB content categories of the site. Refer to List 5.1.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub cat: Option<Vec<crate::ContentCategory>>,
/// string array
/// Array of IAB content categories that describe the current section of the site. Refer to
/// List 5.1.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub sectioncat: Option<Vec<crate::ContentCategory>>,
/// string array
/// Array of IAB content categories that describe the current page or view of the site. Refer
/// to List 5.1.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub pagecat: Option<Vec<crate::ContentCategory>>,
/// string
/// URL of the page where the impression will be shown.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub page: Option<String>,
/// string
/// Referrer URL that caused navigation to the current page.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub r#ref: Option<String>,
/// string
/// Search string that caused navigation to the current page.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub search: Option<String>,
/// integer
/// Indicates if the site has been programmed to optimize layout when viewed on mobile devices,
/// where 0 = no, 1 = yes.
#[serde(
default,
skip_serializing_if = "Option::is_none",
with = "crate::serde::i32_as_opt_bool"
)]
pub mobile: Option<bool>,
/// integer
/// Indicates if the site has a privacy policy, where 0 = no, 1 = yes.
#[serde(
default,
skip_serializing_if = "Option::is_none",
with = "crate::serde::i32_as_opt_bool"
)]
pub privacypolicy: Option<bool>,
/// object
/// Details about the Publisher (Section 3.2.15) of the site.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub publisher: Option<crate::Publisher>,
/// object
/// Details about the Content (Section 3.2.16) within the site.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub content: Option<crate::Content>,
/// string
/// Comma separated list of keywords about the site.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub keywords: Option<String>,
/// object
/// Placeholder for exchange-specific extensions to OpenRTB.
#[serde(default, skip_serializing_if = "Option::is_none")]
pub ext: Option<serde_json::Map<String, serde_json::Value>>,
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn json() -> serde_json::Result<()> {
let json = "{}";
let o1 = Site::default();
assert_eq!(serde_json::to_string(&o1)?, json);
assert_eq!(o1, serde_json::from_str::<Site>(json)?);
Ok(())
}
}