Skip to main content

reifydb_transaction/transaction/catalog/
table.rs

1// SPDX-License-Identifier: Apache-2.0
2// Copyright (c) 2025 ReifyDB
3
4use reifydb_core::interface::catalog::{
5	change::CatalogTrackTableChangeOperations,
6	id::{NamespaceId, TableId},
7	table::TableDef,
8};
9use reifydb_type::Result;
10
11use crate::{
12	change::{
13		Change,
14		OperationType::{Create, Delete, Update},
15		TransactionalTableChanges,
16	},
17	transaction::{admin::AdminTransaction, subscription::SubscriptionTransaction},
18};
19
20impl CatalogTrackTableChangeOperations for AdminTransaction {
21	fn track_table_def_created(&mut self, table: TableDef) -> Result<()> {
22		let change = Change {
23			pre: None,
24			post: Some(table),
25			op: Create,
26		};
27		self.changes.add_table_def_change(change);
28		Ok(())
29	}
30
31	fn track_table_def_updated(&mut self, pre: TableDef, post: TableDef) -> Result<()> {
32		let change = Change {
33			pre: Some(pre),
34			post: Some(post),
35			op: Update,
36		};
37		self.changes.add_table_def_change(change);
38		Ok(())
39	}
40
41	fn track_table_def_deleted(&mut self, table: TableDef) -> Result<()> {
42		let change = Change {
43			pre: Some(table),
44			post: None,
45			op: Delete,
46		};
47		self.changes.add_table_def_change(change);
48		Ok(())
49	}
50}
51
52impl TransactionalTableChanges for AdminTransaction {
53	fn find_table(&self, id: TableId) -> Option<&TableDef> {
54		for change in self.changes.table_def.iter().rev() {
55			if let Some(table) = &change.post {
56				if table.id == id {
57					return Some(table);
58				}
59			} else if let Some(table) = &change.pre {
60				if table.id == id && change.op == Delete {
61					return None;
62				}
63			}
64		}
65		None
66	}
67
68	fn find_table_by_name(&self, namespace: NamespaceId, name: &str) -> Option<&TableDef> {
69		self.changes
70			.table_def
71			.iter()
72			.rev()
73			.find_map(|change| change.post.as_ref().filter(|t| t.namespace == namespace && t.name == name))
74	}
75
76	fn is_table_deleted(&self, id: TableId) -> bool {
77		self.changes
78			.table_def
79			.iter()
80			.rev()
81			.any(|change| change.op == Delete && change.pre.as_ref().map(|t| t.id) == Some(id))
82	}
83
84	fn is_table_deleted_by_name(&self, namespace: NamespaceId, name: &str) -> bool {
85		self.changes.table_def.iter().rev().any(|change| {
86			change.op == Delete
87				&& change
88					.pre
89					.as_ref()
90					.map(|t| t.namespace == namespace && t.name == name)
91					.unwrap_or(false)
92		})
93	}
94}
95
96impl CatalogTrackTableChangeOperations for SubscriptionTransaction {
97	fn track_table_def_created(&mut self, table: TableDef) -> Result<()> {
98		self.inner.track_table_def_created(table)
99	}
100
101	fn track_table_def_updated(&mut self, pre: TableDef, post: TableDef) -> Result<()> {
102		self.inner.track_table_def_updated(pre, post)
103	}
104
105	fn track_table_def_deleted(&mut self, table: TableDef) -> Result<()> {
106		self.inner.track_table_def_deleted(table)
107	}
108}
109
110impl TransactionalTableChanges for SubscriptionTransaction {
111	fn find_table(&self, id: TableId) -> Option<&TableDef> {
112		self.inner.find_table(id)
113	}
114
115	fn find_table_by_name(&self, namespace: NamespaceId, name: &str) -> Option<&TableDef> {
116		self.inner.find_table_by_name(namespace, name)
117	}
118
119	fn is_table_deleted(&self, id: TableId) -> bool {
120		self.inner.is_table_deleted(id)
121	}
122
123	fn is_table_deleted_by_name(&self, namespace: NamespaceId, name: &str) -> bool {
124		self.inner.is_table_deleted_by_name(namespace, name)
125	}
126}