@aerokit/sdk 12.68.0 → 12.69.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -18,13 +18,17 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
18
18
|
var decorators_exports = {};
|
|
19
19
|
__export(decorators_exports, {
|
|
20
20
|
Column: () => Column,
|
|
21
|
+
CreatedAt: () => CreatedAt,
|
|
22
|
+
CreatedBy: () => CreatedBy,
|
|
21
23
|
Documentation: () => Documentation,
|
|
22
24
|
Entity: () => Entity,
|
|
23
25
|
Generated: () => Generated,
|
|
24
26
|
Id: () => Id,
|
|
25
27
|
ManyToOne: () => ManyToOne,
|
|
26
28
|
OneToMany: () => OneToMany,
|
|
27
|
-
Table: () => Table
|
|
29
|
+
Table: () => Table,
|
|
30
|
+
UpdatedAt: () => UpdatedAt,
|
|
31
|
+
UpdatedBy: () => UpdatedBy
|
|
28
32
|
});
|
|
29
33
|
module.exports = __toCommonJS(decorators_exports);
|
|
30
34
|
const globalCache = globalThis.__decorator_metadata_cache__ || (globalThis.__decorator_metadata_cache__ = /* @__PURE__ */ new WeakMap());
|
|
@@ -53,11 +57,19 @@ function createPropertyDecorator(kind, options) {
|
|
|
53
57
|
metadata = {
|
|
54
58
|
propertyName,
|
|
55
59
|
isId: false,
|
|
60
|
+
isCreatedAt: false,
|
|
61
|
+
isUpdatedAt: false,
|
|
62
|
+
isCreatedBy: false,
|
|
63
|
+
isUpdatedBy: false,
|
|
56
64
|
isGenerated: false
|
|
57
65
|
};
|
|
58
66
|
metadataArray.push(metadata);
|
|
59
67
|
}
|
|
60
68
|
if (kind === "id") metadata.isId = true;
|
|
69
|
+
if (kind === "createdAt") metadata.isCreatedAt = true;
|
|
70
|
+
if (kind === "updatedAt") metadata.isUpdatedAt = true;
|
|
71
|
+
if (kind === "createdBy") metadata.isCreatedBy = true;
|
|
72
|
+
if (kind === "updatedBy") metadata.isUpdatedBy = true;
|
|
61
73
|
if (kind === "generated") metadata.isGenerated = true;
|
|
62
74
|
if (kind === "column") metadata.columnOptions = options;
|
|
63
75
|
});
|
|
@@ -82,6 +94,10 @@ function Documentation(description) {
|
|
|
82
94
|
metadata = {
|
|
83
95
|
propertyName,
|
|
84
96
|
isId: false,
|
|
97
|
+
isCreatedAt: false,
|
|
98
|
+
isUpdatedAt: false,
|
|
99
|
+
isCreatedBy: false,
|
|
100
|
+
isUpdatedBy: false,
|
|
85
101
|
isGenerated: false
|
|
86
102
|
};
|
|
87
103
|
metadataArray.push(metadata);
|
|
@@ -119,6 +135,10 @@ function Table(tableName) {
|
|
|
119
135
|
}
|
|
120
136
|
const Column = (options) => createPropertyDecorator("column", options);
|
|
121
137
|
const Id = () => createPropertyDecorator("id");
|
|
138
|
+
const CreatedAt = () => createPropertyDecorator("createdAt");
|
|
139
|
+
const UpdatedAt = () => createPropertyDecorator("updatedAt");
|
|
140
|
+
const CreatedBy = () => createPropertyDecorator("createdBy");
|
|
141
|
+
const UpdatedBy = () => createPropertyDecorator("updatedBy");
|
|
122
142
|
const Generated = (strategy) => createPropertyDecorator("generated");
|
|
123
143
|
function OneToMany(typeFunction, options) {
|
|
124
144
|
return function(_, context) {
|
|
@@ -134,6 +154,10 @@ function OneToMany(typeFunction, options) {
|
|
|
134
154
|
metadata = {
|
|
135
155
|
propertyName,
|
|
136
156
|
isId: false,
|
|
157
|
+
isCreatedAt: false,
|
|
158
|
+
isUpdatedAt: false,
|
|
159
|
+
isCreatedBy: false,
|
|
160
|
+
isUpdatedBy: false,
|
|
137
161
|
isGenerated: false
|
|
138
162
|
};
|
|
139
163
|
metadataArray.push(metadata);
|
|
@@ -156,6 +180,10 @@ function ManyToOne(typeFunction, options = {}) {
|
|
|
156
180
|
metadata = {
|
|
157
181
|
propertyName,
|
|
158
182
|
isId: false,
|
|
183
|
+
isCreatedAt: false,
|
|
184
|
+
isUpdatedAt: false,
|
|
185
|
+
isCreatedBy: false,
|
|
186
|
+
isUpdatedBy: false,
|
|
159
187
|
isGenerated: false
|
|
160
188
|
};
|
|
161
189
|
metadataArray.push(metadata);
|
|
@@ -164,4 +192,4 @@ function ManyToOne(typeFunction, options = {}) {
|
|
|
164
192
|
});
|
|
165
193
|
};
|
|
166
194
|
}
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "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",
  "names": []
}

|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isCreatedAt: boolean;\n  isUpdatedAt: boolean;\n  isCreatedBy: boolean;\n  isUpdatedBy: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\" | \"createdAt\" | \"updatedAt\" | \"createdBy\" | \"updatedBy\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n\t  if (kind === \"createdAt\") metadata.isCreatedAt = true;\n\t  if (kind === \"updatedAt\") metadata.isUpdatedAt = true;\n\t  if (kind === \"createdBy\") metadata.isCreatedBy = true;\n\t  if (kind === \"updatedBy\") metadata.isUpdatedBy = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n\t\t\tisCreatedAt: false,\n\t\t\tisUpdatedAt: false,\n\t\t\tisCreatedBy: false,\n\t\t\tisUpdatedBy: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as the entity's created at timestamp.\n */\nexport const CreatedAt = () => createPropertyDecorator(\"createdAt\");\n\n/**\n * Marks a property as the entity's update at timestamp.\n */\nexport const UpdatedAt = () => createPropertyDecorator(\"updatedAt\");\n\n/**\n * Marks a property as the entity's creation actor.\n */\nexport const CreatedBy = () => createPropertyDecorator(\"createdBy\");\n\n/**\n * Marks a property as the entity's update actor.\n */\nexport const UpdatedBy = () => createPropertyDecorator(\"updatedBy\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6FA,MAAM,cACH,WAAmB,iCAClB,WAAmB,+BAA+B,oBAAI,QAAQ;AAElE,SAAS,iBAAiB,aAA2C;AACnE,MAAI,CAAC,YAAY,IAAI,WAAW,GAAG;AACjC,gBAAY,IAAI,aAAa,CAAC,CAAC;AAAA,EACjC;AACA,SAAO,YAAY,IAAI,WAAW;AACpC;AAGA,SAAS,MAAM,IAAsB;AAEnC,UAAQ,QAAQ,EAAE,KAAK,EAAE;AAC3B;AAGA,SAAS,wBACP,MACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,SAAS;AAC5B,YAAM,IAAI,MAAM,IAAI,IAAI,uBAAuB;AAAA,IACjD;AAEA,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,UAAI,SAAS,KAAM,UAAS,OAAO;AACtC,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AAC9C,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,SAAU,UAAS,gBAAgB;AAAA,IAClD,CAAC;AAAA,EACH;AACF;AAMO,SAAS,cAAc,aAAqB;AACjD,SAAO,SACL,OACA,SACA;AACA,QAAI,QAAQ,SAAS,SAAS;AAC5B,cAAQ,eAAe,WAAY;AACjC,QAAC,MAA4B,iBAAiB;AAAA,MAChD,CAAC;AACD,aAAO;AAAA,IACT,WAAW,QAAQ,SAAS,SAAS;AACnC,cAAQ,eAAe,WAAY;AACjC,cAAM,OAAQ,KAAa;AAC3B,cAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,cAAM,gBAAgB,iBAAiB,IAAI;AAE3C,YAAI,WAAW,cAAc;AAAA,UAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,QAC5B;AAEA,YAAI,CAAC,UAAU;AACb,qBAAW;AAAA,YACT;AAAA,YACA,MAAM;AAAA,YACf,aAAa;AAAA,YACb,aAAa;AAAA,YACb,aAAa;AAAA,YACb,aAAa;AAAA,YACJ,aAAa;AAAA,UACf;AACA,wBAAc,KAAK,QAAQ;AAAA,QAC7B;AAEA,iBAAS,gBAAgB;AAAA,MAC3B,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAQO,SAAS,OAAO,YAAqB;AAC1C,SAAO,SAAU,OAAiB,SAAgC;AAChE,YAAQ,eAAe,WAAY;AAEjC,YAAM,MAAM;AACV,cAAM,OAAO;AAGb,YAAI,KAAK,aAAc;AACvB,aAAK,eAAe;AAEpB,aAAK,eAAe,cAAc,KAAK;AAEvC,cAAM,gBAAgB,iBAAiB,IAAI;AAC3C,cAAM,aAAa,cAAc,KAAK,CAAC,MAAM,EAAE,IAAI;AAEnD,YAAI,YAAY;AACd,eAAK,WAAW,WAAW;AAE3B,eAAK,aACH,WAAW,eAAe,QAC1B,WAAW,aAAa,YAAY;AAAA,QACxC;AAAA,MAGF,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;AAOO,SAAS,MAAM,WAAoB;AACxC,SAAO,SACL,OACA,SACA;AACA,YAAQ,eAAe,WAAY;AACjC,MAAC,MAA4B,cAC3B,cAAc,QAAQ,MAAM,SAAS,KAAK,MAAM,KAAK,YAAY;AAAA,IACrE,CAAC;AAED,WAAO;AAAA,EACT;AACF;AAMO,MAAM,SAAS,CAAC,YACrB,wBAAwB,UAAU,OAAO;AAKpC,MAAM,KAAK,MAAM,wBAAwB,IAAI;AAK7C,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAM3D,MAAM,YAAY,CAAC,aACxB,wBAAwB,WAAW;AAK9B,SAAS,UACd,cACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;AAKO,SAAS,UACd,cACA,UAA4B,CAAC,GAC7B;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;",
  "names": []
}

