Skip to main content

NodeDbError

Struct NodeDbError 

Source
pub struct NodeDbError { /* private fields */ }
Expand description

Public error type returned by all NodeDb trait methods.

Separates machine-readable data (ErrorCode + ErrorDetails) from the human-readable message. Optional cause preserves the error chain.

Implementations§

Source§

impl NodeDbError

Source

pub fn mirror_read_only(database: impl Into<String>) -> NodeDbError

Write was rejected because the target database is an un-promoted mirror.

The mirror is read-only until ALTER DATABASE <name> PROMOTE is issued.

Source

pub fn stale_read_not_leader( database: impl Into<String>, source_cluster: impl Into<String>, ) -> NodeDbError

Strong-consistency read was requested on a mirror database.

Mirrors cannot serve strong reads; the client should redirect to source_cluster.

Source

pub fn mirror_not_promoted(database: impl Into<String>) -> NodeDbError

Operation requires the database to already be a promoted mirror.

Source§

impl NodeDbError

Source

pub fn move_tenant_drain_timeout( tenant: impl Into<String>, source_db: impl Into<String>, ) -> NodeDbError

Drain phase timed out; the tenant’s sessions on source could not be cleanly wound down within the bounded window. The source is left unmodified; no data was moved.

Source

pub fn move_tenant_preflight_failed( tenant: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Pre-flight schema-compatibility check failed. No state was mutated.

Source

pub fn move_tenant_snapshot_failed( tenant: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Snapshot phase failed; partial snapshot has been cleaned up. Source is unmodified.

Source

pub fn move_tenant_cutover_failed( tenant: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Cutover Raft proposal failed. The source database still holds the tenant’s data; no partial state was left.

Source

pub fn move_tenant_already_at_target( tenant: impl Into<String>, target_db: impl Into<String>, ) -> NodeDbError

The tenant’s data is already in the target database; this is the idempotent response when a previously completed MOVE TENANT is re-issued.

Source§

impl NodeDbError

Source

pub fn collection_not_found(collection: impl Into<String>) -> NodeDbError

Source

pub fn collection_draining(collection: impl Into<String>) -> NodeDbError

Collection is mid-purge; new scans are refused until the purge ack. Distinct from collection_not_found so clients can differentiate “try again in a moment” from “does not exist”.

Source

pub fn collection_deactivated( collection: impl Into<String>, retention_expires_at_ns: u64, ) -> NodeDbError

Collection is soft-deleted (retention window active). Distinct from collection_not_found so clients can surface the UNDROP COLLECTION <name> hint instead of “does not exist”.

Source

pub fn document_not_found( collection: impl Into<String>, document_id: impl Into<String>, ) -> NodeDbError

Source

pub fn plan_error(detail: impl Display) -> NodeDbError

Source

pub fn plan_error_at( phase: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn fan_out_exceeded(shards_touched: u16, limit: u16) -> NodeDbError

Source

pub fn sql_not_enabled() -> NodeDbError

Source

pub fn authorization_denied(resource: impl Into<String>) -> NodeDbError

Source

pub fn auth_expired(detail: impl Display) -> NodeDbError

Source

pub fn tenant_vector_dim_exceeded(dim: u32, limit: u32) -> NodeDbError

Vector insert or index rejected: vector dim exceeds tenant’s max_vector_dim quota.

Source

pub fn tenant_graph_depth_exceeded(depth: u32, limit: u32) -> NodeDbError

Graph traversal rejected: requested depth exceeds tenant’s max_graph_depth quota.

Source

pub fn clone_depth_exceeded(depth: u32, limit: u32) -> NodeDbError

CLONE DATABASE rejected: the clone chain is already at depth levels, which equals or exceeds MAX_CLONE_DEPTH (8).

Source

pub fn cannot_clone_mirror(database: impl Into<String>) -> NodeDbError

CLONE DATABASE rejected: the source database is a mirror and cannot be cloned until it is promoted to a writable primary.

Source

pub fn clone_dependency( source: impl Into<String>, dependents: Vec<String>, ) -> NodeDbError

DROP DATABASE rejected: one or more databases are cloned from this source. dependents lists the dependent database names.

Source

pub fn clone_predates_query_time( as_of_lsn: u64, created_at_lsn: u64, ) -> NodeDbError

Bitemporal AS OF query predates the clone’s creation LSN; the clone did not exist at that point in time.

Source§

impl NodeDbError

Source

pub fn handshake_failed( code: HelloErrorCode, message: impl Display, ) -> NodeDbError

Build a HandshakeFailed error from a HelloErrorCode and the server’s diagnostic message.

Source

pub fn sync_connection_failed(detail: impl Display) -> NodeDbError

Source

pub fn sync_delta_rejected( reason: impl Display, compensation: Option<CompensationHint>, ) -> NodeDbError

Source

pub fn shape_subscription_failed( shape_id: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn storage(detail: impl Display) -> NodeDbError

Source

pub fn storage_op( component: impl Into<String>, op: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn segment_corrupted(detail: impl Display) -> NodeDbError

Source

pub fn segment_corrupted_at( segment_id: u64, corruption: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn cold_storage(detail: impl Display) -> NodeDbError

Source

pub fn cold_storage_op( backend: impl Into<String>, op: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn wal(detail: impl Display) -> NodeDbError

Source

pub fn wal_at( stage: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn serialization( format: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn codec(detail: impl Display) -> NodeDbError

Source

pub fn codec_at( codec: impl Into<String>, op: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn config(detail: impl Display) -> NodeDbError

Source

pub fn bad_request(detail: impl Display) -> NodeDbError

Source

pub fn no_leader(detail: impl Display) -> NodeDbError

Source

pub fn not_leader(leader_addr: impl Into<String>) -> NodeDbError

Source

pub fn migration_in_progress(detail: impl Display) -> NodeDbError

Source

pub fn node_unreachable(detail: impl Display) -> NodeDbError

Source

pub fn cluster(detail: impl Display) -> NodeDbError

Source

pub fn memory_exhausted(engine: impl Into<String>) -> NodeDbError

Source

pub fn encryption(detail: impl Display) -> NodeDbError

Source

pub fn encryption_at( cipher: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn array(array: impl Into<String>, detail: impl Display) -> NodeDbError

Source

pub fn quota_overcommit( field: impl Into<String>, detail: impl Display, ) -> NodeDbError

Sum of database or tenant quotas would exceed the configured ceiling.

Source

pub fn quota_exceeded( scope: impl Into<String>, detail: impl Display, ) -> NodeDbError

Request rejected because a tenant or database quota is exhausted.

Source

pub fn server_overload(detail: impl Display) -> NodeDbError

Global resource pressure; server cannot accept the request.

Source

pub fn bridge(detail: impl Display) -> NodeDbError

Source

pub fn bridge_op( plane: impl Into<String>, op: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn dispatch(detail: impl Display) -> NodeDbError

Source

pub fn dispatch_at( stage: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source

pub fn internal(detail: impl Display) -> NodeDbError

Source

pub fn internal_at( component: impl Into<String>, detail: impl Into<String>, ) -> NodeDbError

Source§

impl NodeDbError

Source

pub fn constraint_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn write_conflict( collection: impl Into<String>, document_id: impl Into<String>, ) -> NodeDbError

Source

pub fn deadline_exceeded() -> NodeDbError

Source

pub fn prevalidation_rejected( constraint: impl Into<String>, reason: impl Display, ) -> NodeDbError

Source

pub fn append_only_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn balance_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn period_locked( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn state_transition_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn transition_check_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn type_guard_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn retention_violation( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn legal_hold_active( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn type_mismatch( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn overflow( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn insufficient_balance( collection: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source

pub fn rate_exceeded( gate: impl Into<String>, detail: impl Display, ) -> NodeDbError

Source§

impl NodeDbError

Source

pub fn code(&self) -> ErrorCode

The stable numeric error code.

Source

pub fn message(&self) -> &str

Human-readable error message.

Source

pub fn details(&self) -> &ErrorDetails

Machine-matchable error details.

Source

pub fn cause(&self) -> Option<&NodeDbError>

The chained cause, if any.

Source

pub fn with_cause(self, cause: NodeDbError) -> NodeDbError

Attach a cause to this error.

Source

pub fn is_retriable(&self) -> bool

Whether this error is retriable by the client.

Source

pub fn is_client_error(&self) -> bool

Whether this error indicates the client sent invalid input.

Source§

impl NodeDbError

Source

pub fn is_constraint_violation(&self) -> bool

Source

pub fn is_not_found(&self) -> bool

Source

pub fn is_auth_denied(&self) -> bool

Source

pub fn is_storage(&self) -> bool

Source

pub fn is_internal(&self) -> bool

Source

pub fn is_type_mismatch(&self) -> bool

Source

pub fn is_type_guard_violation(&self) -> bool

Source

pub fn is_overflow(&self) -> bool

Source

pub fn is_insufficient_balance(&self) -> bool

Source

pub fn is_rate_exceeded(&self) -> bool

Source

pub fn is_cluster(&self) -> bool

Trait Implementations§

Source§

impl Clone for NodeDbError

Source§

fn clone(&self) -> NodeDbError

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 NodeDbError

Source§

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

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

impl<'de> Deserialize<'de> for NodeDbError

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<NodeDbError, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for NodeDbError

Source§

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

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

impl Error for NodeDbError

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

impl From<Error> for NodeDbError

Source§

fn from(e: Error) -> NodeDbError

Converts to this type from the input type.
Source§

impl From<NdbDateTimeError> for NodeDbError

Source§

fn from(e: NdbDateTimeError) -> NodeDbError

Converts to this type from the input type.
Source§

impl Serialize for NodeDbError

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

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

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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> 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> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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, 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
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> NodeDbMarker for T
where T: Send + Sync + ?Sized,