NonRetryableError
@rotorsoft/act-root / act/src / NonRetryableError
Class: NonRetryableError
Defined in: libs/act/src/types/errors.ts:352
Thrown by a reaction handler to signal that the failure is permanent
and the drain pipeline should block the stream immediately, without
consuming the rest of the maxRetries budget.
The drain finalizer detects instanceof NonRetryableError and forces
block = options.blockOnError regardless of lease.retry. When
blockOnError is false, behavior is unchanged (drain keeps retrying
forever) โ the class never overrides the operator's explicit "never
block" choice.
Use this for failures the handler knows won't get better on retry:
a 4xx from a webhook, a ZodError on malformed input, a "user
deleted" 404 from a downstream API. Use regular Error (or a
subclass) for transient failures so the existing retry-with-backoff
loop applies.
Examplesโ
import { NonRetryableError } from "@rotorsoft/act";
.on("OrderConfirmed")
.do(async (event) => {
const res = await fetch(url, ...);
if (res.status >= 400 && res.status < 500) {
throw new NonRetryableError(
`webhook ${url} responded ${res.status}`,
{ cause: await res.text() }
);
}
if (!res.ok) throw new Error(`webhook ${url} responded ${res.status}`);
})
.on("PaymentReceived")
.do(async (event) => {
const parsed = Schema.safeParse(event.data);
if (!parsed.success) {
throw new NonRetryableError("payment payload failed validation", {
cause: parsed.error,
});
}
// ... handle parsed payload
})
Extendsโ
Error
Extended byโ
Constructorsโ
Constructorโ
new NonRetryableError(
message,options?):NonRetryableError
Defined in: libs/act/src/types/errors.ts:356
Parametersโ
messageโ
string
options?โ
cause?โ
unknown
Returnsโ
NonRetryableError
Overridesโ
Error.constructor
Propertiesโ
cause?โ
readonlyoptionalcause?:unknown
Defined in: libs/act/src/types/errors.ts:354
The original failure, if any. Mirrors the standard Error.cause shape.
Overridesโ
Error.cause
messageโ
message:
string
Defined in: node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts:1077
Inherited fromโ
Error.message
nameโ
name:
string
Defined in: node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts:1076
Inherited fromโ
Error.name
stack?โ
optionalstack?:string
Defined in: node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts:1078
Inherited fromโ
Error.stack
stackTraceLimitโ
staticstackTraceLimit:number
Defined in: node_modules/.pnpm/@types+node@25.8.0/node_modules/@types/node/globals.d.ts:67
The Error.stackTraceLimit property specifies the number of stack frames
collected by a stack trace (whether generated by new Error().stack or
Error.captureStackTrace(obj)).
The default value is 10 but may be set to any valid JavaScript number. Changes
will affect any stack trace captured after the value has been changed.
If set to a non-number value, or set to a negative number, stack traces will not capture any frames.
Inherited fromโ
Error.stackTraceLimit
Methodsโ
captureStackTrace()โ
staticcaptureStackTrace(targetObject,constructorOpt?):void
Defined in: node_modules/.pnpm/@types+node@25.8.0/node_modules/@types/node/globals.d.ts:51
Creates a .stack property on targetObject, which when accessed returns
a string representing the location in the code at which
Error.captureStackTrace() was called.
const myObject = {};
Error.captureStackTrace(myObject);
myObject.stack; // Similar to `new Error().stack`
The first line of the trace will be prefixed with
${myObject.name}: ${myObject.message}.
The optional constructorOpt argument accepts a function. If given, all frames
above constructorOpt, including constructorOpt, will be omitted from the
generated stack trace.
The constructorOpt argument is useful for hiding implementation
details of error generation from the user. For instance:
function a() {
b();
}
function b() {
c();
}
function c() {
// Create an error without stack trace to avoid calculating the stack trace twice.
const { stackTraceLimit } = Error;
Error.stackTraceLimit = 0;
const error = new Error();
Error.stackTraceLimit = stackTraceLimit;
// Capture the stack trace above function b
Error.captureStackTrace(error, b); // Neither function c, nor b is included in the stack trace
throw error;
}
a();
Parametersโ
targetObjectโ
object
constructorOpt?โ
Function
Returnsโ
void
Inherited fromโ
Error.captureStackTrace
prepareStackTrace()โ
staticprepareStackTrace(err,stackTraces):any
Defined in: node_modules/.pnpm/@types+node@25.8.0/node_modules/@types/node/globals.d.ts:55
Parametersโ
errโ
Error
stackTracesโ
CallSite[]
Returnsโ
any
Seeโ
https://v8.dev/docs/stack-trace-api#customizing-stack-traces
Inherited fromโ
Error.prepareStackTrace