JsonHookContext
Usage
import { JsonHookContext } from "@tsed/schema";See /packages/specs/schema/src/interfaces/JsonHookContext.ts.
Overview
interface JsonHookContext extends TsED.JsonHookContext {
self: any;
groups?: string[] | false;
[key: string]: any;
}Description
Context object passed to JSON schema hooks during serialization and schema generation.
This context provides information about the current serialization state, including the target instance, active groups, and extensible custom properties. It enables hooks to make context-aware decisions during schema generation and transformation.
The interface is extensible via TypeScript module augmentation, allowing packages to add custom context properties through the TsED.JsonHookContext namespace.
Usage
import {JsonHookContext} from "@tsed/schema";
function myHook(value: any, ctx: JsonHookContext) {
// Access the target instance
console.log(ctx.self);
// Check active groups
if (ctx.groups?.includes('admin')) {
// Apply admin-specific transformations
}
}self
self: any;The current instance used by serializer function
groups
groups?: string[] | false;Active groups for conditional schema generation.
When set to an array, only properties belonging to these groups will be included. When set to false, group filtering is disabled.
[key: string]
[key: string]: any;