aboutsummaryrefslogtreecommitdiffstats
path: root/lib/api-config/src/schema/get_schema.rs
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2026-03-31 21:35:49 +0200
committerrtkay123 <dev@kanjala.com>2026-03-31 21:35:49 +0200
commit2c336f0339747aa77a8fe6613b83200c8d4902a5 (patch)
tree5e77ac42c48c455fd9869df6baf39c0887f6d8e6 /lib/api-config/src/schema/get_schema.rs
parentcec58d78e968250e4c589899eab460d1132f6d01 (diff)
downloadwarden-2c336f0339747aa77a8fe6613b83200c8d4902a5.tar.bz2
warden-2c336f0339747aa77a8fe6613b83200c8d4902a5.zip
test(config): schema
Diffstat (limited to 'lib/api-config/src/schema/get_schema.rs')
-rw-r--r--lib/api-config/src/schema/get_schema.rs26
1 files changed, 26 insertions, 0 deletions
diff --git a/lib/api-config/src/schema/get_schema.rs b/lib/api-config/src/schema/get_schema.rs
new file mode 100644
index 0000000..427a02f
--- /dev/null
+++ b/lib/api-config/src/schema/get_schema.rs
@@ -0,0 +1,26 @@
+use tracing::debug;
+
+use crate::{
+ ConfigurationError,
+ schema::{SchemaService, TransactionSchema},
+};
+
+pub(super) async fn get_schema(
+ state: &SchemaService,
+ kind: &str,
+ version: &str,
+) -> Result<Option<TransactionSchema>, ConfigurationError> {
+ debug!("getting transaction schema");
+ let result = sqlx::query_as!(
+ TransactionSchema,
+ "select
+ *
+ from transaction_schema where schema_type = $1 and schema_version = $2",
+ kind,
+ version,
+ )
+ .fetch_optional(&state.database)
+ .await?;
+
+ Ok(result)
+}