Skip to content

Class: ServiceSkipError

Makaio Framework


Makaio Framework / kernel / ServiceSkipError

Defined in: ../../../packages/kernel/src/service-skip-error.ts:24

Thrown from a service factory to signal that the service intentionally opts out of starting in the current runtime context (e.g. wrong role, disabled feature flag).

ExtensionCoordinator catches this error and routes the package to the skipped list instead of the failed list, emitting kernel:boot.service.skipped instead of kernel:boot.service.failed.

Contract: Only valid for non-critical services. Throwing ServiceSkipError from a critical service is treated as a real failure to prevent silent startup holes.

factory: async (ctx) => {
const { config } = await ctx.bus.request(ConfigSubjects.get, {});
if (config.role !== 'main-dev-machine') {
throw new ServiceSkipError(`role=${String(config.role)}, expected main-dev-machine`);
}
return new CronTriggerEvaluator(ctx.bus);
}
  • Error

new ServiceSkipError(reason): ServiceSkipError

Defined in: ../../../packages/kernel/src/service-skip-error.ts:34

string

Human-readable explanation for why the service is skipping

ServiceSkipError

Error.constructor

optional cause?: unknown

Defined in: ../../../node_modules/typescript/lib/lib.es2022.error.d.ts:24

The cause of the error.

Error.cause


message: string

Defined in: ../../../node_modules/typescript/lib/lib.es5.d.ts:1075

Error.message


name: string

Defined in: ../../../node_modules/typescript/lib/lib.es5.d.ts:1074

Error.name


readonly reason: string

Defined in: ../../../packages/kernel/src/service-skip-error.ts:29

Human-readable reason why the service chose to skip. Included in the service.skipped bus event.


optional stack?: string

Defined in: ../../../node_modules/typescript/lib/lib.es5.d.ts:1076

Error.stack


static stackTraceLimit: number

Defined in: ../../../node_modules/@types/node/globals.d.ts:68

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.

Error.stackTraceLimit

static captureStackTrace(targetObject, constructorOpt?): void

Defined in: ../../../node_modules/@types/node/globals.d.ts:52

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();

object

Function

void

Error.captureStackTrace

static captureStackTrace(targetObject, constructorOpt?): void

Defined in: ../../../node_modules/bun-types/globals.d.ts:1042

Create .stack property on a target object

object

Function

void

Error.captureStackTrace


static isError(error): error is Error

Defined in: ../../../node_modules/typescript/lib/lib.esnext.error.d.ts:21

Indicates whether the argument provided is a built-in Error instance or not.

unknown

error is Error

Error.isError

static isError(value): value is Error

Defined in: ../../../node_modules/bun-types/globals.d.ts:1037

Check if a value is an instance of Error

unknown

The value to check

value is Error

True if the value is an instance of Error, false otherwise

Error.isError


static prepareStackTrace(err, stackTraces): any

Defined in: ../../../node_modules/@types/node/globals.d.ts:56

Error

CallSite[]

any

https://v8.dev/docs/stack-trace-api#customizing-stack-traces

Error.prepareStackTrace