reifydb_core/key/
namespace_series.rs1use super::{EncodableKey, KeyKind};
5use crate::{
6 encoded::key::{EncodedKey, EncodedKeyRange},
7 interface::catalog::id::{NamespaceId, SeriesId},
8 util::encoding::keycode::{deserializer::KeyDeserializer, serializer::KeySerializer},
9};
10
11const VERSION: u8 = 1;
12
13#[derive(Debug, Clone, PartialEq)]
14pub struct NamespaceSeriesKey {
15 pub namespace: NamespaceId,
16 pub series: SeriesId,
17}
18
19impl NamespaceSeriesKey {
20 pub fn new(namespace: NamespaceId, series: SeriesId) -> Self {
21 Self {
22 namespace,
23 series,
24 }
25 }
26
27 pub fn encoded(namespace: impl Into<NamespaceId>, series: impl Into<SeriesId>) -> EncodedKey {
28 Self::new(namespace.into(), series.into()).encode()
29 }
30
31 pub fn full_scan(namespace: NamespaceId) -> EncodedKeyRange {
32 EncodedKeyRange::start_end(Some(Self::link_start(namespace)), Some(Self::link_end(namespace)))
33 }
34
35 fn link_start(namespace: NamespaceId) -> EncodedKey {
36 let mut serializer = KeySerializer::with_capacity(10);
37 serializer.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(namespace);
38 serializer.to_encoded_key()
39 }
40
41 fn link_end(namespace: NamespaceId) -> EncodedKey {
42 let mut serializer = KeySerializer::with_capacity(10);
43 serializer.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(*namespace - 1);
44 serializer.to_encoded_key()
45 }
46}
47
48impl EncodableKey for NamespaceSeriesKey {
49 const KIND: KeyKind = KeyKind::NamespaceSeries;
50
51 fn encode(&self) -> EncodedKey {
52 let mut serializer = KeySerializer::with_capacity(18);
53 serializer
54 .extend_u8(VERSION)
55 .extend_u8(Self::KIND as u8)
56 .extend_u64(self.namespace)
57 .extend_u64(self.series);
58 serializer.to_encoded_key()
59 }
60
61 fn decode(key: &EncodedKey) -> Option<Self> {
62 let mut de = KeyDeserializer::from_bytes(key.as_slice());
63
64 let version = de.read_u8().ok()?;
65 if version != VERSION {
66 return None;
67 }
68
69 let kind: KeyKind = de.read_u8().ok()?.try_into().ok()?;
70 if kind != Self::KIND {
71 return None;
72 }
73
74 let namespace = de.read_u64().ok()?;
75 let series = de.read_u64().ok()?;
76
77 Some(Self {
78 namespace: NamespaceId(namespace),
79 series: SeriesId(series),
80 })
81 }
82}