reifydb_core/key/
namespace_view.rs1use super::{EncodableKey, KeyKind};
5use crate::{
6 EncodedKey, EncodedKeyRange,
7 interface::catalog::{NamespaceId, ViewId},
8 util::encoding::keycode::{KeyDeserializer, KeySerializer},
9};
10
11#[derive(Debug, Clone, PartialEq)]
12pub struct NamespaceViewKey {
13 pub namespace: NamespaceId,
14 pub view: ViewId,
15}
16
17const VERSION: u8 = 1;
18
19impl EncodableKey for NamespaceViewKey {
20 const KIND: KeyKind = KeyKind::NamespaceView;
21
22 fn encode(&self) -> EncodedKey {
23 let mut serializer = KeySerializer::with_capacity(18);
24 serializer
25 .extend_u8(VERSION)
26 .extend_u8(Self::KIND as u8)
27 .extend_u64(self.namespace)
28 .extend_u64(self.view);
29 serializer.to_encoded_key()
30 }
31
32 fn decode(key: &EncodedKey) -> Option<Self> {
33 let mut de = KeyDeserializer::from_bytes(key.as_slice());
34
35 let version = de.read_u8().ok()?;
36 if version != VERSION {
37 return None;
38 }
39
40 let kind: KeyKind = de.read_u8().ok()?.try_into().ok()?;
41 if kind != Self::KIND {
42 return None;
43 }
44
45 let namespace = de.read_u64().ok()?;
46 let view = de.read_u64().ok()?;
47
48 Some(Self {
49 namespace: NamespaceId(namespace),
50 view: ViewId(view),
51 })
52 }
53}
54
55impl NamespaceViewKey {
56 pub fn encoded(namespace: impl Into<NamespaceId>, view: impl Into<ViewId>) -> EncodedKey {
57 Self {
58 namespace: namespace.into(),
59 view: view.into(),
60 }
61 .encode()
62 }
63
64 pub fn full_scan(namespace_id: NamespaceId) -> EncodedKeyRange {
65 EncodedKeyRange::start_end(Some(Self::link_start(namespace_id)), Some(Self::link_end(namespace_id)))
66 }
67
68 fn link_start(namespace_id: NamespaceId) -> EncodedKey {
69 let mut serializer = KeySerializer::with_capacity(10);
70 serializer.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(namespace_id);
71 serializer.to_encoded_key()
72 }
73
74 fn link_end(namespace_id: NamespaceId) -> EncodedKey {
75 let mut serializer = KeySerializer::with_capacity(10);
76 serializer.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(*namespace_id - 1);
77 serializer.to_encoded_key()
78 }
79}
80
81#[cfg(test)]
82mod tests {
83 use super::{EncodableKey, NamespaceViewKey};
84 use crate::interface::catalog::{NamespaceId, ViewId};
85
86 #[test]
87 fn test_encode_decode() {
88 let key = NamespaceViewKey {
89 namespace: NamespaceId(0xABCD),
90 view: ViewId(0x123456789ABCDEF0),
91 };
92 let encoded = key.encode();
93
94 let expected: Vec<u8> = vec![
95 0xFE, 0xEE, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x54, 0x32, 0xED, 0xCB, 0xA9, 0x87, 0x65, 0x43, 0x21, 0x0F,
98 ];
99
100 assert_eq!(encoded.as_slice(), expected);
101
102 let key = NamespaceViewKey::decode(&encoded).unwrap();
103 assert_eq!(key.namespace, 0xABCD);
104 assert_eq!(key.view, 0x123456789ABCDEF0);
105 }
106
107 #[test]
108 fn test_order_preserving() {
109 let key1 = NamespaceViewKey {
110 namespace: NamespaceId(1),
111 view: ViewId(100),
112 };
113 let key2 = NamespaceViewKey {
114 namespace: NamespaceId(1),
115 view: ViewId(200),
116 };
117 let key3 = NamespaceViewKey {
118 namespace: NamespaceId(2),
119 view: ViewId(1),
120 };
121
122 let encoded1 = key1.encode();
123 let encoded2 = key2.encode();
124 let encoded3 = key3.encode();
125
126 assert!(encoded3 < encoded2, "ordering not preserved");
127 assert!(encoded2 < encoded1, "ordering not preserved");
128 }
129}