@aerokit/sdk 12.67.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.
@@ -49,11 +49,14 @@ class Tracer {
49
49
  }
50
50
  getId() {
51
51
  const executionContext = import_bpm.Process.getExecutionContext();
52
- const processDefinitionId = executionContext.getProcessDefinitionId();
53
- const processInstanceId = executionContext.getProcessInstanceId();
54
- const businessKey = executionContext.getProcessInstanceBusinessKey();
55
- const activityId = executionContext.getCurrentActivityId();
56
- return `[${processDefinitionId}][${processInstanceId}][${businessKey}][${activityId}]`;
52
+ if (executionContext) {
53
+ const processDefinitionId = executionContext.getProcessDefinitionId();
54
+ const processInstanceId = executionContext.getProcessInstanceId();
55
+ const businessKey = executionContext.getProcessInstanceBusinessKey();
56
+ const activityId = executionContext.getCurrentActivityId();
57
+ return `[${processDefinitionId}][${processInstanceId}][${businessKey}][${activityId}]`;
58
+ }
59
+ return "[no-execution-context]";
57
60
  }
58
61
  }
59
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2JwbS90cmFjZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IFByb2Nlc3MgfSBmcm9tICdAYWVyb2tpdC9zZGsvYnBtJztcbmltcG9ydCB7IExvZ2dpbmcsIExvZ2dlciB9IGZyb20gXCJAYWVyb2tpdC9zZGsvbG9nXCI7XG5cbmV4cG9ydCBjbGFzcyBUcmFjZXIge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc3RhcnRUaW1lOiBEYXRlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgbG9nZ2VyOiBMb2dnZXI7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5zdGFydFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICB0aGlzLmxvZ2dlciA9IExvZ2dpbmcuZ2V0TG9nZ2VyKCdicG0udHJhY2VyJyk7XG4gICAgICAgIHRoaXMubG9nKCdTdGFydGVkJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGxvZyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyB3YXJuKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci53YXJuKGAke3RoaXMuZ2V0SWQoKX0gLSAke21lc3NhZ2UgPz8gJyd9YCk7XG4gICAgfVxuXG4gICAgcHVibGljIGVycm9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb21wbGV0ZShtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IGVuZFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICBjb25zdCBzZWNvbmRzID0gTWF0aC5jZWlsKChlbmRUaW1lLmdldFRpbWUoKSAtIHRoaXMuc3RhcnRUaW1lLmdldFRpbWUoKSkgLyAxMDAwKTtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gQ29tcGxldGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBmYWlsKG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgZW5kVGltZSA9IG5ldyBEYXRlKCk7XG4gICAgICAgIGNvbnN0IHNlY29uZHMgPSBNYXRoLmNlaWwoKGVuZFRpbWUuZ2V0VGltZSgpIC0gdGhpcy5zdGFydFRpbWUuZ2V0VGltZSgpKSAvIDEwMDApO1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gRmFpbGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0SWQoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgZXhlY3V0aW9uQ29udGV4dCA9IFByb2Nlc3MuZ2V0RXhlY3V0aW9uQ29udGV4dCgpO1xuICAgICAgICBjb25zdCBwcm9jZXNzRGVmaW5pdGlvbklkID0gZXhlY3V0aW9uQ29udGV4dC5nZXRQcm9jZXNzRGVmaW5pdGlvbklkKCk7XG4gICAgICAgIGNvbnN0IHByb2Nlc3NJbnN0YW5jZUlkID0gZXhlY3V0aW9uQ29udGV4dC5nZXRQcm9jZXNzSW5zdGFuY2VJZCgpO1xuICAgICAgICBjb25zdCBidXNpbmVzc0tleSA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0luc3RhbmNlQnVzaW5lc3NLZXkoKTtcbiAgICAgICAgY29uc3QgYWN0aXZpdHlJZCA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0Q3VycmVudEFjdGl2aXR5SWQoKTtcblxuICAgICAgICByZXR1cm4gYFske3Byb2Nlc3NEZWZpbml0aW9uSWR9XVske3Byb2Nlc3NJbnN0YW5jZUlkfV1bJHtidXNpbmVzc0tleX1dWyR7YWN0aXZpdHlJZH1dYDtcbiAgICB9XG59Il0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsaUJBQXdCO0FBQ3hCLGlCQUFnQztBQUV6QixNQUFNLE9BQU87QUFBQSxFQUloQixjQUFjO0FBQ1YsU0FBSyxZQUFZLG9CQUFJLEtBQUs7QUFDMUIsU0FBSyxTQUFTLG1CQUFRLFVBQVUsWUFBWTtBQUM1QyxTQUFLLElBQUksU0FBUztBQUFBLEVBQ3RCO0FBQUEsRUFFTyxJQUFJLFNBQWlCO0FBQ3hCLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQ3pEO0FBQUEsRUFFTyxLQUFLLFNBQWlCO0FBQ3pCLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQ3pEO0FBQUEsRUFFTyxNQUFNLFNBQWlCO0FBQzFCLFNBQUssT0FBTyxNQUFNLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzFEO0FBQUEsRUFFTyxTQUFTLFNBQWtCO0FBQzlCLFVBQU0sVUFBVSxvQkFBSSxLQUFLO0FBQ3pCLFVBQU0sVUFBVSxLQUFLLE1BQU0sUUFBUSxRQUFRLElBQUksS0FBSyxVQUFVLFFBQVEsS0FBSyxHQUFJO0FBQy9FLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsc0JBQXNCLE9BQU8sYUFBYSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzdGO0FBQUEsRUFFTyxLQUFLLFNBQWtCO0FBQzFCLFVBQU0sVUFBVSxvQkFBSSxLQUFLO0FBQ3pCLFVBQU0sVUFBVSxLQUFLLE1BQU0sUUFBUSxRQUFRLElBQUksS0FBSyxVQUFVLFFBQVEsS0FBSyxHQUFJO0FBQy9FLFNBQUssT0FBTyxNQUFNLEdBQUcsS0FBSyxNQUFNLENBQUMsbUJBQW1CLE9BQU8sYUFBYSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzNGO0FBQUEsRUFFUSxRQUFnQjtBQUNwQixVQUFNLG1CQUFtQixtQkFBUSxvQkFBb0I7QUFDckQsVUFBTSxzQkFBc0IsaUJBQWlCLHVCQUF1QjtBQUNwRSxVQUFNLG9CQUFvQixpQkFBaUIscUJBQXFCO0FBQ2hFLFVBQU0sY0FBYyxpQkFBaUIsOEJBQThCO0FBQ25FLFVBQU0sYUFBYSxpQkFBaUIscUJBQXFCO0FBRXpELFdBQU8sSUFBSSxtQkFBbUIsS0FBSyxpQkFBaUIsS0FBSyxXQUFXLEtBQUssVUFBVTtBQUFBLEVBQ3ZGO0FBQ0o7IiwKICAibmFtZXMiOiBbXQp9Cg==
62
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2JwbS90cmFjZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IFByb2Nlc3MgfSBmcm9tICdAYWVyb2tpdC9zZGsvYnBtJztcbmltcG9ydCB7IExvZ2dpbmcsIExvZ2dlciB9IGZyb20gXCJAYWVyb2tpdC9zZGsvbG9nXCI7XG5cbmV4cG9ydCBjbGFzcyBUcmFjZXIge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc3RhcnRUaW1lOiBEYXRlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgbG9nZ2VyOiBMb2dnZXI7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5zdGFydFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICB0aGlzLmxvZ2dlciA9IExvZ2dpbmcuZ2V0TG9nZ2VyKCdicG0udHJhY2VyJyk7XG4gICAgICAgIHRoaXMubG9nKCdTdGFydGVkJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGxvZyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyB3YXJuKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci53YXJuKGAke3RoaXMuZ2V0SWQoKX0gLSAke21lc3NhZ2UgPz8gJyd9YCk7XG4gICAgfVxuXG4gICAgcHVibGljIGVycm9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb21wbGV0ZShtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IGVuZFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICBjb25zdCBzZWNvbmRzID0gTWF0aC5jZWlsKChlbmRUaW1lLmdldFRpbWUoKSAtIHRoaXMuc3RhcnRUaW1lLmdldFRpbWUoKSkgLyAxMDAwKTtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gQ29tcGxldGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBmYWlsKG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgZW5kVGltZSA9IG5ldyBEYXRlKCk7XG4gICAgICAgIGNvbnN0IHNlY29uZHMgPSBNYXRoLmNlaWwoKGVuZFRpbWUuZ2V0VGltZSgpIC0gdGhpcy5zdGFydFRpbWUuZ2V0VGltZSgpKSAvIDEwMDApO1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gRmFpbGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0SWQoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgZXhlY3V0aW9uQ29udGV4dCA9IFByb2Nlc3MuZ2V0RXhlY3V0aW9uQ29udGV4dCgpO1xuICAgICAgICBpZiAoZXhlY3V0aW9uQ29udGV4dCkge1xuICAgICAgICAgICAgY29uc3QgcHJvY2Vzc0RlZmluaXRpb25JZCA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0RlZmluaXRpb25JZCgpO1xuICAgICAgICAgICAgY29uc3QgcHJvY2Vzc0luc3RhbmNlSWQgPSBleGVjdXRpb25Db250ZXh0LmdldFByb2Nlc3NJbnN0YW5jZUlkKCk7XG4gICAgICAgICAgICBjb25zdCBidXNpbmVzc0tleSA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0luc3RhbmNlQnVzaW5lc3NLZXkoKTtcbiAgICAgICAgICAgIGNvbnN0IGFjdGl2aXR5SWQgPSBleGVjdXRpb25Db250ZXh0LmdldEN1cnJlbnRBY3Rpdml0eUlkKCk7XG4gICAgICAgICAgICByZXR1cm4gYFske3Byb2Nlc3NEZWZpbml0aW9uSWR9XVske3Byb2Nlc3NJbnN0YW5jZUlkfV1bJHtidXNpbmVzc0tleX1dWyR7YWN0aXZpdHlJZH1dYDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gJ1tuby1leGVjdXRpb24tY29udGV4dF0nO1xuICAgIH1cbn0iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxpQkFBd0I7QUFDeEIsaUJBQWdDO0FBRXpCLE1BQU0sT0FBTztBQUFBLEVBSWhCLGNBQWM7QUFDVixTQUFLLFlBQVksb0JBQUksS0FBSztBQUMxQixTQUFLLFNBQVMsbUJBQVEsVUFBVSxZQUFZO0FBQzVDLFNBQUssSUFBSSxTQUFTO0FBQUEsRUFDdEI7QUFBQSxFQUVPLElBQUksU0FBaUI7QUFDeEIsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDekQ7QUFBQSxFQUVPLEtBQUssU0FBaUI7QUFDekIsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDekQ7QUFBQSxFQUVPLE1BQU0sU0FBaUI7QUFDMUIsU0FBSyxPQUFPLE1BQU0sR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDMUQ7QUFBQSxFQUVPLFNBQVMsU0FBa0I7QUFDOUIsVUFBTSxVQUFVLG9CQUFJLEtBQUs7QUFDekIsVUFBTSxVQUFVLEtBQUssTUFBTSxRQUFRLFFBQVEsSUFBSSxLQUFLLFVBQVUsUUFBUSxLQUFLLEdBQUk7QUFDL0UsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxzQkFBc0IsT0FBTyxhQUFhLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDN0Y7QUFBQSxFQUVPLEtBQUssU0FBa0I7QUFDMUIsVUFBTSxVQUFVLG9CQUFJLEtBQUs7QUFDekIsVUFBTSxVQUFVLEtBQUssTUFBTSxRQUFRLFFBQVEsSUFBSSxLQUFLLFVBQVUsUUFBUSxLQUFLLEdBQUk7QUFDL0UsU0FBSyxPQUFPLE1BQU0sR0FBRyxLQUFLLE1BQU0sQ0FBQyxtQkFBbUIsT0FBTyxhQUFhLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDM0Y7QUFBQSxFQUVRLFFBQWdCO0FBQ3BCLFVBQU0sbUJBQW1CLG1CQUFRLG9CQUFvQjtBQUNyRCxRQUFJLGtCQUFrQjtBQUNsQixZQUFNLHNCQUFzQixpQkFBaUIsdUJBQXVCO0FBQ3BFLFlBQU0sb0JBQW9CLGlCQUFpQixxQkFBcUI7QUFDaEUsWUFBTSxjQUFjLGlCQUFpQiw4QkFBOEI7QUFDbkUsWUFBTSxhQUFhLGlCQUFpQixxQkFBcUI7QUFDekQsYUFBTyxJQUFJLG1CQUFtQixLQUFLLGlCQUFpQixLQUFLLFdBQVcsS0FBSyxVQUFVO0FBQUEsSUFDdkY7QUFDQSxXQUFPO0FBQUEsRUFDWDtBQUNKOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -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": "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",
  "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.
