Struct ErrorContext

Source
pub struct ErrorContext {
    pub message: String,
    pub source_location: Option<ErrorSource>,
    pub recovery_suggestion: Option<String>,
    pub metadata: HashMap<String, String>,
    pub severity: ErrorSeverity,
    pub timestamp: Option<SystemTime>,
    pub correlation_id: Option<String>,
    pub component: Option<String>,
    pub tags: Vec<String>,
    pub diagnostic_info: Option<DiagnosticResult>,
}
Expand description

Additional structured context for an error

Fields§

§message: String

Main error message

§source_location: Option<ErrorSource>

Source location information for the error

§recovery_suggestion: Option<String>

Optional suggestion for how to recover from the error

§metadata: HashMap<String, String>

Additional key-value metadata associated with the error

§severity: ErrorSeverity

Severity level of the error

§timestamp: Option<SystemTime>

Timestamp when the error occurred

§correlation_id: Option<String>

Correlation ID for tracking related errors across systems

§component: Option<String>

Component or subsystem where the error occurred

§tags: Vec<String>

Tags for categorizing or filtering errors

§diagnostic_info: Option<DiagnosticResult>

Detailed diagnostic information if available

Implementations§

Source§

impl ErrorContext

Source

pub fn new(message: impl Into<String>) -> ErrorContext

Creates a new ErrorContext with the given message

§Parameters
  • message - Main error message
Source

pub fn with_severity(self, severity: ErrorSeverity) -> ErrorContext

Sets the severity level of the error

§Parameters
  • severity - Severity level to set
Source

pub fn with_source_location(self, source_location: ErrorSource) -> ErrorContext

Adds source location information to the error context

§Parameters
  • source_location - Source location information
Source

pub fn with_recovery_suggestion( self, suggestion: impl Into<String>, ) -> ErrorContext

Adds a recovery suggestion to the error context

§Parameters
  • suggestion - Suggestion for how to recover from the error
Source

pub fn with_metadata( self, key: impl Into<String>, value: impl Into<String>, ) -> ErrorContext

Adds a metadata key-value pair to the error context

§Parameters
  • key - Metadata key
  • value - Metadata value
Source

pub fn with_correlation_id(self, id: impl Into<String>) -> ErrorContext

Adds a correlation ID to the error context

§Parameters
  • id - Correlation ID for tracking related errors
Source

pub fn with_component(self, component: impl Into<String>) -> ErrorContext

Adds a component name to the error context

§Parameters
  • component - Component or subsystem where the error occurred
Source

pub fn add_tag(self, tag: impl Into<String>) -> ErrorContext

Adds a tag to the error context

§Parameters
  • tag - Tag for categorizing or filtering errors
Source

pub fn with_diagnostic_info(self, diagnostic: DiagnosticResult) -> ErrorContext

Adds detailed diagnostic information to the error context

§Parameters
  • diagnostic - Detailed diagnostic information
Source

pub fn with_location(self, location: Location) -> ErrorContext

Adds location information from a Location struct

§Parameters
  • location - Location information
Source

pub fn add_metadata(&mut self, key: impl Into<String>, value: impl Into<String>)

Adds metadata using a mutable reference (for macro usage)

§Parameters
  • key - Metadata key
  • value - Metadata value

Trait Implementations§

Source§

impl Clone for ErrorContext

Source§

fn clone(&self) -> ErrorContext

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ErrorContext

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more