pub struct CustomSqlConstraint { /* private fields */ }Expand description
A constraint that evaluates custom SQL expressions.
This constraint allows users to define custom validation logic using SQL expressions while preventing dangerous operations like DROP, DELETE, UPDATE, etc.
§Examples
use term_guard::constraints::CustomSqlConstraint;
use term_guard::core::Constraint;
// Check that values in a column meet a custom condition
let constraint = CustomSqlConstraint::new("price > 0 AND price < 1000000", None::<String>)?;
assert_eq!(constraint.name(), "custom_sql");
// With a custom hint message
let constraint = CustomSqlConstraint::new(
"order_date <= ship_date",
Some("Shipping date must be after or equal to order date")
)?;Implementations§
Trait Implementations§
Source§impl Clone for CustomSqlConstraint
impl Clone for CustomSqlConstraint
Source§fn clone(&self) -> CustomSqlConstraint
fn clone(&self) -> CustomSqlConstraint
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Constraint for CustomSqlConstraint
impl Constraint for CustomSqlConstraint
Source§fn evaluate<'life0, 'life1, 'async_trait>(
&'life0 self,
ctx: &'life1 SessionContext,
) -> Pin<Box<dyn Future<Output = Result<ConstraintResult>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn evaluate<'life0, 'life1, 'async_trait>(
&'life0 self,
ctx: &'life1 SessionContext,
) -> Pin<Box<dyn Future<Output = Result<ConstraintResult>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Evaluates the constraint against the data in the session context. Read more
Source§fn metadata(&self) -> ConstraintMetadata
fn metadata(&self) -> ConstraintMetadata
Returns the metadata associated with this constraint. Read more
Auto Trait Implementations§
impl Freeze for CustomSqlConstraint
impl RefUnwindSafe for CustomSqlConstraint
impl Send for CustomSqlConstraint
impl Sync for CustomSqlConstraint
impl Unpin for CustomSqlConstraint
impl UnwindSafe for CustomSqlConstraint
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more