@decaf-ts/for-typeorm 0.0.6

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.
Files changed (109) hide show
  1. package/LICENSE.md +21 -0
  2. package/README.md +93 -0
  3. package/dist/for-typeorm.cjs +2553 -0
  4. package/dist/for-typeorm.esm.cjs +2538 -0
  5. package/lib/TypeORMAdapter.cjs +1129 -0
  6. package/lib/TypeORMAdapter.d.ts +221 -0
  7. package/lib/TypeORMDispatch.cjs +134 -0
  8. package/lib/TypeORMDispatch.d.ts +87 -0
  9. package/lib/TypeORMEventSubscriber.cjs +96 -0
  10. package/lib/TypeORMEventSubscriber.d.ts +56 -0
  11. package/lib/TypeORMRepository.cjs +209 -0
  12. package/lib/TypeORMRepository.d.ts +125 -0
  13. package/lib/constants.cjs +43 -0
  14. package/lib/constants.d.ts +39 -0
  15. package/lib/errors.cjs +28 -0
  16. package/lib/errors.d.ts +21 -0
  17. package/lib/esm/TypeORMAdapter.d.ts +221 -0
  18. package/lib/esm/TypeORMAdapter.js +1124 -0
  19. package/lib/esm/TypeORMDispatch.d.ts +87 -0
  20. package/lib/esm/TypeORMDispatch.js +130 -0
  21. package/lib/esm/TypeORMEventSubscriber.d.ts +56 -0
  22. package/lib/esm/TypeORMEventSubscriber.js +93 -0
  23. package/lib/esm/TypeORMRepository.d.ts +125 -0
  24. package/lib/esm/TypeORMRepository.js +206 -0
  25. package/lib/esm/constants.d.ts +39 -0
  26. package/lib/esm/constants.js +40 -0
  27. package/lib/esm/errors.d.ts +21 -0
  28. package/lib/esm/errors.js +24 -0
  29. package/lib/esm/index.d.ts +22 -0
  30. package/lib/esm/index.js +25 -0
  31. package/lib/esm/indexes/generator.d.ts +50 -0
  32. package/lib/esm/indexes/generator.js +95 -0
  33. package/lib/esm/indexes/index.d.ts +1 -0
  34. package/lib/esm/indexes/index.js +2 -0
  35. package/lib/esm/overrides/Column.d.ts +74 -0
  36. package/lib/esm/overrides/Column.js +70 -0
  37. package/lib/esm/overrides/CreateDateColumn.d.ts +2 -0
  38. package/lib/esm/overrides/CreateDateColumn.js +9 -0
  39. package/lib/esm/overrides/Entity.d.ts +11 -0
  40. package/lib/esm/overrides/Entity.js +28 -0
  41. package/lib/esm/overrides/PrimaryColumn.d.ts +20 -0
  42. package/lib/esm/overrides/PrimaryColumn.js +53 -0
  43. package/lib/esm/overrides/PrimaryGeneratedColumn.d.ts +24 -0
  44. package/lib/esm/overrides/PrimaryGeneratedColumn.js +51 -0
  45. package/lib/esm/overrides/UpdateDateColumn.d.ts +2 -0
  46. package/lib/esm/overrides/UpdateDateColumn.js +9 -0
  47. package/lib/esm/overrides/utils.d.ts +2 -0
  48. package/lib/esm/overrides/utils.js +29 -0
  49. package/lib/esm/query/Paginator.d.ts +86 -0
  50. package/lib/esm/query/Paginator.js +124 -0
  51. package/lib/esm/query/Statement.d.ts +131 -0
  52. package/lib/esm/query/Statement.js +242 -0
  53. package/lib/esm/query/constants.d.ts +52 -0
  54. package/lib/esm/query/constants.js +74 -0
  55. package/lib/esm/query/index.d.ts +4 -0
  56. package/lib/esm/query/index.js +5 -0
  57. package/lib/esm/query/translate.d.ts +34 -0
  58. package/lib/esm/query/translate.js +42 -0
  59. package/lib/esm/raw/postgres.d.ts +36 -0
  60. package/lib/esm/raw/postgres.js +2 -0
  61. package/lib/esm/sequences/Sequence.d.ts +67 -0
  62. package/lib/esm/sequences/Sequence.js +117 -0
  63. package/lib/esm/sequences/index.d.ts +1 -0
  64. package/lib/esm/sequences/index.js +2 -0
  65. package/lib/esm/types.d.ts +67 -0
  66. package/lib/esm/types.js +28 -0
  67. package/lib/esm/utils.d.ts +16 -0
  68. package/lib/esm/utils.js +29 -0
  69. package/lib/index.cjs +42 -0
  70. package/lib/index.d.ts +22 -0
  71. package/lib/indexes/generator.cjs +98 -0
  72. package/lib/indexes/generator.d.ts +50 -0
  73. package/lib/indexes/index.cjs +18 -0
  74. package/lib/indexes/index.d.ts +1 -0
  75. package/lib/overrides/Column.cjs +73 -0
  76. package/lib/overrides/Column.d.ts +74 -0
  77. package/lib/overrides/CreateDateColumn.cjs +12 -0
  78. package/lib/overrides/CreateDateColumn.d.ts +2 -0
  79. package/lib/overrides/Entity.cjs +31 -0
  80. package/lib/overrides/Entity.d.ts +11 -0
  81. package/lib/overrides/PrimaryColumn.cjs +56 -0
  82. package/lib/overrides/PrimaryColumn.d.ts +20 -0
  83. package/lib/overrides/PrimaryGeneratedColumn.cjs +54 -0
  84. package/lib/overrides/PrimaryGeneratedColumn.d.ts +24 -0
  85. package/lib/overrides/UpdateDateColumn.cjs +12 -0
  86. package/lib/overrides/UpdateDateColumn.d.ts +2 -0
  87. package/lib/overrides/utils.cjs +32 -0
  88. package/lib/overrides/utils.d.ts +2 -0
  89. package/lib/query/Paginator.cjs +128 -0
  90. package/lib/query/Paginator.d.ts +86 -0
  91. package/lib/query/Statement.cjs +246 -0
  92. package/lib/query/Statement.d.ts +131 -0
  93. package/lib/query/constants.cjs +77 -0
  94. package/lib/query/constants.d.ts +52 -0
  95. package/lib/query/index.cjs +21 -0
  96. package/lib/query/index.d.ts +4 -0
  97. package/lib/query/translate.cjs +45 -0
  98. package/lib/query/translate.d.ts +34 -0
  99. package/lib/raw/postgres.cjs +3 -0
  100. package/lib/raw/postgres.d.ts +36 -0
  101. package/lib/sequences/Sequence.cjs +121 -0
  102. package/lib/sequences/Sequence.d.ts +67 -0
  103. package/lib/sequences/index.cjs +18 -0
  104. package/lib/sequences/index.d.ts +1 -0
  105. package/lib/types.cjs +31 -0
  106. package/lib/types.d.ts +67 -0
  107. package/lib/utils.cjs +32 -0
  108. package/lib/utils.d.ts +16 -0
  109. package/package.json +128 -0
