pub enum DaemonError {
Show 21 variants
Config {
path: PathBuf,
source: Error,
},
Io(Error),
WorkspaceBuildFailed {
root: PathBuf,
reason: String,
},
WorkspaceStaleExpired {
root: PathBuf,
age_hours: u64,
cap_hours: u32,
last_good_at: Option<SystemTime>,
last_error: Option<String>,
},
MemoryBudgetExceeded {
limit_bytes: u64,
current_bytes: u64,
reserved_bytes: u64,
retained_bytes: u64,
requested_bytes: u64,
},
WorkspaceEvicted {
root: PathBuf,
},
WorkspaceNotLoaded {
root: PathBuf,
},
WorkspaceIncompatibleGraph {
root: PathBuf,
reason: String,
},
ToolTimeout {
root: PathBuf,
secs: u64,
deadline_ms: u64,
},
InvalidArgument {
reason: String,
},
RpcErrorPreserved(RpcError),
Internal(Error),
AlreadyRunning {
socket: PathBuf,
lock: PathBuf,
owner_pid: Option<u32>,
},
AutoStartTimeout {
timeout_secs: u64,
socket: PathBuf,
},
SignalSetup {
source: Error,
},
WorkspaceOversize {
root: PathBuf,
measured_bytes: u64,
limit_bytes: u64,
current_loaded_bytes: u64,
},
WorkspacePinned {
root: PathBuf,
},
ResetWhileLoading {
root: PathBuf,
},
ResetCancellationDispatched {
root: PathBuf,
retry_after_ms: u64,
},
SocketSetup {
path: PathBuf,
reason: String,
},
QueryTooBroad {
reason: String,
details: Value,
},
}Expand description
All daemon-surface error variants.
Variants§
Config
Config file could not be read or parsed.
Io(Error)
An io::Error occurred outside the config surface (socket bind,
pidfile lock, filesystem probe, etc.).
WorkspaceBuildFailed
Workspace load / rebuild failed with no prior-good graph to serve from.
Maps to JSON-RPC -32001.
WorkspaceStaleExpired
Workspace is in the Failed state and the most recent successful build
is older than the configured stale_serve_max_age_hours cap.
Maps to JSON-RPC -32002.
Fields
last_good_at: Option<SystemTime>Last successful build timestamp, if any. None when the workspace
has never successfully built (edge case: should not reach
WorkspaceStaleExpired in that case — WorkspaceBuildFailed is
returned instead — but the type is permissive for future-proofing).
MemoryBudgetExceeded
Admission control could not satisfy a reservation after evicting every non-pinned workspace.
Maps to JSON-RPC -32003.
Fields
WorkspaceEvicted
Workspace was evicted or removed between a rebuild dispatch and its
admission / publish commit. Signals the Task 7b2 watcher task and any
direct handle_changes caller to terminate their per-workspace loop —
subsequent dispatches on the same WorkspaceKey must route through a
fresh get_or_load first.
Surfaced by RebuildDispatcher::handle_changes’ top-of-drain-loop
eviction gate AND by WorkspaceManager::reserve_rebuild’s Phase-1
workspaces.read() membership + cancellation check (both paths use
this typed variant so 7b2 can match on it without string parsing).
Maps to JSON-RPC -32004.
WorkspaceNotLoaded
Caller requested daemon/rebuild or daemon/cancel_rebuild for a
path that is not currently registered in the WorkspaceManager.
Shares the JSON-RPC -32004 code with Self::WorkspaceEvicted.
The error_data "hint" field distinguishes the two situations on
the wire.
Maps to JSON-RPC -32004.
WorkspaceIncompatibleGraph
On-disk graph snapshot or manifest is incompatible with this binary
(unknown plugin ids in the manifest, or a snapshot format the
runtime cannot parse). SGA02 / SGA04 mandate this stay distinct
from Self::WorkspaceBuildFailed so clients can route
“rebuild” vs. “upgrade binary” vs. “wait” responses correctly.
reason is a human-readable rendering of the underlying
sqry_core::graph::acquisition::PluginSelectionStatus — the
From<GraphAcquisitionError> impl below preserves the variant
faithfully so no information is lost on the wire.
Maps to JSON-RPC -32005.
ToolTimeout
Tool invocation exceeded DaemonConfig::tool_timeout_secs.
Emitted by tool_core::classify_and_execute (Task 8 Phase 8c U6)
when the tokio::time::timeout(tool_timeout, spawn_blocking(run))
outer timer fires. The detached tokio::task::JoinHandle is
dropped — the OS thread may continue executing the tool closure
but its result is discarded.
The deadline_ms field is the canonical wire value (populated by
the constructor as secs * 1000) so error_data does not have
to re-derive it on every call and serialised payloads remain
byte-for-byte identical regardless of constructor shape.
Maps to JSON-RPC -32000.
Fields
InvalidArgument
Argument validation failure surfaced by tool_core BEFORE any
workspace classification runs. Used for resolve_index_root
failures, missing path arguments in MCP tool args, and any
other precondition violation that must be rejected with a
JSON-RPC -32602 “Invalid params” response.
Maps to JSON-RPC -32602.
RpcErrorPreserved(RpcError)
Typed sqry_mcp::error::RpcError preserved through the
daemon-hosted MCP path so the wire envelope is byte-identical
to the standalone MCP response (cluster-C iter-3, codex PR
review recommendation).
The daemon adapter (sqry-mcp/src/daemon_adapter/dispatch.rs)
previously rewrapped param-parsing failures with
anyhow!("invalid arguments: {e}"), which destroyed the typed
RpcError root before [crate::ipc::tool_core::execute_with_timeout]
could downcast it. The downstream daemon_err_to_mcp
then mapped through DaemonError::Internal →
McpError::internal_error (-32603) regardless of the
RpcError’s actual code. This variant is the dedicated
pass-through: the inner RpcError carries the correct
code (-32602 for validation failures, etc.), kind,
retryable, retry_after_ms, and details, and
daemon_err_to_mcp renders them through the same
invalid_params / internal_error selector the standalone
path uses.
Internal(Error)
Catch-all for errors surfaced by
sqry_mcp::daemon_adapter tool execution that do not map
to a more specific DaemonError variant. The wrapped
anyhow::Error is flattened into a string on the wire via the
Display/#[source] chain.
Maps to JSON-RPC -32603.
AlreadyRunning
A sqryd process already holds the exclusive flock on lock and has
written its PID to pidfile. The caller should surface this to the
user with the owner PID (if legible) and exit EX_TEMPFAIL (75).
This error fires before IpcServer::bind and therefore before any
workspace is registered; it should never be stored in the workspace
last_error field. [crate::workspace::manager::clone_err] maps it
to WorkspaceBuildFailed as a defensive fallback.
Fields
AutoStartTimeout
The daemon did not become ready within timeout_secs seconds.
Used by both the --detach parent wait loop and the
lifecycle::start_detached auto-spawn helper (Task 10).
Callers should exit EX_UNAVAILABLE (69).
SignalSetup
Installing OS signal handlers failed (e.g. sigaction returned
ENOSYS in a highly-restricted container, or tokio’s signal
registration failed).
Callers should exit EX_SOFTWARE (70).
WorkspaceOversize
The freshly-built graph exceeds the daemon’s memory budget by
itself — even if every other workspace were evicted, the
daemon could not host it. Returned by
WorkspaceManager::publish_and_retain AFTER the build
completes but BEFORE the new graph is exposed to readers.
Wire code: -32006. Distinct from MemoryBudgetExceeded
(-32003), which is a projected admission failure on a
pre-build estimate.
Source: G_daemon_control_plane.md §1.4 hand-off G4.
WorkspacePinned
daemon/reset was invoked on a pinned workspace and the
caller did not pass force = true. Pinning is the operator
opt-in for “do not LRU-evict this workspace”; resetting it
has the same drop-graph effect as eviction and is therefore
gated behind the same explicit override.
Wire code: -32010.
Source: G_daemon_control_plane.md §3.2 hand-off G4.
ResetWhileLoading
daemon/reset was invoked on a workspace whose state is
Loading. Cancelling a load mid-flight is structurally
unsafe (reservation accounting + admission state would
drift). Caller must wait for the load to settle (success or
Failed) and retry.
Wire code: -32008.
Source: G_daemon_control_plane.md §3.2 hand-off G4.
ResetCancellationDispatched
daemon/reset was invoked on a workspace whose state is
Rebuilding. The reset has dispatched a cancellation token
to the runner; the caller should retry after retry_after_ms
for the runner to finish its drain pass and the workspace to
transition to Failed (which is then idempotently reset on
the next call).
Wire code: -32009.
Source: G_daemon_control_plane.md §3.2 hand-off G4.
SocketSetup
Socket parent directory cannot be created or is not writable.
Surfaced before IpcServer::bind so the failure mode is
distinguishable from a generic EACCES (which would otherwise
be wrapped as Io).
Wire code: -32007. Note this is not normally observed on
the wire because it fires before the IPC server binds; the
JSON-RPC mapping exists for the rare case where the daemon
surface re-emits this through IPC during a hot-reload of the
socket configuration.
Source: G_daemon_control_plane.md §5.2 hand-off G4.
QueryTooBroad
Pre-flight cost gate rejected a query (per B_cost_gate.md
§3, daemon-hosted MCP parity arm). The wire envelope mirrors
the standalone RpcError::query_too_broad exactly so MCP
clients can use a single parser regardless of which transport
the request flowed through.
Wire code: -32602 (the existing invalid_params slot;
kind = "query_too_broad" is the discriminator).
Source: B_cost_gate.md §3 + 00_contracts.md §3.CC-2.
Implementations§
Source§impl DaemonError
impl DaemonError
Sourcepub const fn jsonrpc_code(&self) -> Option<i32>
pub const fn jsonrpc_code(&self) -> Option<i32>
Map to the stable JSON-RPC error code used on the wire.
Returns None for errors that have no public JSON-RPC code — these
are serialised as -32603 "Internal error" per the JSON-RPC 2.0 spec
at the IPC boundary (wired in Task 8).
The Task 9 lifecycle variants (AlreadyRunning, AutoStartTimeout,
SignalSetup) fire before IpcServer::bind so they never cross the
IPC boundary directly; None is returned for them here. They are
only surfaced to human users via exit_code() and process exit.
Sourcepub const fn exit_code(&self) -> u8
pub const fn exit_code(&self) -> u8
Map to a POSIX process exit code following the BSD sysexits.h
conventions used for daemon CLI errors (Task 9 U1).
| Code | Symbol | Semantics |
|---|---|---|
| 0 | EX_OK | Success (not an error; included for completeness) |
| 69 | EX_UNAVAILABLE | Service unavailable (timeout, not-ready) |
| 70 | EX_SOFTWARE | Internal software error |
| 73 | EX_CANTCREAT | IO error / cannot create required file |
| 75 | EX_TEMPFAIL | Try again (e.g. another instance is running) |
| 78 | EX_CONFIG | Configuration error |
For variants that only occur inside the IPC / workspace layer
(not at process-startup time) the JSON-RPC code’s sign-flipped
magnitude is used as a proxy, falling back to 70 (EX_SOFTWARE)
for anything not covered.
Sourcepub fn error_data(&self) -> Option<Value>
pub fn error_data(&self) -> Option<Value>
Build the error.data JSON payload surfaced alongside the JSON-RPC
error code. Returns None when no structured payload should be
attached (typically Io/Config errors routed through -32603).
Task 8 Phase 8a. The IPC method dispatch consumes this to populate
JsonRpcError.data so clients can render actionable diagnostics
without parsing the free-form message string.
Trait Implementations§
Source§impl Debug for DaemonError
impl Debug for DaemonError
Source§impl Display for DaemonError
impl Display for DaemonError
Source§impl Error for DaemonError
impl Error for DaemonError
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
use the Display impl or to_string()
Source§impl From<Error> for DaemonError
impl From<Error> for DaemonError
Source§impl From<GraphAcquisitionError> for DaemonError
impl From<GraphAcquisitionError> for DaemonError
Source§fn from(err: GraphAcquisitionError) -> Self
fn from(err: GraphAcquisitionError) -> Self
Auto Trait Implementations§
impl Freeze for DaemonError
impl !RefUnwindSafe for DaemonError
impl Send for DaemonError
impl Sync for DaemonError
impl Unpin for DaemonError
impl UnsafeUnpin for DaemonError
impl !UnwindSafe for DaemonError
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
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>
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>
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<D> OwoColorize for D
impl<D> OwoColorize for D
Source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
Source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
Source§fn black(&self) -> FgColorDisplay<'_, Black, Self>
fn black(&self) -> FgColorDisplay<'_, Black, Self>
Source§fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
Source§fn red(&self) -> FgColorDisplay<'_, Red, Self>
fn red(&self) -> FgColorDisplay<'_, Red, Self>
Source§fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
Source§fn green(&self) -> FgColorDisplay<'_, Green, Self>
fn green(&self) -> FgColorDisplay<'_, Green, Self>
Source§fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
Source§fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
Source§fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
Source§fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
Source§fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
Source§fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
Source§fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
Source§fn white(&self) -> FgColorDisplay<'_, White, Self>
fn white(&self) -> FgColorDisplay<'_, White, Self>
Source§fn on_white(&self) -> BgColorDisplay<'_, White, Self>
fn on_white(&self) -> BgColorDisplay<'_, White, Self>
Source§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
Source§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
Source§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
Source§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
Source§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
Source§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
Source§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
Source§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
Source§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
Source§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
Source§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
Source§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
Source§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
Source§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
Source§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
Source§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
Source§fn bold(&self) -> BoldDisplay<'_, Self>
fn bold(&self) -> BoldDisplay<'_, Self>
Source§fn dimmed(&self) -> DimDisplay<'_, Self>
fn dimmed(&self) -> DimDisplay<'_, Self>
Source§fn italic(&self) -> ItalicDisplay<'_, Self>
fn italic(&self) -> ItalicDisplay<'_, Self>
Source§fn underline(&self) -> UnderlineDisplay<'_, Self>
fn underline(&self) -> UnderlineDisplay<'_, Self>
Source§fn blink(&self) -> BlinkDisplay<'_, Self>
fn blink(&self) -> BlinkDisplay<'_, Self>
Source§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
Source§fn reversed(&self) -> ReversedDisplay<'_, Self>
fn reversed(&self) -> ReversedDisplay<'_, Self>
Source§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
Source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg or
a color-specific method, such as OwoColorize::green, Read moreSource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg or
a color-specific method, such as OwoColorize::on_yellow, Read more