Skip to main content
Version: 1.7.1

Class: CCIPFinalityNotAllowedError

Defined in: errors/specialized.ts:3705

Thrown when a receiver contract rejects the requested finality.

The receiver either does not support "safe" (FCR) finality, or requires a higher minimum confirmation depth than what was requested. Inspect context.requested and context.allowed for the exact mismatch.

Example

TypeScript
try {
await chain.estimateReceiveExecution({ offRamp, message })
} catch (error) {
if (error instanceof CCIPFinalityNotAllowedError) {
console.log(
`Receiver ${error.context.receiver} rejected finality`,
`requested=${error.context.requested}`,
`allowed=${JSON.stringify(error.context.allowed)}`,
)
}
}

Extends

Constructors

Constructor

new CCIPFinalityNotAllowedError(requested: FinalityRequested, allowed: FinalityAllowed, options?: CCIPErrorOptions): CCIPFinalityNotAllowedError

Defined in: errors/specialized.ts:3713

Creates a finality not allowed error.

Parameters

ParameterTypeDescription
requestedFinalityRequestedThe finality value that was requested ("safe" or a block depth number).
allowedFinalityAllowedThe finality config the receiver actually accepts.
options?CCIPErrorOptionsOptional error options.

Returns

CCIPFinalityNotAllowedError

Overrides

CCIPError.constructor

Properties

_isCCIPError

readonly _isCCIPError: true

Defined in: errors/CCIPError.ts:30

Brand for cross-module identification (dual package hazard).

Inherited from

CCIPError._isCCIPError


code

readonly code: CCIPErrorCode

Defined in: errors/CCIPError.ts:32

Machine-readable error code.

Inherited from

CCIPError.code


context

readonly context: Record<string, unknown>

Defined in: errors/CCIPError.ts:34

Structured context (IDs, addresses).

Inherited from

CCIPError.context


isTransient

readonly isTransient: boolean

Defined in: errors/CCIPError.ts:36

True if retry may succeed.

Inherited from

CCIPError.isTransient


name

readonly name: "CCIPFinalityNotAllowedError" = 'CCIPFinalityNotAllowedError'

Defined in: errors/specialized.ts:3706

Overrides

CCIPError.name


recovery?

readonly optional recovery?: string

Defined in: errors/CCIPError.ts:40

Recovery suggestion.

Inherited from

CCIPError.recovery


retryAfterMs?

readonly optional retryAfterMs?: number

Defined in: errors/CCIPError.ts:38

Retry delay in ms.

Inherited from

CCIPError.retryAfterMs

Methods

toJSON()

toJSON(): Record<string, unknown>

Defined in: errors/CCIPError.ts:105

Serializes the error for logging.

Use this instead of JSON.stringify(error) directly, as Error properties are non-enumerable and would be lost.

Returns

Record<string, unknown>

An object containing all error properties

Inherited from

CCIPError.toJSON


from()

static from(error: unknown, code?: CCIPErrorCode): CCIPError

Defined in: errors/CCIPError.ts:89

Wraps an unknown caught value in a CCIPError.

Useful for normalizing errors in catch blocks.

Parameters

ParameterTypeDescription
errorunknownThe error to wrap
code?CCIPErrorCodeOptional error code (defaults to 'UNKNOWN')

Returns

CCIPError

A CCIPError wrapping the original error

Inherited from

CCIPError.from


isCCIPError()

static isCCIPError(error: unknown): error is CCIPError

Defined in: errors/CCIPError.ts:73

Type guard for CCIPError.

Prefer this over instanceof to handle the dual package hazard when multiple versions of the SDK may be present.

Parameters

ParameterTypeDescription
errorunknownThe error to check

Returns

error is CCIPError

True if the error is a CCIPError instance

Inherited from

CCIPError.isCCIPError