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
use serde::{Deserialize, Serialize};
use crate::{descriptor::ObjectDescriptor, object::core::{ObjectRawData, ObjectVersion}, ObjectType, TagDescriptor};
#[derive(Debug, Serialize, Deserialize, PartialEq, Clone)]
pub struct Message {
pub sequence_number: u64,
pub acknowledgment_number: u64,
pub changes: Vec<Change>,
}
#[derive(Debug, Serialize, Deserialize, PartialEq, Clone)]
#[serde(tag = "change")]
pub enum Change {
Options(OptionsChange),
Object(ObjectChange),
Tag(TagChange),
}
#[derive(Debug, Serialize, Deserialize, PartialEq, Clone)]
pub struct OptionsChange {
pub name: Option<String>,
pub custom: Option<serde_json::Value>,
pub expose_capacity: Option<u32>,
pub expose_load_limit: Option<u32>,
pub diff_request: Option<Option<bool>>,
}
#[derive(Debug, Serialize, Deserialize, Eq, PartialEq, Clone)]
pub enum DataChange {
Data { data: ObjectRawData },
Diff { old_data_version: Option<ObjectVersion>, diff: ObjectRawData },
}
#[derive(Debug, Serialize, Deserialize, Eq, PartialEq, Clone)]
pub struct ObjectChange {
pub descriptor: ObjectDescriptor,
pub observer: Option<bool>,
pub exposer: Option<bool>,
pub data: Option<DataChange>,
pub data_type: Option<ObjectType>,
pub data_version: Option<ObjectVersion>,
pub cost: Option<Option<u32>>,
}
#[derive(Debug, Serialize, Deserialize, Eq, PartialEq, Clone)]
pub struct TagChange {
pub descriptor: TagDescriptor,
pub observer: Option<bool>,
pub exposer: Option<bool>,
pub cost: Option<Option<u32>>,
}
impl ObjectChange {
pub fn is_empty(&self) -> bool {
!(self.observer.is_some() || self.exposer.is_some() || self.data.is_some() || self.data_type.is_some() || self.data_version.is_some())
}
}
impl TagChange {
pub fn is_empty(&self) -> bool {
!(self.observer.is_some() || self.exposer.is_some())
}
}
#[cfg(test)]
mod tests {
use std::sync::Arc;
use super::*;
#[test]
fn can_serialie_and_deserialize_message() {
let message = Message {
sequence_number: 1,
acknowledgment_number: 2,
changes: vec![Change::Object(ObjectChange {
descriptor: (vec!["{}"], "{}").into(),
observer: Some(true),
exposer: Some(true),
data: Some(DataChange::Data { data: Arc::new(b"aaaaa".to_vec()) }),
data_type: None,
data_version: None,
cost: None,
})],
};
let serialized = serde_json::to_string(&message).unwrap();
println!("{}", serialized);
let deserialized: Message = serde_json::from_str(&serialized).unwrap();
assert_eq!(message, deserialized);
let serialized = serde_yaml::to_string(&message).unwrap();
println!("{}", serialized);
let deserialized: Message = serde_yaml::from_str(&serialized).unwrap();
assert_eq!(message, deserialized);
let serialized = rmp_serde::to_vec(&message).unwrap();
let deserialized = rmp_serde::from_read_ref::<Vec<u8>, Message>(&serialized).unwrap();
assert_eq!(message, deserialized);
}
}