aboutsummaryrefslogtreecommitdiffstats
path: root/lib/api-config
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2026-03-29 16:51:09 +0200
committerrtkay123 <dev@kanjala.com>2026-03-29 16:51:09 +0200
commit3fb3d0214a69017d49c91aa180fb565533edcc54 (patch)
treec3618666a7e7c5cbe0f0a4bbf379cc82e4f82e3f /lib/api-config
parentff3b9fbaf400c344cae67ef9bdc9ba7d5f27b976 (diff)
downloadwarden-3fb3d0214a69017d49c91aa180fb565533edcc54.tar.bz2
warden-3fb3d0214a69017d49c91aa180fb565533edcc54.zip
refactor: use api-config to create schema
Diffstat (limited to 'lib/api-config')
-rw-r--r--lib/api-config/Cargo.toml1
-rw-r--r--lib/api-config/src/error.rs4
-rw-r--r--lib/api-config/src/schema/create.rs32
-rw-r--r--lib/api-config/src/schema/mod.rs12
4 files changed, 42 insertions, 7 deletions
diff --git a/lib/api-config/Cargo.toml b/lib/api-config/Cargo.toml
index ec31262..b114944 100644
--- a/lib/api-config/Cargo.toml
+++ b/lib/api-config/Cargo.toml
@@ -9,6 +9,7 @@ homepage.workspace = true
publish.workspace = true
[dependencies]
+async-trait.workspace = true
serde.workspace = true
serde_json.workspace = true
thiserror.workspace = true
diff --git a/lib/api-config/src/error.rs b/lib/api-config/src/error.rs
index 6f7b099..b2dc9ad 100644
--- a/lib/api-config/src/error.rs
+++ b/lib/api-config/src/error.rs
@@ -2,8 +2,8 @@ use thiserror::Error;
#[derive(Error, Debug)]
pub enum ConfigurationError {
- #[error("data store disconnected")]
- Disconnect(#[from] sqlx::Error),
+ #[error(transparent)]
+ Database(#[from] sqlx::Error),
#[error("the data for key `{0}` is not available")]
Redaction(String),
#[error("invalid header (expected {expected:?}, found {found:?})")]
diff --git a/lib/api-config/src/schema/create.rs b/lib/api-config/src/schema/create.rs
index 5c91f64..de2d214 100644
--- a/lib/api-config/src/schema/create.rs
+++ b/lib/api-config/src/schema/create.rs
@@ -1,4 +1,8 @@
+use async_trait::async_trait;
use serde::{Deserialize, Serialize};
+use warden_core::state::AppState;
+
+use crate::schema::{SchemaDriver, TransactionSchema};
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
@@ -13,3 +17,31 @@ pub struct CreateSchema {
#[serde(rename = "json_schema")]
pub schema: serde_json::Value,
}
+
+#[async_trait]
+impl SchemaDriver for AppState {
+ async fn create_schema(
+ &self,
+ name: impl AsRef<str> + Send + Sync,
+ version: impl AsRef<str> + Send + Sync,
+ schema: &serde_json::Value,
+ ) -> Result<super::TransactionSchema, crate::ConfigurationError> {
+ sqlx::query_as!(
+ TransactionSchema,
+ "insert into transaction_schema (type, version, json_schema) values ($1, $2, $3)
+ returning
+ type as kind,
+ version,
+ json_schema as schema,
+ created_at,
+ updated_at
+ ",
+ name.as_ref(),
+ version.as_ref(),
+ sqlx::types::Json(&schema) as _
+ )
+ .fetch_one(&self.database)
+ .await
+ .map_err(|e| e.into())
+ }
+}
diff --git a/lib/api-config/src/schema/mod.rs b/lib/api-config/src/schema/mod.rs
index 654e6ad..3893254 100644
--- a/lib/api-config/src/schema/mod.rs
+++ b/lib/api-config/src/schema/mod.rs
@@ -1,5 +1,6 @@
pub mod create;
+use async_trait::async_trait;
use serde::{Deserialize, Serialize};
use time::OffsetDateTime;
@@ -23,11 +24,12 @@ pub struct TransactionSchema {
pub updated_at: OffsetDateTime,
}
+#[async_trait]
pub trait SchemaDriver {
- fn create(
+ async fn create_schema(
&self,
- name: impl AsRef<str>,
- version: impl AsRef<str>,
- schema: serde_json::Value,
- ) -> impl std::future::Future<Output = Result<TransactionSchema, ConfigurationError>> + Send + Sync;
+ name: impl AsRef<str> + Send + Sync,
+ version: impl AsRef<str> + Send + Sync,
+ schema: &serde_json::Value,
+ ) -> Result<TransactionSchema, ConfigurationError>;
}