pub enum AnomalyEvent {
RateSpike {
tenant: String,
rate_per_sec: f64,
baseline: f64,
z_score: f64,
severity: Severity,
detected_at: String,
},
AuthBurst {
user: String,
client_ip: String,
failures: u32,
window_secs: u32,
severity: Severity,
detected_at: String,
},
SqlInjection {
sql_excerpt: String,
patterns_matched: Vec<String>,
severity: Severity,
detected_at: String,
},
NovelQuery {
fingerprint: String,
sql_excerpt: String,
detected_at: String,
},
}Expand description
One anomaly detection event.
Variants§
RateSpike
Per-tenant request-rate spike against the rolling baseline.
Fields
AuthBurst
Failed-auth burst from a single (user, ip) pair.
Fields
SqlInjection
SQL-injection-shaped statement matched one or more well-known payload patterns.
NovelQuery
First-seen query fingerprint. Informational by default.
Implementations§
Trait Implementations§
Source§impl Clone for AnomalyEvent
impl Clone for AnomalyEvent
Source§fn clone(&self) -> AnomalyEvent
fn clone(&self) -> AnomalyEvent
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 Debug for AnomalyEvent
impl Debug for AnomalyEvent
Auto Trait Implementations§
impl Freeze for AnomalyEvent
impl RefUnwindSafe for AnomalyEvent
impl Send for AnomalyEvent
impl Sync for AnomalyEvent
impl Unpin for AnomalyEvent
impl UnsafeUnpin for AnomalyEvent
impl UnwindSafe for AnomalyEvent
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