aw_test/models/
usage_database.rs1#![allow(unused)]
2use serde::{Deserialize, Serialize, Deserializer};
3use std::collections::HashMap;
4use serde_json::value::Value;
5use std::fmt::Display;
6use super::*;
7
8#[derive(Debug, Serialize, Clone)]
9#[serde(deny_unknown_fields)]
10#[serde(untagged)]
11pub enum EmptyOption<T> {
12 Some(T),
13 None {},
14}
15
16impl<T> Display for EmptyOption<T>
17where
18 T: Display,
19{
20 fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
21 match self {
22 EmptyOption::Some(t) => write!(f, "{}", t),
23 EmptyOption::None {} => write!(f, ""),
24 }
25 }
26}
27
28impl<'de, T> Deserialize<'de> for EmptyOption<T>
29where
30 T: Deserialize<'de>,
31{
32 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
33 where
34 D: Deserializer<'de>,
35 {
36 Option::deserialize(deserializer).map(Into::into)
37 }
38}
39
40impl<T> From<EmptyOption<T>> for Option<T> {
41 fn from(empty_option: EmptyOption<T>) -> Option<T> {
42 match empty_option {
43 EmptyOption::Some(option) => Some(option),
44 EmptyOption::None {} => None,
45 }
46 }
47}
48
49impl<T> From<Option<T>> for EmptyOption<T> {
50 fn from(option: Option<T>) -> EmptyOption<T> {
51 match option {
52 Some(option) => EmptyOption::Some(option),
53 None {} => EmptyOption::None {},
54 }
55 }
56}
57
58impl<T> EmptyOption<T> {
59 fn into_option(self) -> Option<T> {
60 self.into()
61 }
62 fn as_option(&self) -> Option<&T> {
63 match self {
64 EmptyOption::Some(option) => Some(option),
65 EmptyOption::None {} => None,
66 }
67 }
68}
69
70#[derive(Serialize, Deserialize, Debug, Clone)]
71pub struct UsageDatabase {
72 pub range: String,
73 pub documentsCount: Vec<MetricList>,
74 pub collectionsCount: Vec<MetricList>,
75 pub documentsCreate: Vec<MetricList>,
76 pub documentsRead: Vec<MetricList>,
77 pub documentsUpdate: Vec<MetricList>,
78 pub documentsDelete: Vec<MetricList>,
79 pub collectionsCreate: Vec<MetricList>,
80 pub collectionsRead: Vec<MetricList>,
81 pub collectionsUpdate: Vec<MetricList>,
82 pub collectionsDelete: Vec<MetricList>,
83}
84
85impl Display for UsageDatabase {
86 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
87 let mut formatBuffer = String::new();
88 formatBuffer.push_str(&format!("{:?}", self.range));
89 for item in &self.documentsCount {
90 formatBuffer.push_str(&format!("{:?}", item));
91 }
92 for item in &self.collectionsCount {
93 formatBuffer.push_str(&format!("{:?}", item));
94 }
95 for item in &self.documentsCreate {
96 formatBuffer.push_str(&format!("{:?}", item));
97 }
98 for item in &self.documentsRead {
99 formatBuffer.push_str(&format!("{:?}", item));
100 }
101 for item in &self.documentsUpdate {
102 formatBuffer.push_str(&format!("{:?}", item));
103 }
104 for item in &self.documentsDelete {
105 formatBuffer.push_str(&format!("{:?}", item));
106 }
107 for item in &self.collectionsCreate {
108 formatBuffer.push_str(&format!("{:?}", item));
109 }
110 for item in &self.collectionsRead {
111 formatBuffer.push_str(&format!("{:?}", item));
112 }
113 for item in &self.collectionsUpdate {
114 formatBuffer.push_str(&format!("{:?}", item));
115 }
116 for item in &self.collectionsDelete {
117 formatBuffer.push_str(&format!("{:?}", item));
118 }
119
120 write!(f, "{}", formatBuffer)
121 }
122}
123
124impl UsageDatabase {
125 pub fn new(range: String, documentsCount: Vec<MetricList>, collectionsCount: Vec<MetricList>, documentsCreate: Vec<MetricList>, documentsRead: Vec<MetricList>, documentsUpdate: Vec<MetricList>, documentsDelete: Vec<MetricList>, collectionsCreate: Vec<MetricList>, collectionsRead: Vec<MetricList>, collectionsUpdate: Vec<MetricList>, collectionsDelete: Vec<MetricList>, ) -> Self {
126 Self {
127 range: range,
128 documentsCount: documentsCount,
129 collectionsCount: collectionsCount,
130 documentsCreate: documentsCreate,
131 documentsRead: documentsRead,
132 documentsUpdate: documentsUpdate,
133 documentsDelete: documentsDelete,
134 collectionsCreate: collectionsCreate,
135 collectionsRead: collectionsRead,
136 collectionsUpdate: collectionsUpdate,
137 collectionsDelete: collectionsDelete,
138 }
139 }
140}