From ef61e3b129db80c21baa391d4a601475e33f0030 Mon Sep 17 00:00:00 2001 From: Vaibhav Date: Wed, 15 Jan 2025 14:51:47 +0530 Subject: [PATCH] chore: more specific error on duplicate control id (#295) --- cala-ledger/src/velocity/error.rs | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/cala-ledger/src/velocity/error.rs b/cala-ledger/src/velocity/error.rs index ac60b1fb..f7100811 100644 --- a/cala-ledger/src/velocity/error.rs +++ b/cala-ledger/src/velocity/error.rs @@ -8,7 +8,7 @@ use crate::primitives::*; #[derive(Error, Debug)] pub enum VelocityError { #[error("VelocityError - Sqlx: {0}")] - Sqlx(#[from] sqlx::Error), + Sqlx(sqlx::Error), #[error("VelocityError - CelError: {0}")] CelError(#[from] CelError), #[error("{0}")] @@ -21,6 +21,21 @@ pub enum VelocityError { EsEntityError(es_entity::EsEntityError), #[error("VelocityError - CursorDestructureError: {0}")] CursorDestructureError(#[from] es_entity::CursorDestructureError), + #[error("VelocityError - control_id already exists")] + ControlIdAlreadyExists, +} + +impl From for VelocityError { + fn from(error: sqlx::Error) -> Self { + if let Some(err) = error.as_database_error() { + if let Some(constraint) = err.constraint() { + if constraint.contains("cala_velocity_controls_pkey") { + return Self::ControlIdAlreadyExists; + } + } + } + Self::Sqlx(error) + } } #[derive(Error, Debug)]