Skip to main content

Error

Enum Error 

Source
#[non_exhaustive]
pub enum Error { Validation { kind: ValidationKind, message: String, }, Api { status: u16, message: String, retry_after: Option<RetryAfter>, source: Option<Box<dyn Error + Send + Sync + 'static>>, }, NotFound(String), Timeout { message: String, retry_after: Option<RetryAfter>, source: Option<Box<dyn Error + Send + Sync + 'static>>, }, Connection { message: String, retry_after: Option<RetryAfter>, source: Option<Box<dyn Error + Send + Sync + 'static>>, }, Parse { message: String, source: Option<Box<dyn Error + Send + Sync + 'static>>, }, }
Expand description

Error type for NSIP operations.

Every variant derives a miette::Diagnostic code and a stable type URI, and maps to an RFC 9457 Problem Details envelope via Error::to_problem_details. The fallible-API variants (Error::Api, Error::Timeout, Error::Connection, Error::Parse) carry an optional #[source] so the originating reqwest/serde_json error stays inspectable; the transient variants also carry an optional retry_after.

Maps to the Python exception hierarchy:

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.
§

Validation

Invalid input parameters (validation failure). The kind selects the specific problem type and guidance; see ValidationKind.

Fields

§kind: ValidationKind

Operation-specific classification selecting the problem type.

§message: String

Human-readable description of the validation failure.

§

Api

The API returned a non-success HTTP status.

Fields

§status: u16

HTTP status code returned by the upstream API.

§message: String

Human-readable error message (the response body where available).

§retry_after: Option<RetryAfter>

Retry delay parsed from the upstream Retry-After header, for transient (429 / 5xx) responses.

§source: Option<Box<dyn Error + Send + Sync + 'static>>

Originating transport error, preserved for the cause chain.

§

NotFound(String)

The requested resource was not found (HTTP 404).

§

Timeout

The request timed out.

Fields

§message: String

Human-readable description of the timeout.

§retry_after: Option<RetryAfter>

Suggested retry delay, where one is known.

§source: Option<Box<dyn Error + Send + Sync + 'static>>

Originating transport error, preserved for the cause chain.

§

Connection

Failed to connect to the API.

Fields

§message: String

Human-readable description of the connection failure.

§retry_after: Option<RetryAfter>

Suggested retry delay, where one is known.

§source: Option<Box<dyn Error + Send + Sync + 'static>>

Originating transport error, preserved for the cause chain.

§

Parse

Failed to parse the API response.

Fields

§message: String

Human-readable description of the parse failure.

§source: Option<Box<dyn Error + Send + Sync + 'static>>

Originating deserialization error, preserved for the cause chain.

Implementations§

Source§

impl Error

Source

pub const fn slug_path(&self) -> &'static str

<domain>/<slug> path component for this error’s type URI, e.g. api/timeout. One slug per variant (the Api variant carries its HTTP status in the status field rather than splitting into sub-slugs).

Source

pub fn type_uri(&self) -> String

Stable type URI under the repository’s docs/reference/errors/ tree.

Source

pub const fn title(&self) -> &'static str

One-sentence, type-level title (stable across occurrences).

Source

pub const fn exit_code(&self) -> i32

Process exit code for this error.

Aligned with sysexits.h where applicable:

  • 1 — caller error (bad input, 4xx, not found).
  • 3 — environment error (unparseable upstream payload).
  • 75EX_TEMPFAIL, transient (timeout, connection, 429, 5xx); retry_after is populated where a delay is known.
Source

pub const fn status_code(&self) -> u16

HTTP-class status for the Problem Details envelope.

Source

pub fn suggested_fix(&self) -> Option<String>

Free-text recovery action for this error, or None when there is no deterministic fix. Applicability markers for each fix are catalogued in docs/reference/errors/README.md, keyed by type.

Source

pub fn retry_after(&self) -> Option<RetryAfter>

Retry delay for transient errors, sourced from the upstream Retry-After header where available. None for terminal errors.

Source

pub fn to_problem_details(&self, command: &str) -> ProblemDetails

Build the RFC 9457 Problem Details object for this error.

command seeds the instance URN — pass the CLI subcommand or MCP tool name (e.g. "search"), or "nsip" if unknown.

