aw_test/models/
bucket.rs

1#![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 Bucket {
72        #[serde(rename(serialize = "id", deserialize = "$id"))]
73        pub id: String,
74        #[serde(rename(serialize = "read", deserialize = "$read"))]
75        pub read: Vec<String>,
76        #[serde(rename(serialize = "write", deserialize = "$write"))]
77        pub write: Vec<String>,
78        pub permission: String,
79        pub dateCreated: i64,
80        pub dateUpdated: i64,
81        pub name: String,
82        pub enabled: bool,
83        pub maximumFileSize: i64,
84        pub allowedFileExtensions: Vec<String>,
85        pub encryption: bool,
86        pub antivirus: bool,
87}
88
89impl Display for Bucket {
90    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
91        let mut formatBuffer = String::new();
92        formatBuffer.push_str(&format!("{:?}", self.id));
93        for item in &self.read {
94            formatBuffer.push_str(&format!("{:?}", item));
95        }
96        for item in &self.write {
97            formatBuffer.push_str(&format!("{:?}", item));
98        }
99        formatBuffer.push_str(&format!("{:?}", self.permission));
100        formatBuffer.push_str(&format!("{:?}", self.dateCreated));
101        formatBuffer.push_str(&format!("{:?}", self.dateUpdated));
102        formatBuffer.push_str(&format!("{:?}", self.name));
103        formatBuffer.push_str(&format!("{:?}", self.enabled));
104        formatBuffer.push_str(&format!("{:?}", self.maximumFileSize));
105        for item in &self.allowedFileExtensions {
106            formatBuffer.push_str(&format!("{:?}", item));
107        }
108        formatBuffer.push_str(&format!("{:?}", self.encryption));
109        formatBuffer.push_str(&format!("{:?}", self.antivirus));
110
111        write!(f, "{}", formatBuffer)
112    }
113}
114
115impl Bucket {
116    pub fn new(id: String, read: Vec<String>, write: Vec<String>, permission: String, dateCreated: i64, dateUpdated: i64, name: String, enabled: bool, maximumFileSize: i64, allowedFileExtensions: Vec<String>, encryption: bool, antivirus: bool, ) -> Self {
117        Self {
118            id: id,
119            read: read,
120            write: write,
121            permission: permission,
122            dateCreated: dateCreated,
123            dateUpdated: dateUpdated,
124            name: name,
125            enabled: enabled,
126            maximumFileSize: maximumFileSize,
127            allowedFileExtensions: allowedFileExtensions,
128            encryption: encryption,
129            antivirus: antivirus,
130            }
131    }
132}