pub struct SecurityEvent {
pub timestamp: DateTime<Utc>,
pub event_type: String,
pub severity: SecurityEventSeverity,
pub source: EventSource,
pub actor: Option<EventActor>,
pub target: Option<EventTarget>,
pub outcome: Option<EventOutcome>,
pub metadata: HashMap<String, Value>,
pub compliance: EventCompliance,
}Expand description
Security event structure
Fields§
§timestamp: DateTime<Utc>Event timestamp (ISO 8601)
event_type: StringEvent type identifier (e.g., “auth.failure”)
severity: SecurityEventSeverityEvent severity
source: EventSourceSource information
actor: Option<EventActor>Actor information (who performed the action)
target: Option<EventTarget>Target resource information
outcome: Option<EventOutcome>Outcome information
metadata: HashMap<String, Value>Additional metadata
compliance: EventComplianceCompliance mappings
Implementations§
Source§impl SecurityEvent
impl SecurityEvent
Sourcepub fn new(
event_type: SecurityEventType,
severity: Option<SecurityEventSeverity>,
source: Option<EventSource>,
) -> Self
pub fn new( event_type: SecurityEventType, severity: Option<SecurityEventSeverity>, source: Option<EventSource>, ) -> Self
Create a new security event
Sourcepub fn with_actor(self, actor: EventActor) -> Self
pub fn with_actor(self, actor: EventActor) -> Self
Set the actor information
Sourcepub fn with_target(self, target: EventTarget) -> Self
pub fn with_target(self, target: EventTarget) -> Self
Set the target resource information
Sourcepub fn with_outcome(self, outcome: EventOutcome) -> Self
pub fn with_outcome(self, outcome: EventOutcome) -> Self
Set the outcome information
Sourcepub fn with_metadata(self, key: String, value: Value) -> Self
pub fn with_metadata(self, key: String, value: Value) -> Self
Add metadata key-value pair
Sourcepub fn to_json_value(&self) -> Value
pub fn to_json_value(&self) -> Value
Convert to JSON value
Trait Implementations§
Source§impl Clone for SecurityEvent
impl Clone for SecurityEvent
Source§fn clone(&self) -> SecurityEvent
fn clone(&self) -> SecurityEvent
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 SecurityEvent
impl Debug for SecurityEvent
Source§impl<'de> Deserialize<'de> for SecurityEvent
impl<'de> Deserialize<'de> for SecurityEvent
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for SecurityEvent
impl RefUnwindSafe for SecurityEvent
impl Send for SecurityEvent
impl Sync for SecurityEvent
impl Unpin for SecurityEvent
impl UnwindSafe for SecurityEvent
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