§Examples
let err = nsip::Error::NotFound("LPN 123".to_string());
let pd = err.to_problem_details("details");
assert_eq!(pd.status, 404);
assert!(pd.instance.starts_with("urn:nsip:details:"));
Source§

impl Error

Source

pub fn validation(message: impl Into<String>) -> Self

Source

pub fn validation_kind(kind: ValidationKind, message: impl Into<String>) -> Self

Construct a Error::Validation with an explicit ValidationKind.

Source

pub fn empty_lpn_id() -> Self

ValidationKind::EmptyLpnId — an LPN ID argument was empty.

Source

pub fn invalid_breed_id(message: impl Into<String>) -> Self

ValidationKind::InvalidBreedId — a breed ID was non-positive or unparseable.

Source

pub fn page_range(message: impl Into<String>) -> Self

ValidationKind::PageRange — a pagination parameter was out of range.

ValidationKind::EmptySearch — a search request carried no filter.

Source

pub fn compare_arity(message: impl Into<String>) -> Self

ValidationKind::CompareArity — comparison given <2 or >5 animals.

Source

pub fn missing_argument(message: impl Into<String>) -> Self

ValidationKind::MissingArgument — a required MCP argument was absent.

Source

pub fn unknown_resource(message: impl Into<String>) -> Self

ValidationKind::UnknownResource — an MCP resource URI was unknown.

Source

pub fn invalid_cursor(message: impl Into<String>) -> Self

ValidationKind::InvalidCursor — an MCP pagination cursor was bad.

Source

pub fn unknown_transport(message: impl Into<String>) -> Self

ValidationKind::UnknownTransport — an unsupported MCP transport.

Source

pub fn not_found(message: impl Into<String>) -> Self

Construct a Error::NotFound from any string-like message.

Source

pub fn api(status: u16, message: impl Into<String>) -> Self

Construct a Error::Api with no retry hint or source.

Source

pub fn timeout(message: impl Into<String>) -> Self

Construct a Error::Timeout with no retry hint or source.

Source

pub fn connection(message: impl Into<String>) -> Self

Construct a Error::Connection with no retry hint or source.

Source

pub fn parse(message: impl Into<String>) -> Self

Construct a Error::Parse with no source.

Trait Implementations§

Source§

impl Debug for Error

Source§

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

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

impl Diagnostic for Error

Source§

fn code(&self) -> Option<Box<dyn Display + '_>>

Unique diagnostic code that can be used to look up more information about this Diagnostic. Ideally also globally unique, and documented in the toplevel crate’s documentation for easy searching. Rust path format (foo::bar::baz) is recommended, but more classic codes like E0123 or enums will work just fine.
Source§

fn help(&self) -> Option<Box<dyn Display + '_>>

Additional help text related to this Diagnostic. Do you have any advice for the poor soul who’s just run into this issue?
Source§

fn url(&self) -> Option<Box<dyn Display + '_>>

URL to visit for a more detailed explanation/help about this Diagnostic.
Source§

fn severity(&self) -> Option<Severity>

Diagnostic severity. This may be used by ReportHandlers to change the display format of this diagnostic. Read more
Source§

fn source_code(&self) -> Option<&dyn SourceCode>

Source code to apply this Diagnostic’s Diagnostic::labels to.
Source§

fn labels(&self) -> Option<Box<dyn Iterator<Item = LabeledSpan> + '_>>

Labels to apply to this Diagnostic’s Diagnostic::source_code
Source§

fn related<'a>( &'a self, ) -> Option<Box<dyn Iterator<Item = &'a dyn Diagnostic> + 'a>>

Additional related Diagnostics.
Source§

fn diagnostic_source(&self) -> Option<&dyn Diagnostic>

The cause of the error.
Source§

impl Display for Error

Source§

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

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

impl Error for Error

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more

Auto Trait Implementations§

§

impl !RefUnwindSafe for Error

§

impl !UnwindSafe for Error

§

impl Freeze for Error

§

impl Send for Error

§

impl Sync for Error

§

impl Unpin for Error

§

impl UnsafeUnpin for Error

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<A, B, T> HttpServerConnExec<A, B> for T
where B: Body,

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<D> OwoColorize for D

Source§

fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>
where C: Color,

Set the foreground color generically Read more
Source§

fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>
where C: Color,

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + 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: Sized + 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> 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, 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