Skip to main content

reifydb_core/key/
policy_op.rs

1// SPDX-License-Identifier: AGPL-3.0-or-later
2// Copyright (c) 2025 ReifyDB
3
4use super::{EncodableKey, KeyKind};
5use crate::{
6	encoded::key::{EncodedKey, EncodedKeyRange},
7	interface::catalog::policy::PolicyId,
8	util::encoding::keycode::{deserializer::KeyDeserializer, serializer::KeySerializer},
9};
10
11const VERSION: u8 = 1;
12
13#[derive(Debug, Clone, PartialEq)]
14pub struct PolicyOpKey {
15	pub policy: PolicyId,
16	pub op_index: u64,
17}
18
19impl PolicyOpKey {
20	pub fn new(policy: PolicyId, op_index: u64) -> Self {
21		Self {
22			policy,
23			op_index,
24		}
25	}
26
27	pub fn encoded(policy: PolicyId, op_index: u64) -> EncodedKey {
28		Self::new(policy, op_index).encode()
29	}
30
31	pub fn full_scan() -> EncodedKeyRange {
32		let mut start = KeySerializer::with_capacity(2);
33		start.extend_u8(VERSION).extend_u8(Self::KIND as u8);
34		let mut end = KeySerializer::with_capacity(2);
35		end.extend_u8(VERSION).extend_u8(Self::KIND as u8 - 1);
36		EncodedKeyRange::start_end(Some(start.to_encoded_key()), Some(end.to_encoded_key()))
37	}
38
39	pub fn policy_scan(policy: PolicyId) -> EncodedKeyRange {
40		let mut start = KeySerializer::with_capacity(10);
41		start.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(policy);
42		let mut end = KeySerializer::with_capacity(18);
43		end.extend_u8(VERSION).extend_u8(Self::KIND as u8).extend_u64(policy);
44		let start_key = start.to_encoded_key();
45		let mut end_bytes = end.to_encoded_key().to_vec();
46		// Append 8 0xFF bytes to cover the full op_index field range
47		end_bytes.extend_from_slice(&[0xFF; 8]);
48		EncodedKeyRange::start_end(Some(start_key), Some(EncodedKey::new(end_bytes)))
49	}
50}
51
52impl EncodableKey for PolicyOpKey {
53	const KIND: KeyKind = KeyKind::PolicyOp;
54
55	fn encode(&self) -> EncodedKey {
56		let mut serializer = KeySerializer::with_capacity(18);
57		serializer
58			.extend_u8(VERSION)
59			.extend_u8(Self::KIND as u8)
60			.extend_u64(self.policy)
61			.extend_u64(self.op_index);
62		serializer.to_encoded_key()
63	}
64
65	fn decode(key: &EncodedKey) -> Option<Self> {
66		let mut de = KeyDeserializer::from_bytes(key.as_slice());
67		let version = de.read_u8().ok()?;
68		if version != VERSION {
69			return None;
70		}
71		let kind: KeyKind = de.read_u8().ok()?.try_into().ok()?;
72		if kind != Self::KIND {
73			return None;
74		}
75		let policy = de.read_u64().ok()?;
76		let op_index = de.read_u64().ok()?;
77		Some(Self {
78			policy,
79			op_index,
80		})
81	}
82}