@@ -27,14 +27,17 @@ class Tracer {
27
27
  }
28
28
  getId() {
29
29
  const executionContext = Process.getExecutionContext();
30
- const processDefinitionId = executionContext.getProcessDefinitionId();
31
- const processInstanceId = executionContext.getProcessInstanceId();
32
- const businessKey = executionContext.getProcessInstanceBusinessKey();
33
- const activityId = executionContext.getCurrentActivityId();
34
- return `[${processDefinitionId}][${processInstanceId}][${businessKey}][${activityId}]`;
30
+ if (executionContext) {
31
+ const processDefinitionId = executionContext.getProcessDefinitionId();
32
+ const processInstanceId = executionContext.getProcessInstanceId();
33
+ const businessKey = executionContext.getProcessInstanceBusinessKey();
34
+ const activityId = executionContext.getCurrentActivityId();
35
+ return `[${processDefinitionId}][${processInstanceId}][${businessKey}][${activityId}]`;
36
+ }
37
+ return "[no-execution-context]";
35
38
  }
36
39
  }
37
40
  export {
38
41
  Tracer
39
42
  };
40
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2JwbS90cmFjZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IFByb2Nlc3MgfSBmcm9tICdAYWVyb2tpdC9zZGsvYnBtJztcbmltcG9ydCB7IExvZ2dpbmcsIExvZ2dlciB9IGZyb20gXCJAYWVyb2tpdC9zZGsvbG9nXCI7XG5cbmV4cG9ydCBjbGFzcyBUcmFjZXIge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc3RhcnRUaW1lOiBEYXRlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgbG9nZ2VyOiBMb2dnZXI7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5zdGFydFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICB0aGlzLmxvZ2dlciA9IExvZ2dpbmcuZ2V0TG9nZ2VyKCdicG0udHJhY2VyJyk7XG4gICAgICAgIHRoaXMubG9nKCdTdGFydGVkJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGxvZyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyB3YXJuKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci53YXJuKGAke3RoaXMuZ2V0SWQoKX0gLSAke21lc3NhZ2UgPz8gJyd9YCk7XG4gICAgfVxuXG4gICAgcHVibGljIGVycm9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb21wbGV0ZShtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IGVuZFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICBjb25zdCBzZWNvbmRzID0gTWF0aC5jZWlsKChlbmRUaW1lLmdldFRpbWUoKSAtIHRoaXMuc3RhcnRUaW1lLmdldFRpbWUoKSkgLyAxMDAwKTtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gQ29tcGxldGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBmYWlsKG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgZW5kVGltZSA9IG5ldyBEYXRlKCk7XG4gICAgICAgIGNvbnN0IHNlY29uZHMgPSBNYXRoLmNlaWwoKGVuZFRpbWUuZ2V0VGltZSgpIC0gdGhpcy5zdGFydFRpbWUuZ2V0VGltZSgpKSAvIDEwMDApO1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gRmFpbGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0SWQoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgZXhlY3V0aW9uQ29udGV4dCA9IFByb2Nlc3MuZ2V0RXhlY3V0aW9uQ29udGV4dCgpO1xuICAgICAgICBjb25zdCBwcm9jZXNzRGVmaW5pdGlvbklkID0gZXhlY3V0aW9uQ29udGV4dC5nZXRQcm9jZXNzRGVmaW5pdGlvbklkKCk7XG4gICAgICAgIGNvbnN0IHByb2Nlc3NJbnN0YW5jZUlkID0gZXhlY3V0aW9uQ29udGV4dC5nZXRQcm9jZXNzSW5zdGFuY2VJZCgpO1xuICAgICAgICBjb25zdCBidXNpbmVzc0tleSA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0luc3RhbmNlQnVzaW5lc3NLZXkoKTtcbiAgICAgICAgY29uc3QgYWN0aXZpdHlJZCA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0Q3VycmVudEFjdGl2aXR5SWQoKTtcblxuICAgICAgICByZXR1cm4gYFske3Byb2Nlc3NEZWZpbml0aW9uSWR9XVske3Byb2Nlc3NJbnN0YW5jZUlkfV1bJHtidXNpbmVzc0tleX1dWyR7YWN0aXZpdHlJZH1dYDtcbiAgICB9XG59Il0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUyxlQUFlO0FBQ3hCLFNBQVMsZUFBdUI7QUFFekIsTUFBTSxPQUFPO0FBQUEsRUFJaEIsY0FBYztBQUNWLFNBQUssWUFBWSxvQkFBSSxLQUFLO0FBQzFCLFNBQUssU0FBUyxRQUFRLFVBQVUsWUFBWTtBQUM1QyxTQUFLLElBQUksU0FBUztBQUFBLEVBQ3RCO0FBQUEsRUFFTyxJQUFJLFNBQWlCO0FBQ3hCLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQ3pEO0FBQUEsRUFFTyxLQUFLLFNBQWlCO0FBQ3pCLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQ3pEO0FBQUEsRUFFTyxNQUFNLFNBQWlCO0FBQzFCLFNBQUssT0FBTyxNQUFNLEdBQUcsS0FBSyxNQUFNLENBQUMsTUFBTSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzFEO0FBQUEsRUFFTyxTQUFTLFNBQWtCO0FBQzlCLFVBQU0sVUFBVSxvQkFBSSxLQUFLO0FBQ3pCLFVBQU0sVUFBVSxLQUFLLE1BQU0sUUFBUSxRQUFRLElBQUksS0FBSyxVQUFVLFFBQVEsS0FBSyxHQUFJO0FBQy9FLFNBQUssT0FBTyxLQUFLLEdBQUcsS0FBSyxNQUFNLENBQUMsc0JBQXNCLE9BQU8sYUFBYSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzdGO0FBQUEsRUFFTyxLQUFLLFNBQWtCO0FBQzFCLFVBQU0sVUFBVSxvQkFBSSxLQUFLO0FBQ3pCLFVBQU0sVUFBVSxLQUFLLE1BQU0sUUFBUSxRQUFRLElBQUksS0FBSyxVQUFVLFFBQVEsS0FBSyxHQUFJO0FBQy9FLFNBQUssT0FBTyxNQUFNLEdBQUcsS0FBSyxNQUFNLENBQUMsbUJBQW1CLE9BQU8sYUFBYSxXQUFXLEVBQUUsRUFBRTtBQUFBLEVBQzNGO0FBQUEsRUFFUSxRQUFnQjtBQUNwQixVQUFNLG1CQUFtQixRQUFRLG9CQUFvQjtBQUNyRCxVQUFNLHNCQUFzQixpQkFBaUIsdUJBQXVCO0FBQ3BFLFVBQU0sb0JBQW9CLGlCQUFpQixxQkFBcUI7QUFDaEUsVUFBTSxjQUFjLGlCQUFpQiw4QkFBOEI7QUFDbkUsVUFBTSxhQUFhLGlCQUFpQixxQkFBcUI7QUFFekQsV0FBTyxJQUFJLG1CQUFtQixLQUFLLGlCQUFpQixLQUFLLFdBQVcsS0FBSyxVQUFVO0FBQUEsRUFDdkY7QUFDSjsiLAogICJuYW1lcyI6IFtdCn0K
43
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2JwbS90cmFjZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IFByb2Nlc3MgfSBmcm9tICdAYWVyb2tpdC9zZGsvYnBtJztcbmltcG9ydCB7IExvZ2dpbmcsIExvZ2dlciB9IGZyb20gXCJAYWVyb2tpdC9zZGsvbG9nXCI7XG5cbmV4cG9ydCBjbGFzcyBUcmFjZXIge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc3RhcnRUaW1lOiBEYXRlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgbG9nZ2VyOiBMb2dnZXI7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5zdGFydFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICB0aGlzLmxvZ2dlciA9IExvZ2dpbmcuZ2V0TG9nZ2VyKCdicG0udHJhY2VyJyk7XG4gICAgICAgIHRoaXMubG9nKCdTdGFydGVkJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGxvZyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyB3YXJuKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci53YXJuKGAke3RoaXMuZ2V0SWQoKX0gLSAke21lc3NhZ2UgPz8gJyd9YCk7XG4gICAgfVxuXG4gICAgcHVibGljIGVycm9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb21wbGV0ZShtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IGVuZFRpbWUgPSBuZXcgRGF0ZSgpO1xuICAgICAgICBjb25zdCBzZWNvbmRzID0gTWF0aC5jZWlsKChlbmRUaW1lLmdldFRpbWUoKSAtIHRoaXMuc3RhcnRUaW1lLmdldFRpbWUoKSkgLyAxMDAwKTtcbiAgICAgICAgdGhpcy5sb2dnZXIuaW5mbyhgJHt0aGlzLmdldElkKCl9IC0gQ29tcGxldGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHB1YmxpYyBmYWlsKG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgZW5kVGltZSA9IG5ldyBEYXRlKCk7XG4gICAgICAgIGNvbnN0IHNlY29uZHMgPSBNYXRoLmNlaWwoKGVuZFRpbWUuZ2V0VGltZSgpIC0gdGhpcy5zdGFydFRpbWUuZ2V0VGltZSgpKSAvIDEwMDApO1xuICAgICAgICB0aGlzLmxvZ2dlci5lcnJvcihgJHt0aGlzLmdldElkKCl9IC0gRmFpbGVkIGFmdGVyICR7c2Vjb25kc30gc2Vjb25kcy4gJHttZXNzYWdlID8/ICcnfWApO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0SWQoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgZXhlY3V0aW9uQ29udGV4dCA9IFByb2Nlc3MuZ2V0RXhlY3V0aW9uQ29udGV4dCgpO1xuICAgICAgICBpZiAoZXhlY3V0aW9uQ29udGV4dCkge1xuICAgICAgICAgICAgY29uc3QgcHJvY2Vzc0RlZmluaXRpb25JZCA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0RlZmluaXRpb25JZCgpO1xuICAgICAgICAgICAgY29uc3QgcHJvY2Vzc0luc3RhbmNlSWQgPSBleGVjdXRpb25Db250ZXh0LmdldFByb2Nlc3NJbnN0YW5jZUlkKCk7XG4gICAgICAgICAgICBjb25zdCBidXNpbmVzc0tleSA9IGV4ZWN1dGlvbkNvbnRleHQuZ2V0UHJvY2Vzc0luc3RhbmNlQnVzaW5lc3NLZXkoKTtcbiAgICAgICAgICAgIGNvbnN0IGFjdGl2aXR5SWQgPSBleGVjdXRpb25Db250ZXh0LmdldEN1cnJlbnRBY3Rpdml0eUlkKCk7XG4gICAgICAgICAgICByZXR1cm4gYFske3Byb2Nlc3NEZWZpbml0aW9uSWR9XVske3Byb2Nlc3NJbnN0YW5jZUlkfV1bJHtidXNpbmVzc0tleX1dWyR7YWN0aXZpdHlJZH1dYDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gJ1tuby1leGVjdXRpb24tY29udGV4dF0nO1xuICAgIH1cbn0iXSwKICAibWFwcGluZ3MiOiAiQUFBQSxTQUFTLGVBQWU7QUFDeEIsU0FBUyxlQUF1QjtBQUV6QixNQUFNLE9BQU87QUFBQSxFQUloQixjQUFjO0FBQ1YsU0FBSyxZQUFZLG9CQUFJLEtBQUs7QUFDMUIsU0FBSyxTQUFTLFFBQVEsVUFBVSxZQUFZO0FBQzVDLFNBQUssSUFBSSxTQUFTO0FBQUEsRUFDdEI7QUFBQSxFQUVPLElBQUksU0FBaUI7QUFDeEIsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDekQ7QUFBQSxFQUVPLEtBQUssU0FBaUI7QUFDekIsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDekQ7QUFBQSxFQUVPLE1BQU0sU0FBaUI7QUFDMUIsU0FBSyxPQUFPLE1BQU0sR0FBRyxLQUFLLE1BQU0sQ0FBQyxNQUFNLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDMUQ7QUFBQSxFQUVPLFNBQVMsU0FBa0I7QUFDOUIsVUFBTSxVQUFVLG9CQUFJLEtBQUs7QUFDekIsVUFBTSxVQUFVLEtBQUssTUFBTSxRQUFRLFFBQVEsSUFBSSxLQUFLLFVBQVUsUUFBUSxLQUFLLEdBQUk7QUFDL0UsU0FBSyxPQUFPLEtBQUssR0FBRyxLQUFLLE1BQU0sQ0FBQyxzQkFBc0IsT0FBTyxhQUFhLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDN0Y7QUFBQSxFQUVPLEtBQUssU0FBa0I7QUFDMUIsVUFBTSxVQUFVLG9CQUFJLEtBQUs7QUFDekIsVUFBTSxVQUFVLEtBQUssTUFBTSxRQUFRLFFBQVEsSUFBSSxLQUFLLFVBQVUsUUFBUSxLQUFLLEdBQUk7QUFDL0UsU0FBSyxPQUFPLE1BQU0sR0FBRyxLQUFLLE1BQU0sQ0FBQyxtQkFBbUIsT0FBTyxhQUFhLFdBQVcsRUFBRSxFQUFFO0FBQUEsRUFDM0Y7QUFBQSxFQUVRLFFBQWdCO0FBQ3BCLFVBQU0sbUJBQW1CLFFBQVEsb0JBQW9CO0FBQ3JELFFBQUksa0JBQWtCO0FBQ2xCLFlBQU0sc0JBQXNCLGlCQUFpQix1QkFBdUI7QUFDcEUsWUFBTSxvQkFBb0IsaUJBQWlCLHFCQUFxQjtBQUNoRSxZQUFNLGNBQWMsaUJBQWlCLDhCQUE4QjtBQUNuRSxZQUFNLGFBQWEsaUJBQWlCLHFCQUFxQjtBQUN6RCxhQUFPLElBQUksbUJBQW1CLEtBQUssaUJBQWlCLEtBQUssV0FBVyxLQUFLLFVBQVU7QUFBQSxJQUN2RjtBQUNBLFdBQU87QUFBQSxFQUNYO0FBQ0o7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -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": "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",
  "names": []
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aerokit/sdk",
3
- "version": "12.67.0",
3
+ "version": "12.69.0",
4
4
  "description": "Unified TypeScript SDK for modern cloud platforms.",
5
5
  "scripts": {
6
6
  "clean": "rm -rf dist",