#[non_exhaustive]pub enum McpError {
Show 20 variants
Connection {
server_id: String,
message: String,
},
ToolCall {
server_id: String,
tool_name: ToolName,
message: String,
code: McpErrorCode,
},
ServerNotFound {
server_id: String,
},
ServerAlreadyConnected {
server_id: String,
},
ToolNotFound {
server_id: String,
tool_name: ToolName,
},
Timeout {
server_id: String,
tool_name: ToolName,
timeout_secs: u64,
},
Qdrant(Box<QdrantError>),
Json(Error),
IntConversion(TryFromIntError),
SsrfBlocked {
url: String,
addr: String,
},
InvalidUrl {
url: String,
message: String,
},
Embedding(String),
CommandNotAllowed {
command: String,
},
EnvVarBlocked {
var_name: String,
},
PolicyViolation(String),
OAuthError {
server_id: String,
message: String,
},
OAuthCallbackTimeout {
server_id: String,
timeout_secs: u64,
},
ToolListLocked {
server_id: String,
},
ManagerShuttingDown {
server_id: String,
},
HttpAuth {
server_id: String,
status: u16,
},
}Expand description
Crate-wide error type for all MCP operations.
Variants cover connection failures, tool call errors, policy blocks, OAuth flows,
and infrastructure errors (Qdrant, JSON serialization). Use McpError::code to
obtain a typed McpErrorCode for retry/recovery decisions.
§Examples
use zeph_mcp::error::{McpError, McpErrorCode};
let err = McpError::Timeout {
server_id: "github".to_owned(),
tool_name: "create_issue".into(),
timeout_secs: 30,
};
assert_eq!(err.code(), Some(McpErrorCode::Transient));
assert!(err.code().unwrap().is_retryable());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.
Connection
ToolCall
Fields
§
code: McpErrorCodeTyped error code for retry classification.
ServerNotFound
ServerAlreadyConnected
ToolNotFound
Timeout
Qdrant(Box<QdrantError>)
Json(Error)
IntConversion(TryFromIntError)
SsrfBlocked
InvalidUrl
Embedding(String)
CommandNotAllowed
EnvVarBlocked
PolicyViolation(String)
OAuthError
OAuthCallbackTimeout
ToolListLocked
ManagerShuttingDown
The MCP manager is shutting down; the connection attempt was aborted.
This is a terminal lifecycle signal, not a transient error. Callers must not retry.
HttpAuth
HTTP 4xx response that indicates an authentication or authorization failure.
This error is non-retryable: the client must fix credentials or permissions before
attempting to connect again. It maps to McpErrorCode::AuthFailure.
Implementations§
Trait Implementations§
Source§impl Error for McpError
impl Error for McpError
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
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
fn description(&self) -> &str
👎Deprecated since 1.42.0:
use the Display impl or to_string()
Source§impl From<Box<QdrantError>> for McpError
impl From<Box<QdrantError>> for McpError
Source§fn from(source: Box<QdrantError>) -> Self
fn from(source: Box<QdrantError>) -> Self
Converts to this type from the input type.
Source§impl From<TryFromIntError> for McpError
impl From<TryFromIntError> for McpError
Source§fn from(source: TryFromIntError) -> Self
fn from(source: TryFromIntError) -> Self
Converts to this type from the input type.
Auto Trait Implementations§
impl !RefUnwindSafe for McpError
impl !UnwindSafe for McpError
impl Freeze for McpError
impl Send for McpError
impl Sync for McpError
impl Unpin for McpError
impl UnsafeUnpin for McpError
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request