|
|
@@ -76,6 +76,22 @@ export declare const Column: (options?: ColumnOptions) => (_: any, context: Clas
|
|
|
76
76
|
* Marks a property as the entity's primary key.
|
|
77
77
|
*/
|
|
78
78
|
export declare const Id: () => (_: any, context: ClassFieldDecoratorContext) => void;
|
|
79
|
+
/**
|
|
80
|
+
* Marks a property as the entity's created at timestamp.
|
|
81
|
+
*/
|
|
82
|
+
export declare const CreatedAt: () => (_: any, context: ClassFieldDecoratorContext) => void;
|
|
83
|
+
/**
|
|
84
|
+
* Marks a property as the entity's update at timestamp.
|
|
85
|
+
*/
|
|
86
|
+
export declare const UpdatedAt: () => (_: any, context: ClassFieldDecoratorContext) => void;
|
|
87
|
+
/**
|
|
88
|
+
* Marks a property as the entity's creation actor.
|
|
89
|
+
*/
|
|
90
|
+
export declare const CreatedBy: () => (_: any, context: ClassFieldDecoratorContext) => void;
|
|
91
|
+
/**
|
|
92
|
+
* Marks a property as the entity's update actor.
|
|
93
|
+
*/
|
|
94
|
+
export declare const UpdatedBy: () => (_: any, context: ClassFieldDecoratorContext) => void;
|
|
79
95
|
/**
|
|
80
96
|
* Marks a property as a generated value (e.g., auto-increment).
|
|
81
97
|
* @param strategy The generation strategy (e.g., "IDENTITY"). Parameter is currently unused in logic.
|
|
@@ -24,11 +24,19 @@ function createPropertyDecorator(kind, options) {
|
|
|
24
24
|
metadata = {
|
|
25
25
|
propertyName,
|
|
26
26
|
isId: false,
|
|
27
|
+
isCreatedAt: false,
|
|
28
|
+
isUpdatedAt: false,
|
|
29
|
+
isCreatedBy: false,
|
|
30
|
+
isUpdatedBy: false,
|
|
27
31
|
isGenerated: false
|
|
28
32
|
};
|
|
29
33
|
metadataArray.push(metadata);
|
|
30
34
|
}
|
|
31
35
|
if (kind === "id") metadata.isId = true;
|
|
36
|
+
if (kind === "createdAt") metadata.isCreatedAt = true;
|
|
37
|
+
if (kind === "updatedAt") metadata.isUpdatedAt = true;
|
|
38
|
+
if (kind === "createdBy") metadata.isCreatedBy = true;
|
|
39
|
+
if (kind === "updatedBy") metadata.isUpdatedBy = true;
|
|
32
40
|
if (kind === "generated") metadata.isGenerated = true;
|
|
33
41
|
if (kind === "column") metadata.columnOptions = options;
|
|
34
42
|
});
|
|
@@ -53,6 +61,10 @@ function Documentation(description) {
|
|
|
53
61
|
metadata = {
|
|
54
62
|
propertyName,
|
|
55
63
|
isId: false,
|
|
64
|
+
isCreatedAt: false,
|
|
65
|
+
isUpdatedAt: false,
|
|
66
|
+
isCreatedBy: false,
|
|
67
|
+
isUpdatedBy: false,
|
|
56
68
|
isGenerated: false
|
|
57
69
|
};
|
|
58
70
|
metadataArray.push(metadata);
|
|
@@ -90,6 +102,10 @@ function Table(tableName) {
|
|
|
90
102
|
}
|
|
91
103
|
const Column = (options) => createPropertyDecorator("column", options);
|
|
92
104
|
const Id = () => createPropertyDecorator("id");
|
|
105
|
+
const CreatedAt = () => createPropertyDecorator("createdAt");
|
|
106
|
+
const UpdatedAt = () => createPropertyDecorator("updatedAt");
|
|
107
|
+
const CreatedBy = () => createPropertyDecorator("createdBy");
|
|
108
|
+
const UpdatedBy = () => createPropertyDecorator("updatedBy");
|
|
93
109
|
const Generated = (strategy) => createPropertyDecorator("generated");
|
|
94
110
|
function OneToMany(typeFunction, options) {
|
|
95
111
|
return function(_, context) {
|
|
@@ -105,6 +121,10 @@ function OneToMany(typeFunction, options) {
|
|
|
105
121
|
metadata = {
|
|
106
122
|
propertyName,
|
|
107
123
|
isId: false,
|
|
124
|
+
isCreatedAt: false,
|
|
125
|
+
isUpdatedAt: false,
|
|
126
|
+
isCreatedBy: false,
|
|
127
|
+
isUpdatedBy: false,
|
|
108
128
|
isGenerated: false
|
|
109
129
|
};
|
|
110
130
|
metadataArray.push(metadata);
|
|
@@ -127,6 +147,10 @@ function ManyToOne(typeFunction, options = {}) {
|
|
|
127
147
|
metadata = {
|
|
128
148
|
propertyName,
|
|
129
149
|
isId: false,
|
|
150
|
+
isCreatedAt: false,
|
|
151
|
+
isUpdatedAt: false,
|
|
152
|
+
isCreatedBy: false,
|
|
153
|
+
isUpdatedBy: false,
|
|
130
154
|
isGenerated: false
|
|
131
155
|
};
|
|
132
156
|
metadataArray.push(metadata);
|
|
@@ -137,12 +161,16 @@ function ManyToOne(typeFunction, options = {}) {
|
|
|
137
161
|
}
|
|
138
162
|
export {
|
|
139
163
|
Column,
|
|
164
|
+
CreatedAt,
|
|
165
|
+
CreatedBy,
|
|
140
166
|
Documentation,
|
|
141
167
|
Entity,
|
|
142
168
|
Generated,
|
|
143
169
|
Id,
|
|
144
170
|
ManyToOne,
|
|
145
171
|
OneToMany,
|
|
146
|
-
Table
|
|
172
|
+
Table,
|
|
173
|
+
UpdatedAt,
|
|
174
|
+
UpdatedBy
|
|
147
175
|
};
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "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",
  "names": []
}

|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isCreatedAt: boolean;\n  isUpdatedAt: boolean;\n  isCreatedBy: boolean;\n  isUpdatedBy: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\" | \"createdAt\" | \"updatedAt\" | \"createdBy\" | \"updatedBy\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n\t  if (kind === \"createdAt\") metadata.isCreatedAt = true;\n\t  if (kind === \"updatedAt\") metadata.isUpdatedAt = true;\n\t  if (kind === \"createdBy\") metadata.isCreatedBy = true;\n\t  if (kind === \"updatedBy\") metadata.isUpdatedBy = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n\t\t\tisCreatedAt: false,\n\t\t\tisUpdatedAt: false,\n\t\t\tisCreatedBy: false,\n\t\t\tisUpdatedBy: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as the entity's created at timestamp.\n */\nexport const CreatedAt = () => createPropertyDecorator(\"createdAt\");\n\n/**\n * Marks a property as the entity's update at timestamp.\n */\nexport const UpdatedAt = () => createPropertyDecorator(\"updatedAt\");\n\n/**\n * Marks a property as the entity's creation actor.\n */\nexport const CreatedBy = () => createPropertyDecorator(\"createdBy\");\n\n/**\n * Marks a property as the entity's update actor.\n */\nexport const UpdatedBy = () => createPropertyDecorator(\"updatedBy\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n\t\t  isCreatedAt: false,\n\t\t  isUpdatedAt: false,\n\t\t  isCreatedBy: false,\n\t\t  isUpdatedBy: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "AA6FA,MAAM,cACH,WAAmB,iCAClB,WAAmB,+BAA+B,oBAAI,QAAQ;AAElE,SAAS,iBAAiB,aAA2C;AACnE,MAAI,CAAC,YAAY,IAAI,WAAW,GAAG;AACjC,gBAAY,IAAI,aAAa,CAAC,CAAC;AAAA,EACjC;AACA,SAAO,YAAY,IAAI,WAAW;AACpC;AAGA,SAAS,MAAM,IAAsB;AAEnC,UAAQ,QAAQ,EAAE,KAAK,EAAE;AAC3B;AAGA,SAAS,wBACP,MACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,SAAS;AAC5B,YAAM,IAAI,MAAM,IAAI,IAAI,uBAAuB;AAAA,IACjD;AAEA,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,UAAI,SAAS,KAAM,UAAS,OAAO;AACtC,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,YAAa,UAAS,cAAc;AAC9C,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,SAAU,UAAS,gBAAgB;AAAA,IAClD,CAAC;AAAA,EACH;AACF;AAMO,SAAS,cAAc,aAAqB;AACjD,SAAO,SACL,OACA,SACA;AACA,QAAI,QAAQ,SAAS,SAAS;AAC5B,cAAQ,eAAe,WAAY;AACjC,QAAC,MAA4B,iBAAiB;AAAA,MAChD,CAAC;AACD,aAAO;AAAA,IACT,WAAW,QAAQ,SAAS,SAAS;AACnC,cAAQ,eAAe,WAAY;AACjC,cAAM,OAAQ,KAAa;AAC3B,cAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,cAAM,gBAAgB,iBAAiB,IAAI;AAE3C,YAAI,WAAW,cAAc;AAAA,UAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,QAC5B;AAEA,YAAI,CAAC,UAAU;AACb,qBAAW;AAAA,YACT;AAAA,YACA,MAAM;AAAA,YACf,aAAa;AAAA,YACb,aAAa;AAAA,YACb,aAAa;AAAA,YACb,aAAa;AAAA,YACJ,aAAa;AAAA,UACf;AACA,wBAAc,KAAK,QAAQ;AAAA,QAC7B;AAEA,iBAAS,gBAAgB;AAAA,MAC3B,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAQO,SAAS,OAAO,YAAqB;AAC1C,SAAO,SAAU,OAAiB,SAAgC;AAChE,YAAQ,eAAe,WAAY;AAEjC,YAAM,MAAM;AACV,cAAM,OAAO;AAGb,YAAI,KAAK,aAAc;AACvB,aAAK,eAAe;AAEpB,aAAK,eAAe,cAAc,KAAK;AAEvC,cAAM,gBAAgB,iBAAiB,IAAI;AAC3C,cAAM,aAAa,cAAc,KAAK,CAAC,MAAM,EAAE,IAAI;AAEnD,YAAI,YAAY;AACd,eAAK,WAAW,WAAW;AAE3B,eAAK,aACH,WAAW,eAAe,QAC1B,WAAW,aAAa,YAAY;AAAA,QACxC;AAAA,MAGF,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;AAOO,SAAS,MAAM,WAAoB;AACxC,SAAO,SACL,OACA,SACA;AACA,YAAQ,eAAe,WAAY;AACjC,MAAC,MAA4B,cAC3B,cAAc,QAAQ,MAAM,SAAS,KAAK,MAAM,KAAK,YAAY;AAAA,IACrE,CAAC;AAED,WAAO;AAAA,EACT;AACF;AAMO,MAAM,SAAS,CAAC,YACrB,wBAAwB,UAAU,OAAO;AAKpC,MAAM,KAAK,MAAM,wBAAwB,IAAI;AAK7C,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAK3D,MAAM,YAAY,MAAM,wBAAwB,WAAW;AAM3D,MAAM,YAAY,CAAC,aACxB,wBAAwB,WAAW;AAK9B,SAAS,UACd,cACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;AAKO,SAAS,UACd,cACA,UAA4B,CAAC,GAC7B;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACZ,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACb,aAAa;AAAA,UACP,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;",
  "names": []
}

|