nodedb_sql/engine_rules/
kv.rs1use crate::engine_rules::*;
6use crate::error::{Result, SqlError};
7use crate::types::*;
8
9pub struct KvRules;
10
11impl EngineRules for KvRules {
12 fn plan_insert(&self, p: InsertParams) -> Result<Vec<SqlPlan>> {
13 Err(SqlError::Unsupported {
20 detail: format!(
21 "INSERT into KV collection '{}' must use the KV insert path",
22 p.collection
23 ),
24 })
25 }
26
27 fn plan_upsert(&self, _p: UpsertParams) -> Result<Vec<SqlPlan>> {
28 Err(SqlError::Unsupported {
31 detail: "KV UPSERT must use the KV insert path (KV PUT is naturally an upsert)".into(),
32 })
33 }
34
35 fn plan_scan(&self, p: ScanParams) -> Result<SqlPlan> {
36 if p.temporal.is_temporal() {
37 return Err(SqlError::Unsupported {
38 detail: format!(
39 "FOR SYSTEM_TIME / FOR VALID_TIME is not supported on KV collection '{}'",
40 p.collection
41 ),
42 });
43 }
44 Ok(SqlPlan::Scan {
45 collection: p.collection,
46 alias: p.alias,
47 engine: EngineType::KeyValue,
48 filters: p.filters,
49 projection: p.projection,
50 sort_keys: p.sort_keys,
51 limit: p.limit,
52 offset: p.offset,
53 distinct: p.distinct,
54 window_functions: p.window_functions,
55 temporal: p.temporal,
56 })
57 }
58
59 fn plan_point_get(&self, p: PointGetParams) -> Result<SqlPlan> {
60 Ok(SqlPlan::PointGet {
61 collection: p.collection,
62 alias: p.alias,
63 engine: EngineType::KeyValue,
64 key_column: p.key_column,
65 key_value: p.key_value,
66 })
67 }
68
69 fn plan_update(&self, p: UpdateParams) -> Result<Vec<SqlPlan>> {
70 Ok(vec![SqlPlan::Update {
71 collection: p.collection,
72 engine: EngineType::KeyValue,
73 assignments: p.assignments,
74 filters: p.filters,
75 target_keys: p.target_keys,
76 returning: p.returning,
77 }])
78 }
79
80 fn plan_update_from(&self, p: UpdateFromParams) -> Result<Vec<SqlPlan>> {
81 Err(SqlError::Unsupported {
82 detail: format!(
83 "UPDATE ... FROM is not supported on KV collection '{}'; \
84 KV keys are opaque and cannot participate in cross-table join updates",
85 p.collection
86 ),
87 })
88 }
89
90 fn plan_delete(&self, p: DeleteParams) -> Result<Vec<SqlPlan>> {
91 Ok(vec![SqlPlan::Delete {
92 collection: p.collection,
93 engine: EngineType::KeyValue,
94 filters: p.filters,
95 target_keys: p.target_keys,
96 }])
97 }
98
99 fn plan_aggregate(&self, p: AggregateParams) -> Result<SqlPlan> {
100 let base_scan = SqlPlan::Scan {
101 collection: p.collection,
102 alias: p.alias,
103 engine: EngineType::KeyValue,
104 filters: p.filters,
105 projection: Vec::new(),
106 sort_keys: Vec::new(),
107 limit: None,
108 offset: 0,
109 distinct: false,
110 window_functions: Vec::new(),
111 temporal: crate::temporal::TemporalScope::default(),
112 };
113 Ok(SqlPlan::Aggregate {
114 input: Box::new(base_scan),
115 group_by: p.group_by,
116 aggregates: p.aggregates,
117 having: p.having,
118 limit: p.limit,
119 grouping_sets: None,
120 sort_keys: Vec::new(),
121 })
122 }
123
124 fn plan_merge(&self, p: MergeParams) -> Result<Vec<SqlPlan>> {
125 Err(SqlError::Unsupported {
126 detail: format!(
127 "MERGE is not supported on key-value collection '{}'",
128 p.collection
129 ),
130 })
131 }
132}