@@ -0,0 +1,1129 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.TypeORMAdapter = void 0;
13
+ exports.createdByOnPostgresCreateUpdate = createdByOnPostgresCreateUpdate;
14
+ const core_1 = require("@decaf-ts/core");
15
+ const constants_1 = require("./constants.cjs");
16
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
17
+ require("reflect-metadata");
18
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
19
+ const errors_1 = require("./errors.cjs");
20
+ const query_1 = require("./query/index.cjs");
21
+ const sequences_1 = require("./sequences/index.cjs");
22
+ const indexes_1 = require("./indexes/index.cjs");
23
+ const reflection_1 = require("@decaf-ts/reflection");
24
+ const TypeORMRepository_1 = require("./TypeORMRepository.cjs");
25
+ const logging_1 = require("@decaf-ts/logging");
26
+ const TypeORMDispatch_1 = require("./TypeORMDispatch.cjs");
27
+ const utils_1 = require("./utils.cjs");
28
+ const typeorm_1 = require("typeorm");
29
+ const Column_1 = require("./overrides/Column.cjs");
30
+ const UpdateDateColumn_1 = require("./overrides/UpdateDateColumn.cjs");
31
+ const CreateDateColumn_1 = require("./overrides/CreateDateColumn.cjs");
32
+ const PrimaryGeneratedColumn_1 = require("./overrides/PrimaryGeneratedColumn.cjs");
33
+ const PrimaryColumn_1 = require("./overrides/PrimaryColumn.cjs");
34
+ const Entity_1 = require("./overrides/Entity.cjs");
35
+ async function createdByOnPostgresCreateUpdate(context, data, key, model) {
36
+ try {
37
+ const user = context.get("user");
38
+ model[key] = user;
39
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
40
+ }
41
+ catch (e) {
42
+ throw new db_decorators_1.InternalError("No User found in context. Please provide a user in the context");
43
+ }
44
+ }
45
+ /**
46
+ * @description Adapter for TypeORM-backed persistence operations.
47
+ * @summary Implements the Decaf.ts Adapter over a TypeORM DataSource, providing CRUD operations, query/statement factories, sequence management, error parsing, and decoration helpers.
48
+ * @template Y The native configuration type (TypeORM DataSourceOptions).
49
+ * @template F The repository flags type.
50
+ * @template C The context type.
51
+ * @param {DataSourceOptions} scope The DataSource options for the adapter.
52
+ * @param {string} flavour The flavour of the adapter.
53
+ * @param {string} [alias] Optional alias for the adapter.
54
+ * @class TypeORMAdapter
55
+ * @example
56
+ * const adapter = new TypeORMAdapter({ type: 'postgres', /* ... *\/ });
57
+ * await adapter.initialize();
58
+ * const repo = new (adapter.repository<User>())(adapter, User);
59
+ * const created = await repo.create(new User({ name: 'Alice' }));
60
+ *
61
+ * @mermaid
62
+ * sequenceDiagram
63
+ * participant App
64
+ * participant Adapter as TypeORMAdapter
65
+ * participant Repo as TypeORMRepository
66
+ * participant DS as TypeORM DataSource
67
+ *
68
+ * App->>Adapter: new TypeORMAdapter(opts)
69
+ * Adapter->>DS: initialize()
70
+ * App->>Adapter: repository()
71
+ * Adapter-->>App: TypeORMRepository
72
+ * App->>Repo: create(model)
73
+ * Repo->>Adapter: prepare/create/revert
74
+ * Adapter-->>Repo: Model
75
+ * Repo-->>App: Model
76
+ */
77
+ class TypeORMAdapter extends core_1.Adapter {
78
+ get dataSource() {
79
+ if (!this._dataSource) {
80
+ const models = core_1.Adapter.models(this.flavour);
81
+ this._dataSource = new typeorm_1.DataSource(Object.assign(this.native, {
82
+ entities: models.map((c) => c[decorator_validation_1.ModelKeys.ANCHOR]),
83
+ }));
84
+ }
85
+ return this._dataSource;
86
+ }
87
+ // protected dataSou
88
+ constructor(options, alias) {
89
+ super(options, constants_1.TypeORMFlavour, alias);
90
+ }
91
+ async flags(operation, model, flags) {
92
+ const f = await super.flags(operation, model, flags);
93
+ const newObj = {
94
+ user: (await TypeORMAdapter.getCurrentUser(this.dataSource)),
95
+ };
96
+ const m = new model();
97
+ const exceptions = [];
98
+ if (operation === db_decorators_1.OperationKeys.CREATE) {
99
+ const pk = (0, db_decorators_1.findPrimaryKey)(m).id;
100
+ exceptions.push(pk);
101
+ }
102
+ if (operation === db_decorators_1.OperationKeys.CREATE ||
103
+ operation === db_decorators_1.OperationKeys.UPDATE) {
104
+ const decs = Object.keys(m).reduce((accum, key) => {
105
+ const decs = reflection_1.Reflection.getPropertyDecorators(decorator_validation_1.ValidationKeys.REFLECT, m, key, true);
106
+ const dec = decs.decorators.find((dec) => dec.key === db_decorators_1.DBKeys.TIMESTAMP &&
107
+ dec.props.operation.indexOf(operation) !== -1);
108
+ if (dec) {
109
+ accum[key] = dec.props;
110
+ }
111
+ return accum;
112
+ }, {});
113
+ exceptions.push(...Object.keys(decs));
114
+ }
115
+ newObj.ignoredValidationProperties = (f.ignoredValidationProperties ? f.ignoredValidationProperties : []).concat(...exceptions);
116
+ return Object.assign(f, newObj);
117
+ }
118
+ Dispatch() {
119
+ return new TypeORMDispatch_1.TypeORMDispatch();
120
+ }
121
+ repository() {
122
+ return TypeORMRepository_1.TypeORMRepository;
123
+ }
124
+ /**
125
+ * @description Creates a new Postgres statement for querying
126
+ * @summary Factory method that creates a new PostgresStatement instance for building queries
127
+ * @template M - The model type
128
+ * @return {TypeORMStatement<M, any>} A new PostgresStatement instance
129
+ */
130
+ Statement() {
131
+ return new query_1.TypeORMStatement(this);
132
+ }
133
+ /**
134
+ * @description Creates a new PostgreSQL sequence
135
+ * @summary Factory method that creates a new PostgreSQLSequence instance for managing sequences
136
+ * @param {SequenceOptions} options - The options for the sequence
137
+ * @return {Promise<Sequence>} A promise that resolves to a new Sequence instance
138
+ */
139
+ async Sequence(options) {
140
+ return new sequences_1.TypeORMSequence(options, this);
141
+ }
142
+ /**
143
+ * @description Initializes the adapter by creating indexes for all managed models
144
+ * @summary Sets up the necessary database indexes for all models managed by this adapter
145
+ * @return {Promise<void>} A promise that resolves when initialization is complete
146
+ */
147
+ async initialize() {
148
+ const ds = this.dataSource;
149
+ try {
150
+ await ds.initialize();
151
+ }
152
+ catch (e) {
153
+ throw this.parseError(e);
154
+ }
155
+ const log = this.log.for(this.initialize);
156
+ log.verbose(`${this.flavour} adapter initialized`);
157
+ }
158
+ /**
159
+ * @description Creates indexes for the given models
160
+ * @summary Abstract method that must be implemented to create database indexes for the specified models
161
+ * @template M - The model type
162
+ * @param {...Constructor<M>} models - The model constructors to create indexes for
163
+ * @return {Promise<void>} A promise that resolves when all indexes are created
164
+ */
165
+ async index(...models) {
166
+ const indexes = (0, indexes_1.generateIndexes)(models);
167
+ try {
168
+ await this.dataSource.query("BEGIN");
169
+ for (const index of indexes) {
170
+ await this.dataSource.query(index.query, index.values);
171
+ }
172
+ await this.dataSource.query("COMMIT");
173
+ }
174
+ catch (e) {
175
+ await this.dataSource.query("ROLLBACK");
176
+ throw this.parseError(e);
177
+ }
178
+ }
179
+ /**
180
+ * @description Executes a raw SQL query against the database
181
+ * @summary Abstract method that must be implemented to execute raw SQL queries
182
+ * @template R - The result type
183
+ * @param {TypeORMQuery} q - The query to execute
184
+ * @return {Promise<R>} A promise that resolves to the query result
185
+ */
186
+ async raw(q) {
187
+ const log = this.log.for(this.raw);
188
+ try {
189
+ if (!this.dataSource.isInitialized)
190
+ await this.dataSource.initialize();
191
+ }
192
+ catch (e) {
193
+ throw this.parseError(e);
194
+ }
195
+ try {
196
+ const { query, values } = q;
197
+ log.debug(`executing query: ${query.getSql()}`);
198
+ const response = await this.dataSource.query(query, values);
199
+ return response;
200
+ }
201
+ catch (e) {
202
+ throw this.parseError(e);
203
+ }
204
+ }
205
+ prepare(model, pk, child = false) {
206
+ const prepared = super.prepare(model, pk);
207
+ prepared.record = Object.entries(prepared.record).reduce((accum, [key, value]) => {
208
+ if (key === core_1.PersistenceKeys.METADATA || this.isReserved(key))
209
+ return accum;
210
+ if (value === undefined) {
211
+ return accum;
212
+ }
213
+ if (value instanceof Date) {
214
+ value = new Date(value.getTime());
215
+ }
216
+ else if (decorator_validation_1.Model.isModel(value)) {
217
+ value = this.prepare(value, (0, db_decorators_1.findPrimaryKey)(value).id, true).record;
218
+ }
219
+ else {
220
+ switch (typeof value) {
221
+ case "string":
222
+ value = `${value}`;
223
+ break;
224
+ default:
225
+ //do nothing;
226
+ }
227
+ }
228
+ accum[key] = value;
229
+ return accum;
230
+ }, {});
231
+ const constr = decorator_validation_1.Model.get(model.constructor.name);
232
+ if (!constr)
233
+ throw new db_decorators_1.InternalError(`Model ${model.constructor.name} not found in registry`);
234
+ const result = child
235
+ ? new constr[decorator_validation_1.ModelKeys.ANCHOR]()
236
+ : new constr();
237
+ if (child)
238
+ Object.defineProperty(result, "constructor", {
239
+ configurable: false,
240
+ enumerable: false,
241
+ value: constr[decorator_validation_1.ModelKeys.ANCHOR],
242
+ writable: false,
243
+ });
244
+ Object.entries(prepared.record).forEach(([key, val]) => (result[key] = val));
245
+ prepared.record = result;
246
+ return prepared;
247
+ }
248
+ revert(obj, clazz, pk, id, transient) {
249
+ const log = this.log.for(this.revert);
250
+ if (transient) {
251
+ log.verbose(`re-adding transient properties: ${Object.keys(transient).join(", ")}`);
252
+ Object.entries(transient).forEach(([key, val]) => {
253
+ if (key in obj)
254
+ throw new db_decorators_1.InternalError(`Transient property ${key} already exists on model ${typeof clazz === "string" ? clazz : clazz.name}. should be impossible`);
255
+ obj[key] = val;
256
+ });
257
+ }
258
+ return new clazz(obj);
259
+ }
260
+ /**
261
+ * @description Creates a new record in the database
262
+ * @summary Abstract method that must be implemented to create a new record
263
+ * @param {string} tableName - The name of the table
264
+ * @param {string|number} id - The ID of the record
265
+ * @param {Record<string, any>} model - The model to create
266
+ * @param {...any[]} args - Additional arguments
267
+ * @return {Promise<Record<string, any>>} A promise that resolves to the created record
268
+ */
269
+ async create(tableName, id, model,
270
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
271
+ ...args) {
272
+ const m = tableName;
273
+ try {
274
+ const repo = this.dataSource.getRepository(m);
275
+ return await repo.save(model);
276
+ }
277
+ catch (e) {
278
+ throw this.parseError(e);
279
+ }
280
+ }
281
+ /**
282
+ * @description Reads a record from the database
283
+ * @summary Abstract method that must be implemented to read a record
284
+ * @param {string} tableName - The name of the table
285
+ * @param {string|number} id - The ID of the record
286
+ * @param {string} pk - primary key colum
287
+ * @return {Promise<Record<string, any>>} A promise that resolves to the read record
288
+ */
289
+ async read(tableName, id, pk) {
290
+ const m = tableName;
291
+ let result;
292
+ try {
293
+ const repo = this.dataSource.getRepository(m);
294
+ const q = {
295
+ where: {
296
+ [pk]: id,
297
+ },
298
+ };
299
+ result = (await repo.findOne(q));
300
+ }
301
+ catch (e) {
302
+ throw this.parseError(e);
303
+ }
304
+ if (!result)
305
+ throw new db_decorators_1.NotFoundError(`Record with id: ${id} not found in table ${typeof tableName === "string" ? tableName : core_1.Repository.table(tableName)}`);
306
+ return result;
307
+ }
308
+ /**
309
+ * @description Updates a record in the database
310
+ * @summary Abstract method that must be implemented to update a record
311
+ * @param {string} tableName - The name of the table
312
+ * @param {string|number} id - The ID of the record
313
+ * @param {Record<string, any>} model - The model to update
314
+ * @param {string} pk - Additional arguments
315
+ * @return A promise that resolves to the updated record
316
+ */
317
+ async update(tableName, id, model,
318
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
319
+ ...args) {
320
+ const m = tableName;
321
+ try {
322
+ const repo = this.dataSource.getRepository(m);
323
+ return repo.save(model);
324
+ }
325
+ catch (e) {
326
+ throw this.parseError(e);
327
+ }
328
+ }
329
+ /**
330
+ * @description Deletes a record from the database
331
+ * @summary Abstract method that must be implemented to delete a record
332
+ * @param {string} tableName - The name of the table
333
+ * @param {string|number} id - The ID of the record
334
+ * @param {string} pk - Additional arguments
335
+ * @return A promise that resolves to the deleted record
336
+ */
337
+ async delete(tableName, id, pk,
338
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
339
+ ...args) {
340
+ const m = tableName;
341
+ try {
342
+ const repo = this.dataSource.getRepository(m);
343
+ const model = await this.read(tableName, id, pk);
344
+ const res = await repo.delete(id);
345
+ return model;
346
+ }
347
+ catch (e) {
348
+ throw this.parseError(e);
349
+ }
350
+ }
351
+ async createAll(tableName, id, model,
352
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
353
+ ...args) {
354
+ const m = tableName;
355
+ try {
356
+ const repo = this.dataSource.getRepository(m);
357
+ const result = await repo.insert(model);
358
+ return this.readAll(tableName, result.identifiers.map((id) => id.id), "id");
359
+ }
360
+ catch (e) {
361
+ throw this.parseError(e);
362
+ }
363
+ }
364
+ async readAll(tableName, id, pk,
365
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
366
+ ...args) {
367
+ if (!id.length)
368
+ return [];
369
+ const m = tableName;
370
+ try {
371
+ const repo = this.dataSource.getRepository(m);
372
+ return repo.findBy({ [pk]: (0, typeorm_1.In)(id) });
373
+ }
374
+ catch (e) {
375
+ throw this.parseError(e);
376
+ }
377
+ }
378
+ async updateAll(tableName, ids, model, pk, ...args) {
379
+ const result = [];
380
+ for (const m of model) {
381
+ result.push(await this.update(tableName, m[pk], m, ...args));
382
+ }
383
+ return result;
384
+ }
385
+ async deleteAll(tableName, ids, pk,
386
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
387
+ ...args) {
388
+ if (!ids.length)
389
+ return [];
390
+ const m = tableName;
391
+ try {
392
+ const repo = this.dataSource.getRepository(m);
393
+ const models = await this.readAll(tableName, ids, pk);
394
+ await repo.delete(ids);
395
+ return models;
396
+ }
397
+ catch (e) {
398
+ throw this.parseError(e);
399
+ }
400
+ }
401
+ /**
402
+ * @description Parses an error and converts it to a BaseError
403
+ * @summary Converts various error types to appropriate BaseError subtypes
404
+ * @param {Error|string} err - The error to parse
405
+ * @param {string} [reason] - Optional reason for the error
406
+ * @return {BaseError} The parsed error as a BaseError
407
+ */
408
+ parseError(err, reason) {
409
+ return TypeORMAdapter.parseError(err, reason);
410
+ }
411
+ /**
412
+ * @description Checks if an attribute is reserved
413
+ * @summary Determines if an attribute name is reserved in PostgreSQL
414
+ * @param {string} attr - The attribute name to check
415
+ * @return {boolean} True if the attribute is reserved, false otherwise
416
+ */
417
+ isReserved(attr) {
418
+ return !!attr.match(constants_1.reservedAttributes);
419
+ }
420
+ /**
421
+ * @description Static method to parse an error and convert it to a BaseError
422
+ * @summary Converts various error types to appropriate BaseError subtypes based on PostgreSQL error codes and messages
423
+ * @param {Error|string} err - The error to parse
424
+ * @param {string} [reason] - Optional reason for the error
425
+ * @return {BaseError} The parsed error as a BaseError
426
+ * @mermaid
427
+ * sequenceDiagram
428
+ * participant Caller
429
+ * participant parseError
430
+ * participant ErrorTypes
431
+ *
432
+ * Caller->>parseError: err, reason
433
+ * Note over parseError: Check if err is already a BaseError
434
+ * alt err is BaseError
435
+ * parseError-->>Caller: return err
436
+ * else err is string
437
+ * Note over parseError: Extract code from string
438
+ * alt code matches "duplicate key|already exists"
439
+ * parseError->>ErrorTypes: new ConflictError(code)
440
+ * ErrorTypes-->>Caller: ConflictError
441
+ * else code matches "does not exist|not found"
442
+ * parseError->>ErrorTypes: new NotFoundError(code)
443
+ * ErrorTypes-->>Caller: NotFoundError
444
+ * end
445
+ * else err has code property
446
+ * Note over parseError: Extract code and reason
447
+ * else
448
+ * Note over parseError: Use err.message as code
449
+ * end
450
+ *
451
+ * Note over parseError: Switch on PostgreSQL error code
452
+ * alt code is 23505 (unique_violation)
453
+ * parseError->>ErrorTypes: new ConflictError(reason)
454
+ * ErrorTypes-->>Caller: ConflictError
455
+ * else code is 23503 (foreign_key_violation)
456
+ * parseError->>ErrorTypes: new ConflictError(reason)
457
+ * ErrorTypes-->>Caller: ConflictError
458
+ * else code is 42P01 (undefined_table)
459
+ * parseError->>ErrorTypes: new NotFoundError(reason)
460
+ * ErrorTypes-->>Caller: NotFoundError
461
+ * else code is 42703 (undefined_column)
462
+ * parseError->>ErrorTypes: new NotFoundError(reason)
463
+ * ErrorTypes-->>Caller: NotFoundError
464
+ * else code is 42P07 (duplicate_table)
465
+ * parseError->>ErrorTypes: new ConflictError(reason)
466
+ * ErrorTypes-->>Caller: ConflictError
467
+ * else code is 42P16 (invalid_table_definition)
468
+ * parseError->>ErrorTypes: new IndexError(err)
469
+ * ErrorTypes-->>Caller: IndexError
470
+ * else code matches "ECONNREFUSED"
471
+ * parseError->>ErrorTypes: new ConnectionError(err)
472
+ * ErrorTypes-->>Caller: ConnectionError
473
+ * else
474
+ * parseError->>ErrorTypes: new InternalError(err)
475
+ * ErrorTypes-->>Caller: InternalError
476
+ * end
477
+ */
478
+ static parseError(err, reason) {
479
+ if (err instanceof db_decorators_1.BaseError)
480
+ return err;
481
+ const code = typeof err === "string" ? err : err.message;
482
+ if (code.match(/duplicate key|already exists/g))
483
+ return new db_decorators_1.ConflictError(code);
484
+ if (code.match(/does not exist|not found/g))
485
+ return new db_decorators_1.NotFoundError(code);
486
+ // PostgreSQL error codes: https://www.postgresql.org/docs/current/errcodes-appendix.html
487
+ switch (code.toString()) {
488
+ // Integrity constraint violations
489
+ case "23505": // unique_violation
490
+ case "23503": // foreign_key_violation
491
+ case "42P07": // duplicate_table
492
+ return new db_decorators_1.ConflictError(reason);
493
+ // Object not found errors
494
+ case "42P01": // undefined_table
495
+ case "42703": // undefined_column
496
+ return new db_decorators_1.NotFoundError(reason);
497
+ // Invalid object definition
498
+ case "42P16": // invalid_table_definition
499
+ return new errors_1.IndexError(err);
500
+ // Connection errors
501
+ default:
502
+ if (code.toString().match(/ECONNREFUSED/g))
503
+ return new core_1.ConnectionError(err);
504
+ return new db_decorators_1.InternalError(err);
505
+ }
506
+ }
507
+ static async connect(config) {
508
+ const con = new typeorm_1.DataSource(config);
509
+ if (!con.isInitialized)
510
+ await con.initialize();
511
+ return con;
512
+ }
513
+ static async createDatabase(dataSource, dbName) {
514
+ const log = logging_1.Logging.for(this.createDatabase);
515
+ log.verbose(`Creating database ${dbName}`);
516
+ try {
517
+ await dataSource.query(`CREATE DATABASE ${dbName}`);
518
+ log.info(`Created database ${dbName}`);
519
+ }
520
+ catch (e) {
521
+ throw this.parseError(e);
522
+ }
523
+ }
524
+ static async createNotifyFunction(dataSource, user) {
525
+ const log = logging_1.Logging.for(this.createNotifyFunction);
526
+ log.verbose(`Creating notify function`);
527
+ try {
528
+ await dataSource.query(`CREATE OR REPLACE FUNCTION notify_table_changes()
529
+ RETURNS trigger AS $$
530
+ BEGIN
531
+ PERFORM pg_notify(
532
+ 'table_changes',
533
+ json_build_object(
534
+ 'table', TG_TABLE_NAME,
535
+ 'action', TG_OP,
536
+ 'data', row_to_json(NEW),
537
+ 'old_data', row_to_json(OLD)
538
+ )::text
539
+ );
540
+ RETURN NEW;
541
+ END;
542
+ $$ LANGUAGE plpgsql SECURITY DEFINER
543
+ ;`);
544
+ await dataSource.query(`ALTER FUNCTION notify_table_changes() OWNER TO ${user};`);
545
+ await dataSource.query(`
546
+ GRANT EXECUTE ON FUNCTION notify_table_changes() TO public;
547
+ `);
548
+ log.info(`Created notify function`);
549
+ }
550
+ catch (e) {
551
+ throw this.parseError(e);
552
+ }
553
+ }
554
+ static async deleteDatabase(dataSource, dbName, user) {
555
+ try {
556
+ if (user)
557
+ await dataSource.query(`DROP OWNED BY ${user} CASCADE;`);
558
+ await dataSource.query(`DROP DATABASE ${dbName}`);
559
+ }
560
+ catch (e) {
561
+ throw this.parseError(e);
562
+ }
563
+ }
564
+ static async createUser(dataSource, dbName, user, password) {
565
+ try {
566
+ await dataSource.query(`CREATE USER ${user} WITH PASSWORD '${password}'`);
567
+ await dataSource.query(`GRANT CONNECT ON DATABASE ${dbName} TO ${user}`);
568
+ await dataSource.query(`GRANT USAGE ON SCHEMA public TO ${user}`);
569
+ await dataSource.query(`GRANT CREATE ON SCHEMA public TO ${user}`);
570
+ await dataSource.query(`GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO ${user}`);
571
+ await dataSource.query(`GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO ${user}`);
572
+ await dataSource.query(`GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public TO ${user}`);
573
+ await dataSource.query(`ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON TABLES TO ${user}`);
574
+ await dataSource.query(`ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON SEQUENCES TO ${user}`);
575
+ }
576
+ catch (e) {
577
+ throw this.parseError(e);
578
+ }
579
+ }
580
+ static async deleteUser(client, user, admin) {
581
+ try {
582
+ await client.query(`REASSIGN OWNED BY ${user} TO ${admin}`);
583
+ await client.query(`REVOKE ALL ON ALL TABLES IN SCHEMA public FROM ${user}`);
584
+ await client.query(`REVOKE ALL ON SCHEMA public FROM ${user}`);
585
+ await client.query(`REVOKE ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public FROM ${user}`);
586
+ await client.query(`REVOKE ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public FROM ${user}`);
587
+ await client.query(`ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON TABLES FROM ${user}`);
588
+ await client.query(`ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON SEQUENCES FROM ${user};`);
589
+ await client.query(`ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON FUNCTIONS FROM ${user}`);
590
+ await client.query(`DROP OWNED BY ${user} CASCADE`);
591
+ await client.query(`DROP USER IF EXISTS "${user}"`);
592
+ }
593
+ catch (e) {
594
+ throw this.parseError(e);
595
+ }
596
+ }
597
+ static parseTypeToPostgres(type, isPk, isFk = false) {
598
+ switch (type.toLowerCase()) {
599
+ case "string":
600
+ return isPk ? "TEXT PRIMARY KEY" : isFk ? "TEXT" : "VARCHAR";
601
+ case "number":
602
+ return isPk ? "SERIAL PRIMARY KEY" : "INTEGER";
603
+ case "boolean":
604
+ return "BOOLEAN";
605
+ case "date":
606
+ return "TIMESTAMP";
607
+ case "bigint":
608
+ return isPk ? "BIGINT PRIMARY KEY" : "BIGINT";
609
+ default: {
610
+ const m = decorator_validation_1.Model.get(type);
611
+ if (m) {
612
+ const mm = new m();
613
+ const type = reflection_1.Reflection.getTypeFromDecorator(mm, (0, db_decorators_1.findPrimaryKey)(mm).id);
614
+ return {
615
+ model: m,
616
+ pkType: type,
617
+ };
618
+ }
619
+ throw new db_decorators_1.InternalError(`Unsupported type: ${type}`);
620
+ }
621
+ }
622
+ }
623
+ static parseValidationToPostgres(prop, type, isPk, key, options) {
624
+ switch (key) {
625
+ case decorator_validation_1.ValidationKeys.REQUIRED:
626
+ return "NOT NULL";
627
+ case decorator_validation_1.ValidationKeys.MAX_LENGTH:
628
+ if (isPk || !options || type.toLowerCase() !== "string") {
629
+ return "";
630
+ }
631
+ return `(${options[decorator_validation_1.ValidationKeys.MAX_LENGTH]})`;
632
+ case decorator_validation_1.ValidationKeys.MIN_LENGTH:
633
+ return `CONSTRAINT ${prop}_min_length_check CHECK (LENGTH(${prop}) >= ${options[decorator_validation_1.ValidationKeys.MIN_LENGTH]})`;
634
+ case decorator_validation_1.ValidationKeys.PATTERN:
635
+ case decorator_validation_1.ValidationKeys.URL:
636
+ case decorator_validation_1.ValidationKeys.EMAIL:
637
+ return `CONSTRAINT ${prop}_pattern_check CHECK (${prop} ~ '${(0, utils_1.convertJsRegexToPostgres)(options[decorator_validation_1.ValidationKeys.PATTERN])}')`;
638
+ case decorator_validation_1.ValidationKeys.TYPE:
639
+ case decorator_validation_1.ValidationKeys.DATE:
640
+ return "";
641
+ case decorator_validation_1.ValidationKeys.MIN:
642
+ return `CONSTRAINT ${prop}_${key}_check CHECK (${prop} >= ${options[decorator_validation_1.ValidationKeys.MIN]})`;
643
+ case decorator_validation_1.ValidationKeys.MAX:
644
+ return `CONSTRAINT ${prop}_${key}_check CHECK (${prop} <= ${options[decorator_validation_1.ValidationKeys.MAX]})`;
645
+ case decorator_validation_1.ValidationKeys.PASSWORD:
646
+ default:
647
+ throw new db_decorators_1.InternalError(`Unsupported type: ${key}`);
648
+ }
649
+ }
650
+ static parseRelationsToPostgres(prop, clazz, pk, key, options) {
651
+ const tableName = core_1.Repository.table(clazz);
652
+ const { cascade } = options;
653
+ const cascadeStr = `${cascade.update ? " ON UPDATE CASCADE" : ""}${cascade.delete ? " ON DELETE CASCADE" : ""}`;
654
+ switch (`relations${key}`) {
655
+ case core_1.PersistenceKeys.ONE_TO_ONE:
656
+ return `FOREIGN KEY (${prop}) REFERENCES ${tableName}(${pk})${cascadeStr}`;
657
+ default:
658
+ throw new db_decorators_1.InternalError(`Unsupported operation: ${key}`);
659
+ }
660
+ }
661
+ static async createTable(client, model) {
662
+ const result = {};
663
+ const m = new model({});
664
+ const tableName = core_1.Repository.table(model);
665
+ const { id } = (0, db_decorators_1.findPrimaryKey)(m);
666
+ let isPk, column;
667
+ const properties = Object.getOwnPropertyNames(m);
668
+ for (const prop of properties) {
669
+ if (typeof this[prop] === "function" ||
670
+ prop.toString().startsWith("_") ||
671
+ prop === "constructor") {
672
+ continue;
673
+ }
674
+ isPk = prop === id;
675
+ column = core_1.Repository.column(m, prop.toString());
676
+ const allDecs = reflection_1.Reflection.getPropertyDecorators(decorator_validation_1.ValidationKeys.REFLECT, m, prop.toString(), false, true);
677
+ const decoratorData = allDecs.decorators.reduce((accum, el) => {
678
+ const { key, props } = el;
679
+ if (key === decorator_validation_1.ModelKeys.TYPE && !accum[decorator_validation_1.ValidationKeys.TYPE]) {
680
+ accum[decorator_validation_1.ValidationKeys.TYPE] = {
681
+ customTypes: [props.name],
682
+ message: decorator_validation_1.DEFAULT_ERROR_MESSAGES.TYPE,
683
+ description: "defines the accepted types for the attribute",
684
+ };
685
+ }
686
+ else if (key !== decorator_validation_1.ValidationKeys.TYPE) {
687
+ // do nothing. we can only support basis ctypes at this time
688
+ accum[key] = props;
689
+ }
690
+ return accum;
691
+ }, {});
692
+ const dbDecs = reflection_1.Reflection.getPropertyDecorators(core_1.Repository.key("relations"), m, prop.toString(), true, true);
693
+ const query = [];
694
+ const constraints = [];
695
+ const foreignKeys = [];
696
+ let typeData = undefined;
697
+ let childClass = undefined;
698
+ let childPk;
699
+ if (Object.keys(decoratorData).length) {
700
+ typeData = decoratorData[decorator_validation_1.ValidationKeys.TYPE];
701
+ if (!typeData) {
702
+ throw new Error(`Missing type information`);
703
+ }
704
+ let parsedType = this.parseTypeToPostgres(typeof typeData.customTypes[0] === "function"
705
+ ? typeData.customTypes[0]()
706
+ : typeData.customTypes[0], isPk);
707
+ if (typeof parsedType === "string") {
708
+ parsedType = { model: parsedType };
709
+ }
710
+ let typeStr = parsedType.model;
711
+ if (typeof typeStr !== "string") {
712
+ if (Array.isArray(typeStr)) {
713
+ console.log(typeStr);
714
+ }
715
+ // continue;
716
+ // const res: Record<string, PostgresTableSpec> = await this.createTable(pool, typeStr);
717
+ try {
718
+ childClass = parsedType.model;
719
+ const m = new childClass();
720
+ childPk = (0, db_decorators_1.findPrimaryKey)(m);
721
+ typeStr = this.parseTypeToPostgres(parsedType.pkType, false, true);
722
+ await this.createTable(client, childClass);
723
+ }
724
+ catch (e) {
725
+ if (!(e instanceof db_decorators_1.ConflictError))
726
+ throw e;
727
+ }
728
+ }
729
+ let tp = Array.isArray(typeData.customTypes)
730
+ ? typeData.customTypes[0]
731
+ : typeData.customTypes;
732
+ tp = typeof tp === "function" && !tp.name ? tp() : tp;
733
+ const validationStr = this.parseValidationToPostgres(column, tp, isPk, decorator_validation_1.ValidationKeys.MAX_LENGTH, decoratorData[decorator_validation_1.ValidationKeys.MAX_LENGTH] || {
734
+ [decorator_validation_1.ValidationKeys.MAX_LENGTH]: 255,
735
+ });
736
+ const q = `${column} ${typeStr}${validationStr}`;
737
+ if (isPk) {
738
+ query.unshift(q);
739
+ }
740
+ else {
741
+ query.push(q);
742
+ }
743
+ for (const [key, props] of Object.entries(decoratorData).filter(([k]) => ![decorator_validation_1.ValidationKeys.TYPE, decorator_validation_1.ValidationKeys.MAX_LENGTH].includes(k))) {
744
+ const validation = this.parseValidationToPostgres(column, tp, isPk, key, props);
745
+ if (validation.startsWith("CONSTRAINT")) {
746
+ constraints.push(validation);
747
+ }
748
+ else {
749
+ if (validation) {
750
+ query.push(validation);
751
+ }
752
+ }
753
+ }
754
+ }
755
+ // TODO ignore for now. this leaves foreign keys out
756
+ // eslint-disable-next-line no-constant-binary-expression
757
+ if (false || (dbDecs && dbDecs.decorators.length)) {
758
+ if (!typeData)
759
+ throw new Error(`Missing type information`);
760
+ for (const decorator of dbDecs.decorators) {
761
+ const { key, props } = decorator;
762
+ const validation = this.parseRelationsToPostgres(column, childClass, childPk.id, key, props);
763
+ if (validation.startsWith("FOREIGN")) {
764
+ foreignKeys.push(validation);
765
+ }
766
+ else {
767
+ throw new db_decorators_1.InternalError(`Unsupported relation: ${key}`);
768
+ }
769
+ }
770
+ }
771
+ result[prop.toString()] = {
772
+ query: query.join(" "),
773
+ values: [],
774
+ primaryKey: isPk,
775
+ constraints: constraints,
776
+ foreignKeys: foreignKeys,
777
+ };
778
+ }
779
+ const values = Object.values(result);
780
+ const query = values.map((r) => r.query).join(",\n");
781
+ const constraints = values
782
+ .filter((c) => !!c.constraints.length)
783
+ .map((r) => r.constraints)
784
+ .join(",\n");
785
+ const foreignKeys = values
786
+ .filter((c) => !!c.foreignKeys.length)
787
+ .map((r) => r.foreignKeys)
788
+ .join(",\n");
789
+ const vals = [query, constraints];
790
+ if (foreignKeys) {
791
+ vals.push(foreignKeys);
792
+ }
793
+ const queryString = `CREATE TABLE ${tableName} (${vals.filter((v) => !!v).join(",\n")})`;
794
+ try {
795
+ await client.query(queryString);
796
+ await client.query(`CREATE TRIGGER notify_changes_${tableName}
797
+ AFTER INSERT OR UPDATE OR DELETE ON ${tableName}
798
+ FOR EACH ROW
799
+ EXECUTE FUNCTION notify_table_changes();`);
800
+ }
801
+ catch (e) {
802
+ throw this.parseError(e);
803
+ }
804
+ return result;
805
+ }
806
+ static async getCurrentUser(client) {
807
+ const queryString = `SELECT CURRENT_USER;`;
808
+ try {
809
+ const result = await client.query(queryString);
810
+ return result[0].current_user;
811
+ }
812
+ catch (e) {
813
+ throw this.parseError(e);
814
+ }
815
+ }
816
+ static decoration() {
817
+ // @table() => @Entity()
818
+ const tableKey = core_1.Adapter.key(core_1.PersistenceKeys.TABLE);
819
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
820
+ .for(tableKey)
821
+ .extend((original) => (0, Entity_1.Entity)()(original[decorator_validation_1.ModelKeys.ANCHOR] || original))
822
+ .apply();
823
+ // @pk() => @PrimaryGeneratedColumn() | @PrimaryColumn()
824
+ const pkKey = core_1.Repository.key(db_decorators_1.DBKeys.ID);
825
+ function pkDec(options) {
826
+ const decorators = [
827
+ (0, decorator_validation_1.required)(),
828
+ (0, db_decorators_1.readonly)(),
829
+ (0, decorator_validation_1.propMetadata)(pkKey, options),
830
+ ];
831
+ if (options.type)
832
+ decorators.push((0, PrimaryGeneratedColumn_1.PrimaryGeneratedColumn)());
833
+ else
834
+ decorators.push((0, PrimaryColumn_1.PrimaryColumn)({ unique: true }));
835
+ return (0, reflection_1.apply)(...decorators);
836
+ }
837
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
838
+ .for(pkKey)
839
+ .define({
840
+ decorator: pkDec,
841
+ })
842
+ .apply();
843
+ // @column("columnName") => @Column({name: "columnName"})
844
+ const columnKey = core_1.Adapter.key(core_1.PersistenceKeys.COLUMN);
845
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
846
+ .for(columnKey)
847
+ .extend({
848
+ decorator: function columm(name) {
849
+ return function column(obj, prop) {
850
+ return (0, Column_1.Column)({
851
+ name: name || prop,
852
+ nullable: true,
853
+ })(obj, prop);
854
+ };
855
+ },
856
+ transform: (args) => {
857
+ const columnName = args[1];
858
+ return [columnName];
859
+ },
860
+ })
861
+ .apply();
862
+ // @unique => @Column({unique: true})
863
+ const uniqueKey = core_1.Adapter.key(core_1.PersistenceKeys.UNIQUE);
864
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
865
+ .for(uniqueKey)
866
+ .define((0, decorator_validation_1.propMetadata)(uniqueKey, {}))
867
+ .extend((0, Column_1.Column)({ unique: true }))
868
+ .apply();
869
+ // @required => @Column({ nullable: false })
870
+ const requiredKey = decorator_validation_1.Validation.key(decorator_validation_1.ValidationKeys.REQUIRED);
871
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
872
+ .for(requiredKey)
873
+ .extend((0, Column_1.Column)({ nullable: false }))
874
+ .apply();
875
+ // @version => @VersionColumn()
876
+ const versionKey = core_1.Repository.key(db_decorators_1.DBKeys.VERSION);
877
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
878
+ .for(versionKey)
879
+ .define((0, decorator_validation_1.type)(Number.name), (0, typeorm_1.VersionColumn)())
880
+ .apply();
881
+ function ValidationUpdateKey(key) {
882
+ return db_decorators_1.UpdateValidationKeys.REFLECT + key;
883
+ }
884
+ // @timestamp(op) => @CreateDateColumn() || @UpdateDateColumn()
885
+ const timestampKey = ValidationUpdateKey(db_decorators_1.DBKeys.TIMESTAMP);
886
+ function ts(operation, format) {
887
+ const decorators = [
888
+ (0, decorator_validation_1.date)(format, db_decorators_1.DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),
889
+ (0, decorator_validation_1.required)(db_decorators_1.DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),
890
+ (0, decorator_validation_1.propMetadata)(decorator_validation_1.Validation.key(db_decorators_1.DBKeys.TIMESTAMP), {
891
+ operation: operation,
892
+ format: format,
893
+ }),
894
+ ];
895
+ if (operation.indexOf(db_decorators_1.OperationKeys.UPDATE) !== -1)
896
+ decorators.push((0, decorator_validation_1.propMetadata)(timestampKey, {
897
+ message: db_decorators_1.DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,
898
+ }));
899
+ else
900
+ decorators.push((0, db_decorators_1.readonly)());
901
+ return (0, reflection_1.apply)(...decorators);
902
+ }
903
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
904
+ .for(timestampKey)
905
+ .define({
906
+ decorator: ts,
907
+ })
908
+ .extend({
909
+ decorator: function timestamp(...ops) {
910
+ return function timestamp(obj, prop) {
911
+ if (ops.indexOf(db_decorators_1.OperationKeys.UPDATE) !== -1)
912
+ return (0, UpdateDateColumn_1.UpdateDateColumn)()(obj, prop);
913
+ return (0, CreateDateColumn_1.CreateDateColumn)()(obj, prop);
914
+ };
915
+ },
916
+ transform: (args) => {
917
+ return args[0];
918
+ },
919
+ })
920
+ .apply();
921
+ // @oneToOne(clazz) => @OneToOne(() => clazz)
922
+ const oneToOneKey = core_1.Repository.key(core_1.PersistenceKeys.ONE_TO_ONE);
923
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
924
+ .for(oneToOneKey)
925
+ .define({
926
+ decorator: function oneToOne(clazz, cascade, populate) {
927
+ const metadata = {
928
+ class: (clazz.name ? clazz.name : clazz),
929
+ cascade: cascade,
930
+ populate: populate,
931
+ };
932
+ const ormMeta = {
933
+ cascade: cascade.update === core_1.Cascade.CASCADE ||
934
+ cascade.delete === core_1.Cascade.CASCADE,
935
+ onDelete: cascade.delete ? "CASCADE" : "DEFAULT",
936
+ onUpdate: cascade.update ? "CASCADE" : "DEFAULT",
937
+ nullable: true,
938
+ eager: populate,
939
+ };
940
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.type)([
941
+ (typeof clazz === "function" && !clazz.name
942
+ ? clazz
943
+ : clazz.name),
944
+ String.name,
945
+ Number.name,
946
+ BigInt.name,
947
+ ]), (0, decorator_validation_1.propMetadata)(oneToOneKey, metadata), (0, typeorm_1.OneToOne)(() => {
948
+ if (!clazz.name)
949
+ clazz = clazz();
950
+ if (!clazz[decorator_validation_1.ModelKeys.ANCHOR])
951
+ throw new db_decorators_1.InternalError("Original Model not found in constructor");
952
+ return clazz[decorator_validation_1.ModelKeys.ANCHOR];
953
+ }, (model) => {
954
+ const pk = (0, db_decorators_1.findPrimaryKey)(new clazz()).id;
955
+ return model[pk];
956
+ }, ormMeta), (0, typeorm_1.JoinColumn)());
957
+ },
958
+ })
959
+ .apply();
960
+ // @oneToMany(clazz) => @OneToMany(() => clazz)
961
+ const oneToManyKey = core_1.Repository.key(core_1.PersistenceKeys.ONE_TO_MANY);
962
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
963
+ .for(oneToManyKey)
964
+ .define({
965
+ decorator: function oneToMany(clazz, cascade, populate) {
966
+ const metadata = {
967
+ class: (clazz.name ? clazz.name : clazz),
968
+ cascade: cascade,
969
+ populate: populate,
970
+ };
971
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.list)(clazz), (0, decorator_validation_1.propMetadata)(oneToManyKey, metadata), function OneToManyWrapper(obj, prop) {
972
+ const ormMeta = {
973
+ cascade: cascade.update === core_1.Cascade.CASCADE ||
974
+ cascade.delete === core_1.Cascade.CASCADE,
975
+ onDelete: cascade.delete ? "CASCADE" : "DEFAULT",
976
+ onUpdate: cascade.update ? "CASCADE" : "DEFAULT",
977
+ nullable: true,
978
+ eager: populate,
979
+ };
980
+ return (0, typeorm_1.OneToMany)(() => {
981
+ if (!clazz.name)
982
+ clazz = clazz();
983
+ if (!clazz[decorator_validation_1.ModelKeys.ANCHOR])
984
+ throw new db_decorators_1.InternalError("Original Model not found in constructor");
985
+ return clazz[decorator_validation_1.ModelKeys.ANCHOR];
986
+ }, (model) => {
987
+ if (!clazz.name)
988
+ clazz = clazz();
989
+ const m = new clazz();
990
+ const crossRelationKey = Object.keys(m).find((k) => {
991
+ const decs = reflection_1.Reflection.getPropertyDecorators(core_1.Repository.key(core_1.PersistenceKeys.MANY_TO_ONE), m, k, true);
992
+ if (!decs || !decs.decorators || !decs.decorators.length)
993
+ return false;
994
+ const designType = Reflect.getMetadata(decorator_validation_1.ModelKeys.TYPE, m, k);
995
+ if (!designType)
996
+ throw new db_decorators_1.InternalError(`No Type Definition found for ${k} in ${m.constructor.name}`);
997
+ return designType.name === obj.constructor.name;
998
+ });
999
+ if (!crossRelationKey)
1000
+ throw new db_decorators_1.InternalError(`Cross relation not found. Did you use @manyToOne on the ${clazz.name}?`);
1001
+ return model[crossRelationKey];
1002
+ }, ormMeta)(obj, prop);
1003
+ });
1004
+ },
1005
+ })
1006
+ .apply();
1007
+ // @manyToOne(clazz) => @ManyToOne(() => clazz)
1008
+ const manyToOneKey = core_1.Repository.key(core_1.PersistenceKeys.MANY_TO_ONE);
1009
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
1010
+ .for(manyToOneKey)
1011
+ .define({
1012
+ decorator: function manyToOne(clazz, cascade, populate) {
1013
+ const metadata = {
1014
+ class: (clazz.name ? clazz.name : clazz),
1015
+ cascade: cascade,
1016
+ populate: populate,
1017
+ };
1018
+ const ormMeta = {
1019
+ cascade: cascade.update === core_1.Cascade.CASCADE ||
1020
+ cascade.delete === core_1.Cascade.CASCADE,
1021
+ onDelete: cascade.delete ? "CASCADE" : "DEFAULT",
1022
+ onUpdate: cascade.update ? "CASCADE" : "DEFAULT",
1023
+ nullable: true,
1024
+ eager: populate,
1025
+ };
1026
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.type)([
1027
+ (typeof clazz === "function" && !clazz.name
1028
+ ? clazz
1029
+ : clazz.name),
1030
+ String.name,
1031
+ Number.name,
1032
+ BigInt.name,
1033
+ ]), (0, decorator_validation_1.propMetadata)(manyToOneKey, metadata), function ManyToOneWrapper(obj, prop) {
1034
+ return (0, typeorm_1.ManyToOne)(() => {
1035
+ if (!clazz.name)
1036
+ clazz = clazz();
1037
+ if (!clazz[decorator_validation_1.ModelKeys.ANCHOR])
1038
+ throw new db_decorators_1.InternalError("Original Model not found in constructor");
1039
+ return clazz[decorator_validation_1.ModelKeys.ANCHOR];
1040
+ }, (model) => {
1041
+ if (!clazz.name)
1042
+ clazz = clazz();
1043
+ const m = new clazz();
1044
+ const crossRelationKey = Object.keys(m).find((k) => {
1045
+ const decs = reflection_1.Reflection.getPropertyDecorators(core_1.Repository.key(core_1.PersistenceKeys.ONE_TO_MANY), m, k, true);
1046
+ if (!decs || !decs.decorators || !decs.decorators.length)
1047
+ return false;
1048
+ const listDec = Reflect.getMetadata(decorator_validation_1.Validation.key(decorator_validation_1.ValidationKeys.LIST), m, k);
1049
+ if (!listDec)
1050
+ throw new db_decorators_1.InternalError(`No Type Definition found for ${k} in ${m.constructor.name}`);
1051
+ const name = listDec.clazz[0]().name;
1052
+ return name === obj.constructor.name;
1053
+ });
1054
+ if (!crossRelationKey)
1055
+ throw new db_decorators_1.InternalError(`Cross relation not found. Did you use @manyToOne on the ${clazz.name}?`);
1056
+ return model[crossRelationKey];
1057
+ })(obj, prop);
1058
+ });
1059
+ },
1060
+ })
1061
+ .apply();
1062
+ // @manyToMany(clazz) => @ManyToMany(() => clazz)
1063
+ const manyToManyKey = core_1.Repository.key(core_1.PersistenceKeys.MANY_TO_MANY);
1064
+ decorator_validation_1.Decoration.flavouredAs(constants_1.TypeORMFlavour)
1065
+ .for(manyToManyKey)
1066
+ .define({
1067
+ decorator: function manyToMany(clazz, cascade, populate) {
1068
+ const metadata = {
1069
+ class: clazz.name,
1070
+ cascade: cascade,
1071
+ populate: populate,
1072
+ };
1073
+ const ormMeta = {
1074
+ cascade: cascade.update === core_1.Cascade.CASCADE ||
1075
+ cascade.delete === core_1.Cascade.CASCADE,
1076
+ onDelete: cascade.delete ? "CASCADE" : "DEFAULT",
1077
+ onUpdate: cascade.update ? "CASCADE" : "DEFAULT",
1078
+ nullable: true,
1079
+ eager: populate,
1080
+ };
1081
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.list)(clazz), (0, decorator_validation_1.propMetadata)(manyToManyKey, metadata), (0, typeorm_1.ManyToMany)(() => {
1082
+ if (!clazz.name)
1083
+ clazz = clazz();
1084
+ if (!clazz[decorator_validation_1.ModelKeys.ANCHOR])
1085
+ throw new db_decorators_1.InternalError("Original Model not found in constructor");
1086
+ return clazz[decorator_validation_1.ModelKeys.ANCHOR];
1087
+ }, (model) => {
1088
+ if (!clazz.name)
1089
+ clazz = clazz();
1090
+ const pk = (0, db_decorators_1.findPrimaryKey)(new clazz()).id;
1091
+ return model[pk];
1092
+ }, ormMeta), (0, typeorm_1.JoinTable)());
1093
+ },
1094
+ })
1095
+ .apply();
1096
+ }
1097
+ }
1098
+ exports.TypeORMAdapter = TypeORMAdapter;
1099
+ __decorate([
1100
+ (0, core_1.final)(),
1101
+ __metadata("design:type", Function),
1102
+ __metadata("design:paramtypes", []),
1103
+ __metadata("design:returntype", TypeORMDispatch_1.TypeORMDispatch)
1104
+ ], TypeORMAdapter.prototype, "Dispatch", null);
1105
+ __decorate([
1106
+ (0, core_1.final)(),
1107
+ __metadata("design:type", Function),
1108
+ __metadata("design:paramtypes", []),
1109
+ __metadata("design:returntype", Object)
1110
+ ], TypeORMAdapter.prototype, "repository", null);
1111
+ __decorate([
1112
+ (0, core_1.final)(),
1113
+ __metadata("design:type", Function),
1114
+ __metadata("design:paramtypes", []),
1115
+ __metadata("design:returntype", query_1.TypeORMStatement)
1116
+ ], TypeORMAdapter.prototype, "Statement", null);
1117
+ __decorate([
1118
+ (0, core_1.final)(),
1119
+ __metadata("design:type", Function),
1120
+ __metadata("design:paramtypes", [Object]),
1121
+ __metadata("design:returntype", Promise)
1122
+ ], TypeORMAdapter.prototype, "Sequence", null);
1123
+ __decorate([
1124
+ (0, core_1.final)(),
1125
+ __metadata("design:type", Function),
1126
+ __metadata("design:paramtypes", [Object]),
1127
+ __metadata("design:returntype", Promise)
1128
+ ], TypeORMAdapter.prototype, "index", null);
1129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TypeORMAdapter.js","sourceRoot":"","sources":["../src/TypeORMAdapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Adapter,\n  Cascade,\n  CascadeMetadata,\n  ConnectionError,\n  final,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  Sequence,\n  type SequenceOptions,\n} from \"@decaf-ts/core\";\nimport { reservedAttributes, TypeORMFlavour } from \"./constants\";\nimport {\n  BaseError,\n  ConflictError,\n  Context,\n  DBKeys,\n  DEFAULT_ERROR_MESSAGES as DB_DEFAULT_ERROR_MESSAGES,\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n  OperationKeys,\n  readonly,\n  UpdateValidationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  type Constructor,\n  date,\n  Decoration,\n  DEFAULT_ERROR_MESSAGES,\n  list,\n  MaxLengthValidatorOptions,\n  MaxValidatorOptions,\n  MinLengthValidatorOptions,\n  MinValidatorOptions,\n  Model,\n  ModelKeys,\n  PatternValidatorOptions,\n  prop,\n  propMetadata,\n  required,\n  type,\n  TypeMetadata,\n  Validation,\n  ValidationKeys,\n  ValidatorOptions,\n} from \"@decaf-ts/decorator-validation\";\nimport { IndexError } from \"./errors\";\nimport { TypeORMStatement } from \"./query\";\nimport { TypeORMSequence } from \"./sequences\";\nimport { generateIndexes } from \"./indexes\";\nimport { TypeORMFlags, TypeORMQuery, TypeORMTableSpec } from \"./types\";\nimport { apply, Reflection } from \"@decaf-ts/reflection\";\nimport { TypeORMRepository } from \"./TypeORMRepository\";\nimport { Logging } from \"@decaf-ts/logging\";\nimport { TypeORMDispatch } from \"./TypeORMDispatch\";\nimport { convertJsRegexToPostgres } from \"./utils\";\nimport {\n  DataSource,\n  FindOneOptions,\n  In,\n  InsertResult,\n  RelationOptions,\n  OneToOne,\n  JoinColumn,\n  ManyToMany,\n  SelectQueryBuilder,\n  VersionColumn,\n  OneToMany,\n  ManyToOne,\n  JoinTable,\n} from \"typeorm\";\nimport { DataSourceOptions } from \"typeorm/data-source/DataSourceOptions\";\nimport { Column } from \"./overrides/Column\";\nimport { UpdateDateColumn } from \"./overrides/UpdateDateColumn\";\nimport { CreateDateColumn } from \"./overrides/CreateDateColumn\";\nimport { PrimaryGeneratedColumn } from \"./overrides/PrimaryGeneratedColumn\";\nimport { PrimaryColumn } from \"./overrides/PrimaryColumn\";\nimport { Entity } from \"./overrides/Entity\";\n\nexport async function createdByOnPostgresCreateUpdate<\n  M extends Model,\n  R extends TypeORMRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<TypeORMFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"user\");\n    model[key] = user as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new InternalError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Adapter for TypeORM-backed persistence operations.\n * @summary Implements the Decaf.ts Adapter over a TypeORM DataSource, providing CRUD operations, query/statement factories, sequence management, error parsing, and decoration helpers.\n * @template Y The native configuration type (TypeORM DataSourceOptions).\n * @template F The repository flags type.\n * @template C The context type.\n * @param {DataSourceOptions} scope The DataSource options for the adapter.\n * @param {string} flavour The flavour of the adapter.\n * @param {string} [alias] Optional alias for the adapter.\n * @class TypeORMAdapter\n * @example\n * const adapter = new TypeORMAdapter({ type: 'postgres', /* ... *\\/ });\n * await adapter.initialize();\n * const repo = new (adapter.repository<User>())(adapter, User);\n * const created = await repo.create(new User({ name: 'Alice' }));\n *\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Adapter as TypeORMAdapter\n *   participant Repo as TypeORMRepository\n *   participant DS as TypeORM DataSource\n *\n *   App->>Adapter: new TypeORMAdapter(opts)\n *   Adapter->>DS: initialize()\n *   App->>Adapter: repository()\n *   Adapter-->>App: TypeORMRepository\n *   App->>Repo: create(model)\n *   Repo->>Adapter: prepare/create/revert\n *   Adapter-->>Repo: Model\n *   Repo-->>App: Model\n */\nexport class TypeORMAdapter extends Adapter<\n  DataSourceOptions,\n  TypeORMQuery,\n  TypeORMFlags,\n  Context<TypeORMFlags>\n> {\n  private _dataSource?: DataSource;\n\n  get dataSource(): DataSource {\n    if (!this._dataSource) {\n      const models = Adapter.models(this.flavour);\n      this._dataSource = new DataSource(\n        Object.assign(this.native, {\n          entities: models.map((c) => c[ModelKeys.ANCHOR as keyof typeof c]),\n        })\n      );\n    }\n    return this._dataSource;\n  }\n  // protected dataSou\n\n  constructor(options: DataSourceOptions, alias?: string) {\n    super(options, TypeORMFlavour, alias);\n  }\n\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<TypeORMFlags>\n  ): Promise<TypeORMFlags> {\n    const f = await super.flags(operation, model, flags);\n    const newObj: any = {\n      user: (await TypeORMAdapter.getCurrentUser(this.dataSource)) as string,\n    };\n    const m = new model();\n\n    const exceptions: string[] = [];\n    if (operation === OperationKeys.CREATE) {\n      const pk = findPrimaryKey(m).id;\n      exceptions.push(pk as string);\n    }\n\n    if (\n      operation === OperationKeys.CREATE ||\n      operation === OperationKeys.UPDATE\n    ) {\n      const decs = Object.keys(m).reduce((accum: Record<string, any>, key) => {\n        const decs = Reflection.getPropertyDecorators(\n          ValidationKeys.REFLECT,\n          m,\n          key,\n          true\n        );\n        const dec = decs.decorators.find(\n          (dec: any) =>\n            dec.key === DBKeys.TIMESTAMP &&\n            dec.props.operation.indexOf(operation) !== -1\n        );\n        if (dec) {\n          accum[key] = dec.props;\n        }\n        return accum;\n      }, {});\n\n      exceptions.push(...Object.keys(decs));\n    }\n\n    newObj.ignoredValidationProperties = (\n      f.ignoredValidationProperties ? f.ignoredValidationProperties : []\n    ).concat(...exceptions);\n    return Object.assign(f, newObj) as TypeORMFlags;\n  }\n\n  @final()\n  protected override Dispatch(): TypeORMDispatch {\n    return new TypeORMDispatch();\n  }\n\n  @final()\n  override repository<M extends Model>(): Constructor<TypeORMRepository<M>> {\n    return TypeORMRepository;\n  }\n\n  /**\n   * @description Creates a new Postgres statement for querying\n   * @summary Factory method that creates a new PostgresStatement instance for building queries\n   * @template M - The model type\n   * @return {TypeORMStatement<M, any>} A new PostgresStatement instance\n   */\n  @final()\n  Statement<M extends Model>(): TypeORMStatement<M, any> {\n    return new TypeORMStatement(this);\n  }\n\n  /**\n   * @description Creates a new PostgreSQL sequence\n   * @summary Factory method that creates a new PostgreSQLSequence instance for managing sequences\n   * @param {SequenceOptions} options - The options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to a new Sequence instance\n   */\n  @final()\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new TypeORMSequence(options, this);\n  }\n\n  /**\n   * @description Initializes the adapter by creating indexes for all managed models\n   * @summary Sets up the necessary database indexes for all models managed by this adapter\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   */\n  async initialize(): Promise<void> {\n    const ds = this.dataSource;\n    try {\n      await ds.initialize();\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    const log = this.log.for(this.initialize);\n    log.verbose(`${this.flavour} adapter initialized`);\n  }\n\n  /**\n   * @description Creates indexes for the given models\n   * @summary Abstract method that must be implemented to create database indexes for the specified models\n   * @template M - The model type\n   * @param {...Constructor<M>} models - The model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   */\n  @final()\n  protected async index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void> {\n    const indexes: TypeORMQuery[] = generateIndexes(models);\n\n    try {\n      await this.dataSource.query(\"BEGIN\");\n\n      for (const index of indexes) {\n        await this.dataSource.query(index.query, index.values);\n      }\n\n      await this.dataSource.query(\"COMMIT\");\n    } catch (e: unknown) {\n      await this.dataSource.query(\"ROLLBACK\");\n      throw this.parseError(e as Error);\n    }\n  }\n\n  /**\n   * @description Executes a raw SQL query against the database\n   * @summary Abstract method that must be implemented to execute raw SQL queries\n   * @template R - The result type\n   * @param {TypeORMQuery} q - The query to execute\n   * @return {Promise<R>} A promise that resolves to the query result\n   */\n  override async raw<R>(q: TypeORMQuery): Promise<R> {\n    const log = this.log.for(this.raw);\n    try {\n      if (!this.dataSource.isInitialized) await this.dataSource.initialize();\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    try {\n      const { query, values } = q;\n      log.debug(\n        `executing query: ${(query as unknown as SelectQueryBuilder<any>).getSql()}`\n      );\n      const response = await this.dataSource.query(query, values);\n      return response as R;\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  override prepare<M extends Model>(\n    model: M,\n    pk: keyof M,\n    child = false\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const prepared = super.prepare(model, pk);\n\n    prepared.record = Object.entries(prepared.record).reduce(\n      (accum: Record<string, any>, [key, value]) => {\n        if (key === PersistenceKeys.METADATA || this.isReserved(key))\n          return accum;\n        if (value === undefined) {\n          return accum;\n        }\n\n        if (value instanceof Date) {\n          value = new Date(value.getTime());\n        } else if (Model.isModel(value)) {\n          value = this.prepare(value, findPrimaryKey(value).id, true).record;\n        } else {\n          switch (typeof value) {\n            case \"string\":\n              value = `${value}`;\n              break;\n            default:\n            //do nothing;\n          }\n        }\n        accum[key] = value;\n        return accum;\n      },\n      {}\n    );\n    const constr: Constructor<any> | undefined = Model.get(\n      model.constructor.name\n    );\n    if (!constr)\n      throw new InternalError(\n        `Model ${model.constructor.name} not found in registry`\n      );\n    const result = child\n      ? new (constr as any)[ModelKeys.ANCHOR as keyof typeof constr]()\n      : new constr();\n    if (child)\n      Object.defineProperty(result, \"constructor\", {\n        configurable: false,\n        enumerable: false,\n        value: (constr as any)[ModelKeys.ANCHOR as keyof typeof constr],\n        writable: false,\n      });\n    Object.entries(prepared.record).forEach(\n      ([key, val]) => (result[key as keyof typeof result] = val)\n    );\n    prepared.record = result;\n    return prepared;\n  }\n\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint,\n    transient?: Record<string, any>\n  ): M {\n    const log = this.log.for(this.revert);\n    if (transient) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient).forEach(([key, val]) => {\n        if (key in obj)\n          throw new InternalError(\n            `Transient property ${key} already exists on model ${typeof clazz === \"string\" ? clazz : clazz.name}. should be impossible`\n          );\n        (obj as M)[key as keyof M] = val;\n      });\n    }\n\n    return new (clazz as Constructor<M>)(obj);\n  }\n\n  /**\n   * @description Creates a new record in the database\n   * @summary Abstract method that must be implemented to create a new record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {Record<string, any>} model - The model to create\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created record\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      return await repo.save(model);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  /**\n   * @description Reads a record from the database\n   * @summary Abstract method that must be implemented to read a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {string} pk - primary key colum\n   * @return {Promise<Record<string, any>>} A promise that resolves to the read record\n   */\n  override async read(\n    tableName: string,\n    id: string | number,\n    pk: string\n  ): Promise<Record<string, any>> {\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    let result: any;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      const q: FindOneOptions = {\n        where: {\n          [pk]: id,\n        },\n      };\n      result = (await repo.findOne(q)) as Record<string, any>;\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    if (!result)\n      throw new NotFoundError(\n        `Record with id: ${id} not found in table ${typeof tableName === \"string\" ? tableName : Repository.table(tableName)}`\n      );\n    return result;\n  }\n\n  /**\n   * @description Updates a record in the database\n   * @summary Abstract method that must be implemented to update a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {Record<string, any>} model - The model to update\n   * @param {string} pk - Additional arguments\n   * @return A promise that resolves to the updated record\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      return repo.save(model);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  /**\n   * @description Deletes a record from the database\n   * @summary Abstract method that must be implemented to delete a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {string} pk - Additional arguments\n   * @return A promise that resolves to the deleted record\n   */\n  override async delete(\n    tableName: string,\n    id: string | number,\n    pk: string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      const model = await this.read(tableName, id, pk);\n      const res = await repo.delete(id);\n      return model;\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  override async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      const result: InsertResult = await repo.insert(model);\n      return this.readAll(\n        tableName,\n        result.identifiers.map((id) => id.id),\n        \"id\"\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  override async readAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    pk: string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (!id.length) return [];\n\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      return repo.findBy({ [pk]: In(id) });\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    model: Record<string, any>[],\n    pk: string,\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const result = [];\n    for (const m of model) {\n      result.push(await this.update(tableName, m[pk], m, ...args));\n    }\n    return result;\n  }\n\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[],\n    pk: string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (!ids.length) return [];\n    const m: Constructor<Model> = tableName as unknown as Constructor<Model>;\n    try {\n      const repo = this.dataSource.getRepository(m);\n      const models = await this.readAll(tableName, ids, pk);\n      await repo.delete(ids);\n      return models;\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  /**\n   * @description Parses an error and converts it to a BaseError\n   * @summary Converts various error types to appropriate BaseError subtypes\n   * @param {Error|string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error as a BaseError\n   */\n  parseError(err: Error | string, reason?: string): BaseError {\n    return TypeORMAdapter.parseError(err, reason);\n  }\n\n  /**\n   * @description Checks if an attribute is reserved\n   * @summary Determines if an attribute name is reserved in PostgreSQL\n   * @param {string} attr - The attribute name to check\n   * @return {boolean} True if the attribute is reserved, false otherwise\n   */\n  protected override isReserved(attr: string): boolean {\n    return !!attr.match(reservedAttributes);\n  }\n\n  /**\n   * @description Static method to parse an error and convert it to a BaseError\n   * @summary Converts various error types to appropriate BaseError subtypes based on PostgreSQL error codes and messages\n   * @param {Error|string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error as a BaseError\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant parseError\n   *   participant ErrorTypes\n   *\n   *   Caller->>parseError: err, reason\n   *   Note over parseError: Check if err is already a BaseError\n   *   alt err is BaseError\n   *     parseError-->>Caller: return err\n   *   else err is string\n   *     Note over parseError: Extract code from string\n   *     alt code matches \"duplicate key|already exists\"\n   *       parseError->>ErrorTypes: new ConflictError(code)\n   *       ErrorTypes-->>Caller: ConflictError\n   *     else code matches \"does not exist|not found\"\n   *       parseError->>ErrorTypes: new NotFoundError(code)\n   *       ErrorTypes-->>Caller: NotFoundError\n   *     end\n   *   else err has code property\n   *     Note over parseError: Extract code and reason\n   *   else\n   *     Note over parseError: Use err.message as code\n   *   end\n   *\n   *   Note over parseError: Switch on PostgreSQL error code\n   *   alt code is 23505 (unique_violation)\n   *     parseError->>ErrorTypes: new ConflictError(reason)\n   *     ErrorTypes-->>Caller: ConflictError\n   *   else code is 23503 (foreign_key_violation)\n   *     parseError->>ErrorTypes: new ConflictError(reason)\n   *     ErrorTypes-->>Caller: ConflictError\n   *   else code is 42P01 (undefined_table)\n   *     parseError->>ErrorTypes: new NotFoundError(reason)\n   *     ErrorTypes-->>Caller: NotFoundError\n   *   else code is 42703 (undefined_column)\n   *     parseError->>ErrorTypes: new NotFoundError(reason)\n   *     ErrorTypes-->>Caller: NotFoundError\n   *   else code is 42P07 (duplicate_table)\n   *     parseError->>ErrorTypes: new ConflictError(reason)\n   *     ErrorTypes-->>Caller: ConflictError\n   *   else code is 42P16 (invalid_table_definition)\n   *     parseError->>ErrorTypes: new IndexError(err)\n   *     ErrorTypes-->>Caller: IndexError\n   *   else code matches \"ECONNREFUSED\"\n   *     parseError->>ErrorTypes: new ConnectionError(err)\n   *     ErrorTypes-->>Caller: ConnectionError\n   *   else\n   *     parseError->>ErrorTypes: new InternalError(err)\n   *     ErrorTypes-->>Caller: InternalError\n   *   end\n   */\n  protected static parseError(err: Error | string, reason?: string): BaseError {\n    if (err instanceof BaseError) return err as any;\n    const code: string = typeof err === \"string\" ? err : err.message;\n\n    if (code.match(/duplicate key|already exists/g))\n      return new ConflictError(code);\n    if (code.match(/does not exist|not found/g)) return new NotFoundError(code);\n\n    // PostgreSQL error codes: https://www.postgresql.org/docs/current/errcodes-appendix.html\n    switch (code.toString()) {\n      // Integrity constraint violations\n      case \"23505\": // unique_violation\n      case \"23503\": // foreign_key_violation\n      case \"42P07\": // duplicate_table\n        return new ConflictError(reason as string);\n\n      // Object not found errors\n      case \"42P01\": // undefined_table\n      case \"42703\": // undefined_column\n        return new NotFoundError(reason as string);\n\n      // Invalid object definition\n      case \"42P16\": // invalid_table_definition\n        return new IndexError(err);\n\n      // Connection errors\n      default:\n        if (code.toString().match(/ECONNREFUSED/g))\n          return new ConnectionError(err);\n        return new InternalError(err);\n    }\n  }\n\n  static async connect(config: DataSourceOptions): Promise<DataSource> {\n    const con = new DataSource(config);\n    if (!con.isInitialized) await con.initialize();\n    return con;\n  }\n\n  static async createDatabase(\n    dataSource: DataSource,\n    dbName: string\n  ): Promise<void> {\n    const log = Logging.for(this.createDatabase);\n    log.verbose(`Creating database ${dbName}`);\n    try {\n      await dataSource.query(`CREATE DATABASE ${dbName}`);\n      log.info(`Created database ${dbName}`);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  static async createNotifyFunction(\n    dataSource: DataSource,\n    user: string\n  ): Promise<void> {\n    const log = Logging.for(this.createNotifyFunction);\n    log.verbose(`Creating notify function`);\n    try {\n      await dataSource.query(\n        `CREATE OR REPLACE FUNCTION notify_table_changes()\nRETURNS trigger AS $$\nBEGIN\n    PERFORM pg_notify(\n        'table_changes',\n        json_build_object(\n            'table', TG_TABLE_NAME,\n            'action', TG_OP,\n            'data', row_to_json(NEW),\n            'old_data', row_to_json(OLD)\n        )::text\n    );\n    RETURN NEW;\nEND;\n$$ LANGUAGE plpgsql SECURITY DEFINER\n;`\n      );\n      await dataSource.query(\n        `ALTER FUNCTION notify_table_changes() OWNER TO ${user};`\n      );\n      await dataSource.query(`\n            GRANT EXECUTE ON FUNCTION notify_table_changes() TO public;\n        `);\n      log.info(`Created notify function`);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  static async deleteDatabase(\n    dataSource: DataSource,\n    dbName: string,\n    user?: string\n  ): Promise<void> {\n    try {\n      if (user) await dataSource.query(`DROP OWNED BY ${user} CASCADE;`);\n      await dataSource.query(`DROP DATABASE ${dbName}`);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  static async createUser(\n    dataSource: DataSource,\n    dbName: string,\n    user: string,\n    password: string\n  ): Promise<void> {\n    try {\n      await dataSource.query(`CREATE USER ${user} WITH PASSWORD '${password}'`);\n      await dataSource.query(`GRANT CONNECT ON DATABASE ${dbName} TO ${user}`);\n\n      await dataSource.query(`GRANT USAGE ON SCHEMA public TO ${user}`);\n      await dataSource.query(`GRANT CREATE ON SCHEMA public TO ${user}`);\n      await dataSource.query(\n        `GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO ${user}`\n      );\n      await dataSource.query(\n        `GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO ${user}`\n      );\n      await dataSource.query(\n        `GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public TO ${user}`\n      );\n      await dataSource.query(\n        `ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON TABLES TO ${user}`\n      );\n      await dataSource.query(\n        `ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON SEQUENCES TO ${user}`\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  static async deleteUser(\n    client: DataSource,\n    user: string,\n    admin: string\n  ): Promise<void> {\n    try {\n      await client.query(`REASSIGN OWNED BY ${user} TO ${admin}`);\n      await client.query(\n        `REVOKE ALL ON ALL TABLES IN SCHEMA public FROM ${user}`\n      );\n      await client.query(`REVOKE ALL ON SCHEMA public FROM ${user}`);\n      await client.query(\n        `REVOKE ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public FROM ${user}`\n      );\n      await client.query(\n        `REVOKE ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public FROM ${user}`\n      );\n      await client.query(\n        `ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON TABLES FROM ${user}`\n      );\n      await client.query(\n        `ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON SEQUENCES FROM ${user};`\n      );\n      await client.query(\n        `ALTER DEFAULT PRIVILEGES FOR ROLE ${admin} IN SCHEMA public REVOKE ALL ON FUNCTIONS FROM ${user}`\n      );\n      await client.query(`DROP OWNED BY ${user} CASCADE`);\n      await client.query(`DROP USER IF EXISTS \"${user}\"`);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  private static parseTypeToPostgres(\n    type: string,\n    isPk: boolean,\n    isFk = false\n  ) {\n    switch (type.toLowerCase()) {\n      case \"string\":\n        return isPk ? \"TEXT PRIMARY KEY\" : isFk ? \"TEXT\" : \"VARCHAR\";\n      case \"number\":\n        return isPk ? \"SERIAL PRIMARY KEY\" : \"INTEGER\";\n      case \"boolean\":\n        return \"BOOLEAN\";\n      case \"date\":\n        return \"TIMESTAMP\";\n      case \"bigint\":\n        return isPk ? \"BIGINT PRIMARY KEY\" : \"BIGINT\";\n      default: {\n        const m = Model.get(type);\n        if (m) {\n          const mm = new m();\n          const type = Reflection.getTypeFromDecorator(\n            mm,\n            findPrimaryKey(mm).id\n          );\n          return {\n            model: m,\n            pkType: type,\n          };\n        }\n        throw new InternalError(`Unsupported type: ${type}`);\n      }\n    }\n  }\n\n  private static parseValidationToPostgres(\n    prop: string,\n    type: string,\n    isPk: boolean,\n    key: string,\n    options: ValidatorOptions\n  ) {\n    switch (key) {\n      case ValidationKeys.REQUIRED:\n        return \"NOT NULL\";\n      case ValidationKeys.MAX_LENGTH:\n        if (isPk || !options || type.toLowerCase() !== \"string\") {\n          return \"\";\n        }\n        return `(${(options as MaxLengthValidatorOptions)[ValidationKeys.MAX_LENGTH]})`;\n      case ValidationKeys.MIN_LENGTH:\n        return `CONSTRAINT ${prop}_min_length_check CHECK (LENGTH(${prop}) >= ${(options as MinLengthValidatorOptions)[ValidationKeys.MIN_LENGTH]})`;\n      case ValidationKeys.PATTERN:\n      case ValidationKeys.URL:\n      case ValidationKeys.EMAIL:\n        return `CONSTRAINT ${prop}_pattern_check CHECK (${prop} ~ '${convertJsRegexToPostgres((options as PatternValidatorOptions)[ValidationKeys.PATTERN] as string)}')`;\n      case ValidationKeys.TYPE:\n      case ValidationKeys.DATE:\n        return \"\";\n      case ValidationKeys.MIN:\n        return `CONSTRAINT ${prop}_${key}_check CHECK (${prop} >= ${(options as MinValidatorOptions)[ValidationKeys.MIN]})`;\n      case ValidationKeys.MAX:\n        return `CONSTRAINT ${prop}_${key}_check CHECK (${prop} <= ${(options as MaxValidatorOptions)[ValidationKeys.MAX]})`;\n      case ValidationKeys.PASSWORD:\n      default:\n        throw new InternalError(`Unsupported type: ${key}`);\n    }\n  }\n\n  private static parseRelationsToPostgres(\n    prop: string,\n    clazz: Constructor<Model>,\n    pk: string,\n    key: PersistenceKeys,\n    options: RelationsMetadata\n  ) {\n    const tableName = Repository.table(clazz);\n    const { cascade } = options;\n    const cascadeStr = `${cascade.update ? \" ON UPDATE CASCADE\" : \"\"}${cascade.delete ? \" ON DELETE CASCADE\" : \"\"}`;\n    switch (`relations${key}`) {\n      case PersistenceKeys.ONE_TO_ONE:\n        return `FOREIGN KEY (${prop}) REFERENCES ${tableName}(${pk})${cascadeStr}`;\n      default:\n        throw new InternalError(`Unsupported operation: ${key}`);\n    }\n  }\n\n  static async createTable<M extends Model>(\n    client: DataSource,\n    model: Constructor<M>\n  ): Promise<Record<string, TypeORMTableSpec>> {\n    const result: Record<string, TypeORMTableSpec> = {};\n    const m = new model({});\n    const tableName = Repository.table(model);\n    const { id } = findPrimaryKey(m);\n\n    let isPk: boolean, column: string;\n    const properties = Object.getOwnPropertyNames(m) as (keyof M)[];\n    for (const prop of properties) {\n      if (\n        typeof (this as any)[prop] === \"function\" ||\n        prop.toString().startsWith(\"_\") ||\n        prop === \"constructor\"\n      ) {\n        continue;\n      }\n\n      isPk = prop === id;\n      column = Repository.column(m, prop.toString());\n\n      const allDecs = Reflection.getPropertyDecorators(\n        ValidationKeys.REFLECT,\n        m,\n        prop.toString(),\n        false,\n        true\n      );\n\n      const decoratorData = allDecs.decorators.reduce(\n        (accum: Record<string, any>, el) => {\n          const { key, props } = el;\n          if (key === ModelKeys.TYPE && !accum[ValidationKeys.TYPE]) {\n            accum[ValidationKeys.TYPE] = {\n              customTypes: [props.name as string],\n              message: DEFAULT_ERROR_MESSAGES.TYPE,\n              description: \"defines the accepted types for the attribute\",\n            };\n          } else if (key !== ValidationKeys.TYPE) {\n            // do nothing. we can only support basis ctypes at this time\n            accum[key] = props;\n          }\n          return accum;\n        },\n        {}\n      );\n\n      const dbDecs = Reflection.getPropertyDecorators(\n        Repository.key(\"relations\"),\n        m,\n        prop.toString(),\n        true,\n        true\n      );\n\n      const query: string[] = [];\n      const constraints: string[] = [];\n      const foreignKeys: string[] = [];\n      let typeData: TypeMetadata | undefined = undefined;\n      let childClass: Constructor<Model> | undefined = undefined;\n      let childPk: any;\n\n      if (Object.keys(decoratorData).length) {\n        typeData = decoratorData[ValidationKeys.TYPE] as TypeMetadata;\n\n        if (!typeData) {\n          throw new Error(`Missing type information`);\n        }\n\n        let parsedType:\n          | string\n          | { model: Constructor<Model> | string; pkType?: string } =\n          this.parseTypeToPostgres(\n            typeof (typeData.customTypes as any[])[0] === \"function\"\n              ? (typeData.customTypes as any)[0]()\n              : (typeData.customTypes as any)[0],\n            isPk\n          );\n        if (typeof parsedType === \"string\") {\n          parsedType = { model: parsedType };\n        }\n        let typeStr:\n          | string\n          | { model: Constructor<Model> | string; pkType?: string } =\n          parsedType.model as\n            | string\n            | { model: Constructor<Model> | string; pkType?: string };\n\n        if (typeof typeStr !== \"string\") {\n          if (Array.isArray(typeStr)) {\n            console.log(typeStr);\n          }\n\n          // continue;\n          // const res: Record<string, PostgresTableSpec> = await this.createTable(pool, typeStr);\n          try {\n            childClass = parsedType.model as Constructor<Model>;\n            const m = new childClass();\n            childPk = findPrimaryKey(m);\n            typeStr = this.parseTypeToPostgres(\n              parsedType.pkType as string,\n              false,\n              true\n            );\n            await this.createTable(client, childClass);\n          } catch (e: unknown) {\n            if (!(e instanceof ConflictError)) throw e;\n          }\n        }\n\n        let tp = Array.isArray(typeData.customTypes)\n          ? typeData.customTypes[0]\n          : typeData.customTypes;\n        tp = typeof tp === \"function\" && !tp.name ? tp() : tp;\n        const validationStr = this.parseValidationToPostgres(\n          column,\n          tp as any,\n          isPk,\n          ValidationKeys.MAX_LENGTH,\n          (decoratorData[\n            ValidationKeys.MAX_LENGTH\n          ] as MaxLengthValidatorOptions) || {\n            [ValidationKeys.MAX_LENGTH]: 255,\n          }\n        );\n\n        const q = `${column} ${typeStr}${validationStr}`;\n\n        if (isPk) {\n          query.unshift(q);\n        } else {\n          query.push(q);\n        }\n\n        for (const [key, props] of Object.entries(decoratorData).filter(\n          ([k]) =>\n            ![ValidationKeys.TYPE, ValidationKeys.MAX_LENGTH].includes(k as any)\n        )) {\n          const validation = this.parseValidationToPostgres(\n            column,\n            tp as any,\n            isPk,\n            key,\n            props\n          );\n          if (validation.startsWith(\"CONSTRAINT\")) {\n            constraints.push(validation);\n          } else {\n            if (validation) {\n              query.push(validation);\n            }\n          }\n        }\n      }\n\n      // TODO ignore for now. this leaves foreign keys out\n      // eslint-disable-next-line no-constant-binary-expression\n      if (false || (dbDecs && dbDecs.decorators.length)) {\n        if (!typeData) throw new Error(`Missing type information`);\n        for (const decorator of dbDecs.decorators) {\n          const { key, props } = decorator;\n          const validation = this.parseRelationsToPostgres(\n            column,\n            childClass as Constructor<Model>,\n            childPk.id,\n            key as PersistenceKeys,\n            props as unknown as RelationsMetadata\n          );\n          if (validation.startsWith(\"FOREIGN\")) {\n            foreignKeys.push(validation);\n          } else {\n            throw new InternalError(`Unsupported relation: ${key}`);\n          }\n        }\n      }\n\n      result[prop.toString()] = {\n        query: query.join(\" \"),\n        values: [],\n        primaryKey: isPk,\n        constraints: constraints,\n        foreignKeys: foreignKeys,\n      };\n    }\n\n    const values = Object.values(result);\n    const query = values.map((r) => r.query).join(\",\\n\");\n    const constraints = values\n      .filter((c) => !!c.constraints.length)\n      .map((r) => r.constraints)\n      .join(\",\\n\");\n    const foreignKeys = values\n      .filter((c) => !!c.foreignKeys.length)\n      .map((r) => r.foreignKeys)\n      .join(\",\\n\");\n    const vals = [query, constraints];\n    if (foreignKeys) {\n      vals.push(foreignKeys);\n    }\n    const queryString = `CREATE TABLE ${tableName} (${vals.filter((v) => !!v).join(\",\\n\")})`;\n    try {\n      await client.query(queryString);\n      await client.query(\n        `CREATE TRIGGER notify_changes_${tableName}\nAFTER INSERT OR UPDATE OR DELETE ON ${tableName}\n    FOR EACH ROW\n    EXECUTE FUNCTION notify_table_changes();`\n      );\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    return result;\n  }\n\n  static async getCurrentUser(client: DataSource): Promise<string> {\n    const queryString = `SELECT CURRENT_USER;`;\n    try {\n      const result = await client.query(queryString);\n      return result[0].current_user;\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n  }\n\n  static decoration() {\n    // @table() => @Entity()\n    const tableKey = Adapter.key(PersistenceKeys.TABLE);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(tableKey)\n      .extend((original: any) =>\n        Entity()(original[ModelKeys.ANCHOR] || original)\n      )\n      .apply();\n\n    // @pk() => @PrimaryGeneratedColumn() | @PrimaryColumn()\n    const pkKey = Repository.key(DBKeys.ID);\n\n    function pkDec(options: SequenceOptions) {\n      const decorators: any[] = [\n        required(),\n        readonly(),\n        propMetadata(pkKey, options),\n      ];\n      if (options.type) decorators.push(PrimaryGeneratedColumn());\n      else decorators.push(PrimaryColumn({ unique: true }));\n      return apply(...decorators);\n    }\n\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(pkKey)\n      .define({\n        decorator: pkDec,\n      })\n      .apply();\n\n    // @column(\"columnName\") => @Column({name: \"columnName\"})\n    const columnKey = Adapter.key(PersistenceKeys.COLUMN);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(columnKey)\n      .extend({\n        decorator: function columm(name: string) {\n          return function column(obj: any, prop: any) {\n            return Column({\n              name: name || prop,\n              nullable: true,\n            })(obj, prop);\n          };\n        },\n        transform: (args: any[]) => {\n          const columnName = args[1];\n          return [columnName];\n        },\n      })\n      .apply();\n\n    // @unique => @Column({unique: true})\n    const uniqueKey = Adapter.key(PersistenceKeys.UNIQUE);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(uniqueKey)\n      .define(propMetadata(uniqueKey, {}))\n      .extend(Column({ unique: true }))\n      .apply();\n\n    // @required => @Column({ nullable: false })\n    const requiredKey = Validation.key(ValidationKeys.REQUIRED);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(requiredKey)\n      .extend(Column({ nullable: false }))\n      .apply();\n\n    // @version => @VersionColumn()\n    const versionKey = Repository.key(DBKeys.VERSION);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(versionKey)\n      .define(type(Number.name), VersionColumn())\n      .apply();\n\n    function ValidationUpdateKey(key: string) {\n      return UpdateValidationKeys.REFLECT + key;\n    }\n\n    // @timestamp(op) => @CreateDateColumn() || @UpdateDateColumn()\n    const timestampKey = ValidationUpdateKey(DBKeys.TIMESTAMP);\n\n    function ts(operation: OperationKeys[], format: string) {\n      const decorators: any[] = [\n        date(format, DB_DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n        required(DB_DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n        propMetadata(Validation.key(DBKeys.TIMESTAMP), {\n          operation: operation,\n          format: format,\n        }),\n      ];\n      if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n        decorators.push(\n          propMetadata(timestampKey, {\n            message: DB_DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n          })\n        );\n      else decorators.push(readonly());\n      return apply(...decorators);\n    }\n\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(timestampKey)\n      .define({\n        decorator: ts,\n      })\n      .extend({\n        decorator: function timestamp(...ops: OperationKeys[]) {\n          return function timestamp(obj: any, prop: any) {\n            if (ops.indexOf(OperationKeys.UPDATE) !== -1)\n              return UpdateDateColumn()(obj, prop);\n            return CreateDateColumn()(obj, prop);\n          };\n        },\n        transform: (args: any[]) => {\n          return args[0];\n        },\n      })\n      .apply();\n\n    // @oneToOne(clazz) => @OneToOne(() => clazz)\n    const oneToOneKey = Repository.key(PersistenceKeys.ONE_TO_ONE);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(oneToOneKey)\n      .define({\n        decorator: function oneToOne(\n          clazz: Constructor<any> | (() => Constructor<any>),\n          cascade: CascadeMetadata,\n          populate: boolean\n        ) {\n          const metadata: RelationsMetadata = {\n            class: (clazz.name ? clazz.name : clazz) as string,\n            cascade: cascade,\n            populate: populate,\n          };\n          const ormMeta: RelationOptions = {\n            cascade:\n              cascade.update === Cascade.CASCADE ||\n              cascade.delete === Cascade.CASCADE,\n            onDelete: cascade.delete ? \"CASCADE\" : \"DEFAULT\",\n            onUpdate: cascade.update ? \"CASCADE\" : \"DEFAULT\",\n            nullable: true,\n            eager: populate,\n          };\n          return apply(\n            prop(PersistenceKeys.RELATIONS),\n            type([\n              (typeof clazz === \"function\" && !clazz.name\n                ? clazz\n                : clazz.name) as any,\n              String.name,\n              Number.name,\n              BigInt.name,\n            ]),\n            propMetadata(oneToOneKey, metadata),\n            OneToOne(\n              () => {\n                if (!clazz.name) clazz = (clazz as any)();\n                if (!clazz[ModelKeys.ANCHOR as keyof typeof clazz])\n                  throw new InternalError(\n                    \"Original Model not found in constructor\"\n                  );\n                return clazz[ModelKeys.ANCHOR as keyof typeof clazz];\n              },\n              (model: any) => {\n                const pk = findPrimaryKey(new (clazz as Constructor<any>)()).id;\n                return model[pk];\n              },\n              ormMeta\n            ),\n            JoinColumn()\n          );\n        },\n      })\n      .apply();\n\n    // @oneToMany(clazz) => @OneToMany(() => clazz)\n    const oneToManyKey = Repository.key(PersistenceKeys.ONE_TO_MANY);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(oneToManyKey)\n      .define({\n        decorator: function oneToMany(\n          clazz: Constructor<any> | (() => Constructor<any>),\n          cascade: CascadeMetadata,\n          populate: boolean\n        ) {\n          const metadata: RelationsMetadata = {\n            class: (clazz.name ? clazz.name : clazz) as string,\n            cascade: cascade,\n            populate: populate,\n          };\n          return apply(\n            prop(PersistenceKeys.RELATIONS),\n            list(clazz),\n            propMetadata(oneToManyKey, metadata),\n            function OneToManyWrapper(obj: any, prop: any): any {\n              const ormMeta: RelationOptions = {\n                cascade:\n                  cascade.update === Cascade.CASCADE ||\n                  cascade.delete === Cascade.CASCADE,\n                onDelete: cascade.delete ? \"CASCADE\" : \"DEFAULT\",\n                onUpdate: cascade.update ? \"CASCADE\" : \"DEFAULT\",\n                nullable: true,\n                eager: populate,\n              };\n              return OneToMany(\n                () => {\n                  if (!clazz.name) clazz = (clazz as any)();\n                  if (!clazz[ModelKeys.ANCHOR as keyof typeof clazz])\n                    throw new InternalError(\n                      \"Original Model not found in constructor\"\n                    );\n                  return clazz[ModelKeys.ANCHOR as keyof typeof clazz];\n                },\n                (model: any) => {\n                  if (!clazz.name) clazz = (clazz as any)();\n                  const m = new (clazz as Constructor<any>)();\n                  const crossRelationKey = Object.keys(m).find((k) => {\n                    const decs = Reflection.getPropertyDecorators(\n                      Repository.key(PersistenceKeys.MANY_TO_ONE),\n                      m,\n                      k,\n                      true\n                    );\n                    if (!decs || !decs.decorators || !decs.decorators.length)\n                      return false;\n                    const designType = Reflect.getMetadata(\n                      ModelKeys.TYPE,\n                      m,\n                      k\n                    );\n                    if (!designType)\n                      throw new InternalError(\n                        `No Type Definition found for ${k} in ${m.constructor.name}`\n                      );\n                    return designType.name === obj.constructor.name;\n                  });\n                  if (!crossRelationKey)\n                    throw new InternalError(\n                      `Cross relation not found. Did you use @manyToOne on the ${clazz.name}?`\n                    );\n                  return model[crossRelationKey];\n                },\n                ormMeta\n              )(obj, prop);\n            }\n          );\n        },\n      })\n      .apply();\n\n    // @manyToOne(clazz) => @ManyToOne(() => clazz)\n    const manyToOneKey = Repository.key(PersistenceKeys.MANY_TO_ONE);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(manyToOneKey)\n      .define({\n        decorator: function manyToOne(\n          clazz: Constructor<any> | (() => Constructor<any>),\n          cascade: CascadeMetadata,\n          populate: boolean\n        ) {\n          const metadata: RelationsMetadata = {\n            class: (clazz.name ? clazz.name : clazz) as string,\n            cascade: cascade,\n            populate: populate,\n          };\n          const ormMeta: RelationOptions = {\n            cascade:\n              cascade.update === Cascade.CASCADE ||\n              cascade.delete === Cascade.CASCADE,\n            onDelete: cascade.delete ? \"CASCADE\" : \"DEFAULT\",\n            onUpdate: cascade.update ? \"CASCADE\" : \"DEFAULT\",\n            nullable: true,\n            eager: populate,\n          };\n          return apply(\n            prop(PersistenceKeys.RELATIONS),\n            type([\n              (typeof clazz === \"function\" && !clazz.name\n                ? clazz\n                : clazz.name) as any,\n              String.name,\n              Number.name,\n              BigInt.name,\n            ]),\n            propMetadata(manyToOneKey, metadata),\n            function ManyToOneWrapper(obj: any, prop: any): any {\n              return ManyToOne(\n                () => {\n                  if (!clazz.name) clazz = (clazz as any)();\n                  if (!clazz[ModelKeys.ANCHOR as keyof typeof clazz])\n                    throw new InternalError(\n                      \"Original Model not found in constructor\"\n                    );\n                  return clazz[ModelKeys.ANCHOR as keyof typeof clazz];\n                },\n                (model: any) => {\n                  if (!clazz.name) clazz = (clazz as any)();\n                  const m = new (clazz as Constructor<any>)();\n                  const crossRelationKey = Object.keys(m).find((k) => {\n                    const decs = Reflection.getPropertyDecorators(\n                      Repository.key(PersistenceKeys.ONE_TO_MANY),\n                      m,\n                      k,\n                      true\n                    );\n                    if (!decs || !decs.decorators || !decs.decorators.length)\n                      return false;\n                    const listDec = Reflect.getMetadata(\n                      Validation.key(ValidationKeys.LIST),\n                      m,\n                      k\n                    );\n                    if (!listDec)\n                      throw new InternalError(\n                        `No Type Definition found for ${k} in ${m.constructor.name}`\n                      );\n                    const name = listDec.clazz[0]().name;\n                    return name === obj.constructor.name;\n                  });\n                  if (!crossRelationKey)\n                    throw new InternalError(\n                      `Cross relation not found. Did you use @manyToOne on the ${clazz.name}?`\n                    );\n                  return model[crossRelationKey];\n                }\n              )(obj, prop);\n            }\n          );\n        },\n      })\n      .apply();\n\n    // @manyToMany(clazz) => @ManyToMany(() => clazz)\n    const manyToManyKey = Repository.key(PersistenceKeys.MANY_TO_MANY);\n    Decoration.flavouredAs(TypeORMFlavour)\n      .for(manyToManyKey)\n      .define({\n        decorator: function manyToMany(\n          clazz: Constructor<any> | (() => Constructor<any>),\n          cascade: CascadeMetadata,\n          populate: boolean\n        ) {\n          const metadata: RelationsMetadata = {\n            class: clazz.name,\n            cascade: cascade,\n            populate: populate,\n          };\n          const ormMeta: RelationOptions = {\n            cascade:\n              cascade.update === Cascade.CASCADE ||\n              cascade.delete === Cascade.CASCADE,\n            onDelete: cascade.delete ? \"CASCADE\" : \"DEFAULT\",\n            onUpdate: cascade.update ? \"CASCADE\" : \"DEFAULT\",\n            nullable: true,\n            eager: populate,\n          };\n          return apply(\n            prop(PersistenceKeys.RELATIONS),\n            list(clazz),\n            propMetadata(manyToManyKey, metadata),\n            ManyToMany(\n              () => {\n                if (!clazz.name) clazz = (clazz as any)();\n                if (!clazz[ModelKeys.ANCHOR as keyof typeof clazz])\n                  throw new InternalError(\n                    \"Original Model not found in constructor\"\n                  );\n                return clazz[ModelKeys.ANCHOR as keyof typeof clazz];\n              },\n              (model: any) => {\n                if (!clazz.name) clazz = (clazz as any)();\n                const pk = findPrimaryKey(new (clazz as Constructor<any>)()).id;\n                return model[pk];\n              },\n              ormMeta\n            ),\n            JoinTable()\n          );\n        },\n      })\n      .apply();\n  }\n}\n"]}