Skip to main content

ToolErrorKind

Enum ToolErrorKind 

Source
#[non_exhaustive]
pub enum ToolErrorKind { Transient, RateLimit, Quota, Auth, Permanent, Validation, Internal, }
Expand description

Cross-tool failure category.

Derive from Error via Self::classify. Used for retry middleware (RetryToolLayer retries Self::Transient / Self::RateLimit), observability sinks (operators surface the category in dashboards), and downstream recovery routing (different categories trigger different operator responses — page on Auth, alert on Quota, ignore Validation noise).

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Transient

Network blip, transient 5xx, generic transport failure — safe to retry.

§

RateLimit

Vendor signalled rate limiting (429 with Retry-After hint). Retryable after the configured cooldown.

§

Quota

Vendor signalled exhausted quota / billing cap. Retry will not succeed until the quota resets or operator intervenes — surface to ops, do not retry automatically.

§

Auth

Credential rejected (401 / 403 / Error::Auth). Retry will not succeed until credentials are rotated.

§

Permanent

Permanent vendor failure (4xx other than auth/rate/quota, 405, 410, 422 …). The same call will fail again.

§

Validation

Caller-side input rejected (Error::InvalidRequest, Error::Serde) — the operator’s payload does not match the tool contract. Retry is meaningless without changing the payload.

§

Internal

Tool-internal bug or misconfiguration (Error::Config, or any unclassified shape). Surface to ops; retry is not meaningful.

Implementations§

Source§

impl ToolErrorKind

Source

pub fn classify(error: &Error) -> Self

Derive the category from an Error.

The mapping is intentionally exhaustive over the variants Error surfaces today — the _ catch-all routes to Self::Internal so future variants stay observable until classified explicitly. Operational variants (Error::Cancelled, Error::DeadlineExceeded, Error::Interrupted, Error::ModelRetry) flow through Internal because they are agent-runtime control signals, not tool failures — call sites that observe them should not reach this classifier in the first place.

Source

pub const fn is_retryable(self) -> bool

Whether the runtime should attempt the tool call again.

Transient and RateLimit are retryable; everything else is a surface-and-stop signal. RetryToolLayer consults this via the underlying RetryClassifier (which can be overridden per deployment) — operators that want different retry policy install a custom classifier rather than mutating this method.

Trait Implementations§

Source§

impl Clone for ToolErrorKind

Source§

fn clone(&self) -> ToolErrorKind

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for ToolErrorKind

Source§

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

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

impl Hash for ToolErrorKind

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 ToolErrorKind

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · 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 ToolErrorKind

Source§

impl Eq for ToolErrorKind

Source§

impl StructuralPartialEq for ToolErrorKind

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> AsOut<T> for T
where T: Copy,

Source§

fn as_out(&mut self) -> Out<'_, T>

Returns an out reference to self.
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

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