InvariantError
@rotorsoft/act-root / act/src / InvariantError
Class: InvariantError<TState, TEvents, TActions, TKey, TActor>
Defined in: libs/act/src/types/errors.ts:152
Thrown when a business rule (invariant) is violated during action execution.
Invariants are conditions that must hold true for an action to succeed. They're checked after loading the current state but before emitting events. This error provides complete context about what action was attempted and why it was rejected.
Examplesโ
import { InvariantError } from "@rotorsoft/act";
try {
await app.do("withdraw",
{ stream: "account-123", actor: { id: "user1", name: "Alice" } },
{ amount: 1000 }
);
} catch (error) {
if (error instanceof InvariantError) {
console.error("Action:", error.action);
console.error("Reason:", error.description);
console.error("Current state:", error.snapshot.state);
console.error("Attempted payload:", error.payload);
}
}
try {
await app.do("closeTicket", target, payload);
} catch (error) {
if (error instanceof InvariantError) {
// Present friendly message to user
if (error.description === "Ticket must be open") {
return { error: "This ticket is already closed" };
} else if (error.description === "Not authorized") {
return { error: "You don't have permission to close this ticket" };
}
}
}
try {
await app.do("transfer", target, { to: "account2", amount: 500 });
} catch (error) {
if (error instanceof InvariantError) {
logger.error({
action: error.action,
stream: error.target.stream,
actor: error.target.actor,
reason: error.description,
balance: error.snapshot.state.balance,
attempted: error.payload.amount
}, "Invariant violation");
}
}
Seeโ
Invariant for defining business rules
Extendsโ
Error
Type Parametersโ
TStateโ
TState extends Schema
State schema type
TEventsโ
TEvents extends Schemas
Event schemas type
TActionsโ
TActions extends Schemas
Action schemas type
TKeyโ
TKey extends keyof TActions
Action name
TActorโ
Actor type extending base Actor
Constructorsโ
Constructorโ
new InvariantError<
TState,TEvents,TActions,TKey,TActor>(action,payload,target,snapshot,description):InvariantError<TState,TEvents,TActions,TKey,TActor>
Defined in: libs/act/src/types/errors.ts:159
Parametersโ
actionโ
TKey
The action that was attempted
payloadโ
Readonly<TActions[TKey]>
The action payload that was provided
targetโ
Target<TActor>
The target stream and actor context
snapshotโ
Snapshot<TState, TEvents>
The current state snapshot when invariant was checked
descriptionโ
string
Human-readable description of why the invariant failed
Returnsโ
InvariantError<TState, TEvents, TActions, TKey, TActor>
Overridesโ
Error.constructor
Propertiesโ
actionโ
readonlyaction:TKey
Defined in: libs/act/src/types/errors.ts:161
The action that was attempted
cause?โ
optionalcause?:unknown
Defined in: node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.error.d.ts:26
Inherited fromโ
Error.cause
descriptionโ
readonlydescription:string
Defined in: libs/act/src/types/errors.ts:169
Human-readable description of why the invariant failed
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
payloadโ
readonlypayload:Readonly<TActions[TKey]>
Defined in: libs/act/src/types/errors.ts:163
The action payload that was provided
snapshotโ
readonlysnapshot:Snapshot<TState,TEvents>
Defined in: libs/act/src/types/errors.ts:167
The current state snapshot when invariant was checked
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
targetโ
readonlytarget:Target<TActor>
Defined in: libs/act/src/types/errors.ts:165
The target stream and actor context
stackTraceLimitโ
staticstackTraceLimit:number
Defined in: node_modules/.pnpm/@types+node@25.9.1/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.9.1/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.9.1/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