Skip to main content

AlienError

Struct AlienError 

Source
pub struct AlienError {
    pub code: AlienErrorCode,
    pub context: Option<Value>,
    pub http_status_code: Option<i32>,
    pub internal: bool,
    pub message: AlienErrorMessage,
    pub retryable: bool,
    pub source: Option<Value>,
}
Expand description

Canonical error container that provides a structured way to represent errors with rich metadata including error codes, human-readable messages, context, and chaining capabilities for error propagation.

This struct is designed to be both machine-readable and user-friendly, supporting serialization for API responses and detailed error reporting in distributed systems.

JSON schema
{
 "description": "Canonical error container that provides a structured way to represent errors\nwith rich metadata including error codes, human-readable messages, context,\nand chaining capabilities for error propagation.\n\nThis struct is designed to be both machine-readable and user-friendly,\nsupporting serialization for API responses and detailed error reporting\nin distributed systems.",
 "type": "object",
 "required": [
   "code",
   "internal",
   "message",
   "retryable"
 ],
 "properties": {
   "code": {
     "description": "A unique identifier for the type of error.\n\nThis should be a short, machine-readable string that can be used\nby clients to programmatically handle different error types.\nExamples: \"NOT_FOUND\", \"VALIDATION_ERROR\", \"TIMEOUT\"",
     "examples": [
       "NOT_FOUND"
     ],
     "type": "string",
     "maxLength": 128
   },
   "context": {
     "description": "Additional diagnostic information about the error context.\n\nThis optional field can contain structured data providing more details\nabout the error, such as validation errors, request parameters that\ncaused the issue, or other relevant context information."
   },
   "httpStatusCode": {
     "description": "HTTP status code for this error.\n\nUsed when converting the error to an HTTP response. If None, falls back to\nthe error type's default status code or 500.",
     "type": [
       "integer",
       "null"
     ],
     "format": "int32",
     "maximum": 599.0,
     "minimum": 100.0
   },
   "internal": {
     "description": "Indicates if this is an internal error that should not be exposed to users.\n\nWhen `true`, this error contains sensitive information or implementation\ndetails that should not be shown to end-users. Such errors should be\nlogged for debugging but replaced with generic error messages in responses.",
     "type": "boolean"
   },
   "message": {
     "description": "Human-readable error message.\n\nThis message should be clear and actionable for developers or end-users,\nproviding context about what went wrong and potentially how to fix it.",
     "examples": [
       "Item not found."
     ],
     "type": "string",
     "maxLength": 16384
   },
   "retryable": {
     "description": "Indicates whether the operation that caused the error should be retried.\n\nWhen `true`, the error is transient and the operation might succeed\nif attempted again. When `false`, retrying the same operation is\nunlikely to succeed without changes.",
     "default": false,
     "type": "boolean"
   },
   "source": {
     "description": "The underlying error that caused this error, creating an error chain.\n\nThis allows for proper error propagation and debugging by maintaining\nthe full context of how an error occurred through multiple layers\nof an application."
   }
 }
}

Fields§

§code: AlienErrorCode

A unique identifier for the type of error.

This should be a short, machine-readable string that can be used by clients to programmatically handle different error types. Examples: “NOT_FOUND”, “VALIDATION_ERROR”, “TIMEOUT”

§context: Option<Value>

Additional diagnostic information about the error context.

This optional field can contain structured data providing more details about the error, such as validation errors, request parameters that caused the issue, or other relevant context information.

§http_status_code: Option<i32>

HTTP status code for this error.

Used when converting the error to an HTTP response. If None, falls back to the error type’s default status code or 500.

§internal: bool

Indicates if this is an internal error that should not be exposed to users.

When true, this error contains sensitive information or implementation details that should not be shown to end-users. Such errors should be logged for debugging but replaced with generic error messages in responses.

§message: AlienErrorMessage

Human-readable error message.

This message should be clear and actionable for developers or end-users, providing context about what went wrong and potentially how to fix it.

§retryable: bool

Indicates whether the operation that caused the error should be retried.

When true, the error is transient and the operation might succeed if attempted again. When false, retrying the same operation is unlikely to succeed without changes.

§source: Option<Value>

The underlying error that caused this error, creating an error chain.

This allows for proper error propagation and debugging by maintaining the full context of how an error occurred through multiple layers of an application.

Implementations§

Trait Implementations§

Source§

impl Clone for AlienError

Source§

fn clone(&self) -> AlienError

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 AlienError

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for AlienError

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<&AlienError> for AlienError

Source§

fn from(value: &AlienError) -> Self

Converts to this type from the input type.
Source§

impl From<AlienError> for AlienError

Source§

fn from(value: AlienError) -> Self

Converts to this type from the input type.
Source§

impl Serialize for AlienError

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl TryFrom<AlienError> for AlienError

Source§

type Error = ConversionError

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

fn try_from(value: AlienError) -> Result<Self, ConversionError>

Performs the conversion.

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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
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
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,