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}