diff options
| author | rtkay123 <dev@kanjala.com> | 2026-03-29 17:11:27 +0200 |
|---|---|---|
| committer | rtkay123 <dev@kanjala.com> | 2026-03-29 17:11:27 +0200 |
| commit | 2b4d2fab25963712900dda4736432a64189fa876 (patch) | |
| tree | ed1e72141d3ebd7325fd4f44b59e71431f20d7c4 /lib | |
| parent | 3fb3d0214a69017d49c91aa180fb565533edcc54 (diff) | |
| download | warden-2b4d2fab25963712900dda4736432a64189fa876.tar.bz2 warden-2b4d2fab25963712900dda4736432a64189fa876.zip | |
feat: delete transaction schema
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/api-config/src/schema/create.rs | 32 | ||||
| -rw-r--r-- | lib/api-config/src/schema/mod.rs | 55 | ||||
| -rw-r--r-- | lib/warden-core/Cargo.toml | 2 |
3 files changed, 54 insertions, 35 deletions
diff --git a/lib/api-config/src/schema/create.rs b/lib/api-config/src/schema/create.rs index de2d214..5c91f64 100644 --- a/lib/api-config/src/schema/create.rs +++ b/lib/api-config/src/schema/create.rs @@ -1,8 +1,4 @@ -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))] @@ -17,31 +13,3 @@ 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 3893254..b058060 100644 --- a/lib/api-config/src/schema/mod.rs +++ b/lib/api-config/src/schema/mod.rs @@ -1,8 +1,10 @@ -pub mod create; +mod create; +pub use create::CreateSchema; use async_trait::async_trait; use serde::{Deserialize, Serialize}; use time::OffsetDateTime; +use warden_core::state::AppState; use crate::ConfigurationError; @@ -28,8 +30,57 @@ pub struct TransactionSchema { pub trait SchemaDriver { async fn create_schema( &self, - name: impl AsRef<str> + Send + Sync, + kind: impl AsRef<str> + Send + Sync, version: impl AsRef<str> + Send + Sync, schema: &serde_json::Value, ) -> Result<TransactionSchema, ConfigurationError>; + + async fn delete_schema( + &self, + kind: impl AsRef<str> + Send + Sync, + version: impl AsRef<str> + Send + Sync, + ) -> Result<(), ConfigurationError>; +} + +#[async_trait] +impl SchemaDriver for AppState { + async fn create_schema( + &self, + kind: impl AsRef<str> + Send + Sync, + version: impl AsRef<str> + Send + Sync, + schema: &serde_json::Value, + ) -> Result<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 + ", + kind.as_ref(), + version.as_ref(), + sqlx::types::Json(&schema) as _ + ) + .fetch_one(&self.database) + .await + .map_err(|e| e.into()) + } + + async fn delete_schema( + &self, + kind: impl AsRef<str> + Send + Sync, + version: impl AsRef<str> + Send + Sync, + ) -> Result<(), crate::ConfigurationError> { + // sqlx::query!("delete * from transaction_schema where type = $1 and version $2", + // name.as_ref(), + // version.as_ref(), + // ) + // .execute(&self.database) + // .await + // .map_err(|e| e.into()) + Ok(()) + } } diff --git a/lib/warden-core/Cargo.toml b/lib/warden-core/Cargo.toml index 1f92e87..49b7186 100644 --- a/lib/warden-core/Cargo.toml +++ b/lib/warden-core/Cargo.toml @@ -14,7 +14,7 @@ serde = { workspace = true, features = ["derive"] } thiserror.workspace = true tracing.workspace = true tracing-subscriber = { version = "0.3.23", features = ["env-filter"] } -url.workspace = true +url = { workspace = true, features = ["serde"] } [dependencies.sqlx] workspace = true |
