Skip to main content

reifydb_transaction/transaction/catalog/
flow.rs

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