Skip to main content

StandardErrorCode

Enum StandardErrorCode 

Source
pub enum StandardErrorCode {
Show 13 variants InvalidRequest, Authentication, PermissionDenied, NotFound, RequestTooLarge, RateLimited, QuotaExhausted, ServerError, Overloaded, Timeout, Conflict, Cancelled, Unknown,
}
Expand description

Standard AI-Protocol V2 error code.

Each variant corresponds to a canonical error from the specification, with associated metadata: code string, name, retryable, and fallbackable flags.

Variants§

§

InvalidRequest

E1001: Malformed request, invalid parameters, or missing required fields

§

Authentication

E1002: Invalid, expired, or missing API key

§

PermissionDenied

E1003: Valid credentials but insufficient permissions

§

NotFound

E1004: Requested model, endpoint, or resource does not exist

§

RequestTooLarge

E1005: Input exceeds context window or API payload size limit

§

RateLimited

E2001: Request rate limit exceeded

§

QuotaExhausted

E2002: Account usage quota or billing limit reached

§

ServerError

E3001: Internal server error on provider side

§

Overloaded

E3002: Provider service temporarily overloaded

§

Timeout

E3003: Request timed out before response received

§

Conflict

E4001: State conflict (e.g., concurrent modification)

§

Cancelled

E4002: Request was cancelled by the client

§

Unknown

E9999: Error could not be classified

Implementations§

Source§

impl StandardErrorCode

Source

pub fn code(&self) -> &'static str

Returns the canonical code string (e.g., "E1001").

Source

pub fn name(&self) -> &'static str

Returns the standard name (e.g., "invalid_request").

Source

pub fn retryable(&self) -> bool

Returns whether this error is retryable by default.

Source

pub fn fallbackable(&self) -> bool

Returns whether this error should trigger a fallback to another provider.

Source

pub fn category(&self) -> &'static str

Returns the category: "client", "rate", "server", "operational", or "unknown".

Source

pub fn from_provider_code(provider_code: &str) -> Option<Self>

Maps a provider error code/type string to the corresponding StandardErrorCode.

Supports both standard names (e.g., "invalid_request") and provider-specific aliases such as "invalid_api_key", "context_length_exceeded", "overloaded_error".

Source

pub fn from_error_class(error_class: &str) -> Self

Maps an error class name string to the corresponding StandardErrorCode.

The class name should match the standard names (e.g., "invalid_request"). Aliases such as "authorized_error" (→ authentication) are supported. Unknown class names map to StandardErrorCode::Unknown.

Source

pub fn from_http_status(status: u16) -> Self

Maps an HTTP status code to the most likely StandardErrorCode.

Multiple status codes can map to the same error (e.g., 429 → rate_limited). Status codes without a standard mapping return StandardErrorCode::Unknown.

Trait Implementations§

Source§

impl Clone for StandardErrorCode

Source§

fn clone(&self) -> StandardErrorCode

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 StandardErrorCode

Source§

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

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

impl Display for StandardErrorCode

Source§

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

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

impl Hash for StandardErrorCode

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for StandardErrorCode

Source§

fn eq(&self, other: &StandardErrorCode) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for StandardErrorCode

Source§

impl Eq for StandardErrorCode

Source§

impl StructuralPartialEq for StandardErrorCode

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> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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> Same for T

Source§

type Output = T

Should always be Self
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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T> ToStringFallible for T
where T: Display,

Source§

fn try_to_string(&self) -> Result<String, TryReserveError>

ToString::to_string, but without panic on OOM.

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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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