@decaf-ts/transactional-decorators 0.1.2 → 0.1.3

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 (44) hide show
  1. package/LICENSE.md +21 -157
  2. package/dist/transactional-decorators.cjs +166 -67
  3. package/dist/transactional-decorators.esm.cjs +166 -67
  4. package/lib/Transaction.cjs +87 -39
  5. package/lib/Transaction.d.ts +86 -38
  6. package/lib/constants.cjs +14 -1
  7. package/lib/constants.d.ts +13 -0
  8. package/lib/decorators.cjs +35 -11
  9. package/lib/decorators.d.ts +34 -10
  10. package/lib/esm/Transaction.d.ts +86 -38
  11. package/lib/esm/Transaction.js +90 -42
  12. package/lib/esm/constants.d.ts +13 -0
  13. package/lib/esm/constants.js +14 -1
  14. package/lib/esm/decorators.d.ts +34 -10
  15. package/lib/esm/decorators.js +37 -13
  16. package/lib/esm/index.d.ts +7 -13
  17. package/lib/esm/index.js +14 -20
  18. package/lib/esm/interfaces/TransactionLock.d.ts +13 -11
  19. package/lib/esm/interfaces/TransactionLock.js +1 -1
  20. package/lib/esm/interfaces/index.d.ts +5 -0
  21. package/lib/esm/interfaces/index.js +7 -2
  22. package/lib/esm/locks/Lock.d.ts +13 -5
  23. package/lib/esm/locks/Lock.js +14 -6
  24. package/lib/esm/locks/SyncronousLock.d.ts +3 -4
  25. package/lib/esm/locks/SyncronousLock.js +14 -2
  26. package/lib/esm/locks/index.d.ts +5 -0
  27. package/lib/esm/locks/index.js +8 -3
  28. package/lib/esm/types.d.ts +13 -3
  29. package/lib/esm/types.js +1 -1
  30. package/lib/index.cjs +8 -14
  31. package/lib/index.d.ts +7 -13
  32. package/lib/interfaces/TransactionLock.cjs +1 -1
  33. package/lib/interfaces/TransactionLock.d.ts +13 -11
  34. package/lib/interfaces/index.cjs +6 -1
  35. package/lib/interfaces/index.d.ts +5 -0
  36. package/lib/locks/Lock.cjs +14 -6
  37. package/lib/locks/Lock.d.ts +13 -5
  38. package/lib/locks/SyncronousLock.cjs +13 -1
  39. package/lib/locks/SyncronousLock.d.ts +3 -4
  40. package/lib/locks/index.cjs +6 -1
  41. package/lib/locks/index.d.ts +5 -0
  42. package/lib/types.cjs +1 -1
  43. package/lib/types.d.ts +13 -3
  44. package/package.json +2 -2
@@ -2,10 +2,16 @@ import { Reflection, metadata } from '@decaf-ts/reflection';
2
2
  import { getAllPropertyDecoratorsRecursive, DBKeys, InternalError } from '@decaf-ts/db-decorators';
3
3
 
4
4
  /**
5
- * @summary Simple Promise based Lock class
6
- *
5
+ * @description Base lock implementation for concurrency control
6
+ * @summary Provides a basic lock mechanism for controlling access to shared resources, with support for queuing and executing functions when the lock is available
7
7
  * @class Lock
8
- * @category Transactions
8
+ * @example
9
+ * // Using the Lock class to execute a function with exclusive access
10
+ * const lock = new Lock();
11
+ * const result = await lock.execute(async () => {
12
+ * // This code will run with exclusive access
13
+ * return await performCriticalOperation();
14
+ * });
9
15
  */
10
16
  class Lock {
11
17
  constructor() {
@@ -13,8 +19,10 @@ class Lock {
13
19
  this.locked = false;
14
20
  }
15
21
  /**
16
- * @summary executes when lock is available
17
- * @param {Function} func
22
+ * @description Executes a function with exclusive lock access
23
+ * @summary Acquires the lock, executes the provided function, and releases the lock afterward, ensuring proper cleanup even if the function throws an error
24
+ * @param {Function} func - The function to execute when the lock is acquired
25
+ * @return {Promise<any>} A promise that resolves with the result of the executed function
18
26
  */
19
27
  async execute(func) {
20
28
  await this.acquire();
@@ -63,6 +71,18 @@ class Lock {
63
71
  }
64
72
  }
65
73
 
74
+ /**
75
+ * @summary Simple Synchronous Lock implementation
76
+ * @description for transaction management
77
+ * adapted from {@link https://www.talkinghightech.com/en/creating-a-js-lock-for-a-resource/}
78
+ *
79
+ * @param {number} [counter] the number of simultaneous transactions allowed. defaults to 1
80
+ * @param {Function} [onBegin] to be called at the start of the transaction
81
+ * @param {Function} [onEnd] to be called at the conclusion of the transaction
82
+ *
83
+ * @class SyncronousLock
84
+ * @implements TransactionLock
85
+ */
66
86
  class SyncronousLock {
67
87
  constructor(counter = 1, onBegin, onEnd) {
68
88
  this.currentTransaction = undefined;
@@ -178,6 +198,19 @@ class SyncronousLock {
178
198
  }
179
199
  }
180
200
 
201
+ /**
202
+ * @typedef {Object} TransactionalKeysType
203
+ * @property {string} REFLECT - Key used for reflection metadata related to transactional models
204
+ * @property {string} TRANSACTIONAL - Key used to identify transactional properties
205
+ * @memberOf module:transactions
206
+ */
207
+ /**
208
+ * @description Keys used for transactional operations
209
+ * @summary Constant object containing string keys used throughout the transactional system for reflection and identification
210
+ * @type {TransactionalKeysType}
211
+ * @const TransactionalKeys
212
+ * @memberOf module:transactions
213
+ */
181
214
  const TransactionalKeys = {
182
215
  REFLECT: "model.transactional.",
183
216
  TRANSACTIONAL: "transactional",
@@ -198,16 +231,48 @@ function getObjectName(obj) {
198
231
  }
199
232
 
200
233
  /**
201
- * @summary Transaction Class
202
- *
203
- * @param {string} source
204
- * @param {string} [method]
205
- * @param {function(): void} [action]
206
- * @param {any[]} [metadata]
207
- *
234
+ * @description Core transaction management class
235
+ * @summary Manages transaction lifecycle, including creation, execution, and cleanup. Provides mechanisms for binding transactions to objects and methods, ensuring proper transaction context propagation.
236
+ * @param {string} source - The source/origin of the transaction (typically a class name)
237
+ * @param {string} [method] - The method name associated with the transaction
238
+ * @param {function(): any} [action] - The function to execute within the transaction
239
+ * @param {any[]} [metadata] - Additional metadata to associate with the transaction
208
240
  * @class Transaction
241
+ * @example
242
+ * // Creating and submitting a transaction
243
+ * const transaction = new Transaction(
244
+ * 'UserService',
245
+ * 'createUser',
246
+ * async () => {
247
+ * // Transaction logic here
248
+ * await db.insert('users', { name: 'John' });
249
+ * }
250
+ * );
251
+ * Transaction.submit(transaction);
252
+ *
253
+ * // Using the transactional decorator
254
+ * class UserService {
255
+ * @transactional()
256
+ * async createUser(data) {
257
+ * // Method will be executed within a transaction
258
+ * return await db.insert('users', data);
259
+ * }
260
+ * }
261
+ * @mermaid
262
+ * sequenceDiagram
263
+ * participant C as Client Code
264
+ * participant T as Transaction
265
+ * participant L as TransactionLock
266
+ * participant O as Original Method
209
267
  *
210
- * @category Transactions
268
+ * C->>T: new Transaction(source, method, action)
269
+ * C->>T: Transaction.submit(transaction)
270
+ * T->>L: submit(transaction)
271
+ * L->>T: fire()
272
+ * T->>O: Execute action()
273
+ * O-->>T: Return result/error
274
+ * T->>L: release(error?)
275
+ * L-->>C: Return result/error
211
276
  */
212
277
  class Transaction {
213
278
  constructor(source, method, action, metadata) {
@@ -219,11 +284,12 @@ class Transaction {
219
284
  this.metadata = metadata;
220
285
  }
221
286
  /**
222
- * @summary Pushes a transaction to que queue and waits its resolution
223
- *
224
- * @param {any} issuer any class. will be used as this when calling the callbackMethod
225
- * @param {Function} callbackMethod callback function containing the transaction. will be called with the issuear as this
226
- * @param {any[]} args arguments to pass to the method. Last one must be the callback
287
+ * @description Queues a transaction for execution
288
+ * @summary Pushes a transaction to the queue and waits for its resolution. Creates a new transaction with the provided issuer and callback method, then submits it to the transaction lock.
289
+ * @param {any} issuer - Any class instance that will be used as 'this' when calling the callbackMethod
290
+ * @param {Function} callbackMethod - Callback function containing the transaction logic, will be called with the issuer as 'this'
291
+ * @param {any[]} args - Arguments to pass to the method. Last one must be the callback function
292
+ * @return {void}
227
293
  */
228
294
  static push(issuer, callbackMethod, ...args) {
229
295
  const callback = args.pop();
@@ -240,14 +306,18 @@ class Transaction {
240
306
  Transaction.getLock().submit(transaction);
241
307
  }
242
308
  /**
243
- * @summary Sets the lock to be used
244
- * @param lock
309
+ * @description Configures the transaction lock implementation
310
+ * @summary Sets the lock implementation to be used for transaction management, allowing customization of the transaction behavior
311
+ * @param {TransactionLock} lock - The lock implementation to use for managing transactions
312
+ * @return {void}
245
313
  */
246
314
  static setLock(lock) {
247
315
  this.lock = lock;
248
316
  }
249
317
  /**
250
- * @summary gets the lock
318
+ * @description Retrieves the current transaction lock
319
+ * @summary Gets the current transaction lock instance, creating a default SyncronousLock if none exists
320
+ * @return {TransactionLock} The current transaction lock implementation
251
321
  */
252
322
  static getLock() {
253
323
  if (!this.lock)
@@ -255,28 +325,36 @@ class Transaction {
255
325
  return this.lock;
256
326
  }
257
327
  /**
258
- * @summary submits a transaction
259
- * @param {Transaction} transaction
328
+ * @description Submits a transaction for processing
329
+ * @summary Submits a transaction to the current transaction lock for processing and execution
330
+ * @param {Transaction} transaction - The transaction to submit for processing
331
+ * @return {void}
260
332
  */
261
333
  static submit(transaction) {
262
334
  Transaction.getLock().submit(transaction);
263
335
  }
264
336
  /**
265
- * @summary releases the lock
266
- * @param {Err} err
337
+ * @description Releases the transaction lock
338
+ * @summary Releases the current transaction lock, optionally with an error, allowing the next transaction to proceed
339
+ * @param {Error} [err] - Optional error that occurred during transaction execution
340
+ * @return {Promise<void>} A promise that resolves when the lock has been released
267
341
  */
268
342
  static async release(err) {
269
343
  return Transaction.getLock().release(err);
270
344
  }
271
345
  /**
272
- * @summary retrieves the metadata for the transaction
346
+ * @description Retrieves transaction metadata
347
+ * @summary Returns a copy of the metadata associated with this transaction, ensuring the original metadata remains unmodified
348
+ * @return {any[] | undefined} A copy of the transaction metadata or undefined if no metadata exists
273
349
  */
274
350
  getMetadata() {
275
351
  return this.metadata ? [...this.metadata] : undefined;
276
352
  }
277
353
  /**
278
- * @summary Binds a new operation to the current transaction
279
- * @param {Transaction} nextTransaction
354
+ * @description Links a new transaction to the current one
355
+ * @summary Binds a new transaction operation to the current transaction, transferring logs and binding methods to maintain transaction context
356
+ * @param {Transaction} nextTransaction - The new transaction to bind to the current one
357
+ * @return {void}
280
358
  */
281
359
  bindTransaction(nextTransaction) {
282
360
  // all(`Binding the {0} to {1}`, nextTransaction, this);
@@ -286,12 +364,10 @@ class Transaction {
286
364
  this.action = nextTransaction.action;
287
365
  }
288
366
  /**
289
- * @summary Binds the Transactional Decorated Object to the transaction
290
- * @description by having all {@link transactional} decorated
291
- * methods always pass the current Transaction as an argument
292
- *
293
- * @param {any} obj
294
- * @return {any} the bound {@param obj}
367
+ * @description Binds an object to the current transaction context
368
+ * @summary Binds a transactional decorated object to the transaction by ensuring all transactional methods automatically receive the current transaction as their first argument
369
+ * @param {any} obj - The object to bind to the transaction
370
+ * @return {any} The bound object with transaction-aware method wrappers
295
371
  */
296
372
  bindToTransaction(obj) {
297
373
  const transactionalMethods = getAllPropertyDecoratorsRecursive(obj, undefined, TransactionalKeys.REFLECT);
@@ -325,7 +401,9 @@ class Transaction {
325
401
  return boundObj;
326
402
  }
327
403
  /**
328
- * @summary Fires the Transaction
404
+ * @description Executes the transaction action
405
+ * @summary Fires the transaction by executing its associated action function, throwing an error if no action is defined
406
+ * @return {any} The result of the transaction action
329
407
  */
330
408
  fire() {
331
409
  if (!this.action)
@@ -333,32 +411,58 @@ class Transaction {
333
411
  return this.action();
334
412
  }
335
413
  /**
336
- * @summary toString override
337
- * @param {boolean} [withId] defaults to true
338
- * @param {boolean} [withLog] defaults to true
414
+ * @description Provides a string representation of the transaction
415
+ * @summary Overrides the default toString method to provide a formatted string representation of the transaction, optionally including the transaction ID and log
416
+ * @param {boolean} [withId=true] - Whether to include the transaction ID in the output
417
+ * @param {boolean} [withLog=false] - Whether to include the transaction log in the output
418
+ * @return {string} A string representation of the transaction
339
419
  */
340
420
  toString(withId = true, withLog = false) {
341
421
  return `${withId ? `[${this.id}]` : ""}[Transaction][${this.source}.${this.method}${withLog ? `]\nTransaction Log:\n${this.log.join("\n")}` : "]"}`;
342
422
  }
343
423
  /**
344
- * @summary gets the transactions reflections key
345
- * @function getRepoKey
346
- * @param {string} key
347
- * @memberOf module:db-decorators.Transactions
348
- * */
424
+ * @description Generates a reflection metadata key for transactions
425
+ * @summary Creates a prefixed reflection key for transaction-related metadata, ensuring proper namespacing
426
+ * @param {string} key - The base key to prefix with the transaction reflection namespace
427
+ * @return {string} The complete reflection key for transaction metadata
428
+ * @function key
429
+ */
349
430
  static key(key) {
350
431
  return TransactionalKeys.REFLECT + key;
351
432
  }
352
433
  }
353
434
 
354
435
  /**
355
- * @summary Sets a class Async method as transactional
436
+ * @description Method decorator that enables transactional behavior
437
+ * @summary Sets a class async method as transactional, wrapping it in a transaction context that can be managed by the transaction system. This decorator handles transaction creation, binding, and error handling.
438
+ * @param {any[]} [data] - Optional metadata available to the {@link TransactionLock} implementation
439
+ * @return {Function} A decorator function that wraps the original method with transactional behavior
440
+ * @function transactional
441
+ * @category Method Decorators
442
+ * @mermaid
443
+ * sequenceDiagram
444
+ * participant C as Client Code
445
+ * participant D as Decorator
446
+ * participant T as Transaction
447
+ * participant O as Original Method
356
448
  *
357
- * @param {any[]} [data] option metadata available to the {@link TransactionLock}
449
+ * C->>D: Call decorated method
450
+ * D->>D: Check if transaction exists in args
358
451
  *
359
- * @function transactional
452
+ * alt Transaction exists in args
453
+ * D->>T: Create updated transaction
454
+ * T->>T: Bind to original transaction
455
+ * T->>T: Fire transaction
456
+ * else No transaction
457
+ * D->>T: Create new transaction
458
+ * T->>T: Submit transaction
459
+ * end
360
460
  *
361
- * @memberOf module:db-decorators.Decorators.transactions
461
+ * T->>O: Execute original method
462
+ * O-->>T: Return result/error
463
+ * T->>T: Release transaction
464
+ * T-->>C: Return result/error
465
+ * @category Decorators
362
466
  */
363
467
  function transactional(...data) {
364
468
  return function (target, propertyKey, descriptor) {
@@ -497,12 +601,13 @@ function transactional(...data) {
497
601
  // };
498
602
  // }
499
603
  /**
500
- * @summary Util function to wrap super calls with the transaction when the super's method is also transactional
501
- *
502
- * @param {Function} method the super method (must be bound to the proper this), eg: super.create.bind(this)
503
- * @param {any[]} args the arguments to call the method with
504
- *
505
- * @memberOf module:db-decorators.Transaction
604
+ * @description Utility for handling super calls in transactional methods
605
+ * @summary Wraps super method calls with the current transaction context when the super's method is also transactional, ensuring transaction continuity through the inheritance chain
606
+ * @param {Function} method - The super method (must be bound to the proper this), e.g., super.create.bind(this)
607
+ * @param {any[]} args - The arguments to call the method with
608
+ * @return {any} The result of the super method call
609
+ * @function transactionalSuperCall
610
+ * @memberOf module:transactions
506
611
  */
507
612
  function transactionalSuperCall(method, ...args) {
508
613
  const lock = Transaction.getLock();
@@ -511,23 +616,17 @@ function transactionalSuperCall(method, ...args) {
511
616
  }
512
617
 
513
618
  /**
514
- * @summary Module summary
515
- * @description Module description
516
- * @module ts-workspace
517
- */
518
- /**
519
- * @summary Namespace summary
520
- * @description Namespace description
521
- * @namespace Namespace
522
- * @memberOf module:ts-workspace
619
+ * @description Transactional decorators for TypeScript
620
+ * @summary A comprehensive module providing transaction management capabilities for TypeScript applications. This module exposes decorators, locks, and utilities for implementing transactional behavior in your code, allowing for atomic operations, concurrency control, and error handling.
621
+ * @module transactions
523
622
  */
524
623
  /**
525
- * @summary stores the current package version
526
- * @description this is how you should document a constant
624
+ * @description Package version identifier
625
+ * @summary Stores the current package version string, used for version tracking and compatibility checks
527
626
  * @const VERSION
528
- * @memberOf module:ts-workspace
627
+ * @memberOf module:transactions
529
628
  */
530
- const VERSION = "0.1.2";
629
+ const VERSION = "0.1.3";
531
630
 
532
631
  export { Lock, SyncronousLock, Transaction, TransactionalKeys, VERSION, transactional, transactionalSuperCall };
533
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"transactional-decorators.esm.cjs","sources":["../src/locks/Lock.ts","../src/locks/SyncronousLock.ts","../src/constants.ts","../src/utils.ts","../src/Transaction.ts","../src/decorators.ts","../src/index.ts"],"sourcesContent":["import { LockCallable } from \"../types\";\n\n/**\n * @summary Simple Promise based Lock class\n *\n * @class Lock\n * @category Transactions\n */\nexport class Lock {\n  private queue: LockCallable[] = [];\n  private locked = false;\n\n  /**\n   * @summary executes when lock is available\n   * @param {Function} func\n   */\n  async execute(func: () => any) {\n    await this.acquire();\n    let result: any;\n    try {\n      result = await Promise.resolve(func());\n    } catch (e: any) {\n      this.release();\n      throw e;\n    }\n    this.release();\n    return result;\n  }\n\n  /**\n   * @summary waits to acquire the lock\n   * @param {string} [issuer]\n   */\n  async acquire(): Promise<void> {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    if (self.locked) {\n      return new Promise<void>((resolve) => self.queue.push(resolve));\n    } else {\n      self.locked = true;\n      return Promise.resolve();\n    }\n  }\n\n  /**\n   * @summary releases the lock\n   */\n  release() {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    const next: LockCallable | undefined = self.queue.shift();\n    if (next) {\n      if (\n        typeof (globalThis as unknown as { window: any }).window === \"undefined\"\n      )\n        globalThis.process.nextTick(next); // if you are on node\n      else setTimeout(next, 0); // if you are in the browser\n    } else {\n      self.locked = false;\n    }\n  }\n}\n","/**\n * @summary Simple Synchronous Lock implementation\n * @description for transaction management\n * adapted from {@link https://www.talkinghightech.com/en/creating-a-js-lock-for-a-resource/}\n *\n * @param {number} [counter] the number of simultaneous transactions allowed. defaults to 1\n * @param {Function} [onBegin] to be called at the start of the transaction\n * @param {Function} [onEnd] to be called at the conclusion of the transaction\n *\n * @class SyncronousLock\n * @implements TransactionLock\n *\n * @category Transactions\n */ import { Transaction } from \"../Transaction\";\nimport { TransactionLock } from \"../interfaces/TransactionLock\";\nimport { Lock } from \"./Lock\";\n\nexport class SyncronousLock implements TransactionLock {\n  private counter: number;\n  private pendingTransactions: Transaction[];\n  currentTransaction?: Transaction = undefined;\n  private readonly onBegin?: () => Promise<void>;\n  private readonly onEnd?: (err?: Error) => Promise<void>;\n\n  private readonly lock = new Lock();\n\n  constructor(\n    counter: number = 1,\n    onBegin?: () => Promise<void>,\n    onEnd?: (err?: Error) => Promise<void>,\n  ) {\n    this.counter = counter;\n    this.pendingTransactions = [];\n    this.onBegin = onBegin;\n    this.onEnd = onEnd;\n  }\n\n  /**\n   * @summary Submits a transaction to be processed\n   * @param {Transaction} transaction\n   */\n  submit(transaction: Transaction): void {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    self.lock.acquire().then(() => {\n      if (\n        self.currentTransaction &&\n        self.currentTransaction.id === transaction.id\n      ) {\n        self.lock.release();\n        return transaction.fire();\n      }\n\n      if (self.counter > 0) {\n        self.counter--;\n        self.lock.release();\n        return self.fireTransaction(transaction);\n      } else {\n        self.pendingTransactions.push(transaction);\n        self.lock.release();\n      }\n    });\n  }\n\n  /**\n   * @summary Executes a transaction\n   *\n   * @param {Transaction} transaction\n   * @private\n   */\n  private fireTransaction(transaction: Transaction) {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    self.lock.acquire().then(() => {\n      self.currentTransaction = transaction;\n      self.lock.release();\n      if (self.onBegin)\n        self.onBegin().then(() => {\n          // all.call(\n          //   self,\n          //   `Firing transaction {0}. {1} remaining...`,\n          //   transaction.id,\n          //   this.pendingTransactions.length,\n          // );\n          transaction.fire();\n        });\n      else {\n        // all.call(\n        //   self,\n        //   `Firing transaction {0}. {1} remaining...`,\n        //   transaction.id,\n        //   this.pendingTransactions.length,\n        // );\n        transaction.fire();\n      }\n    });\n  }\n  /**\n   * @summary Releases The lock after the conclusion of a transaction\n   */\n  async release(err?: Error): Promise<void> {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    return new Promise<void>((resolve) => {\n      self.lock.acquire().then(() => {\n        if (!self.currentTransaction)\n          console.warn(\n            \"Trying to release an unexisting transaction. should never happen...\",\n          );\n        // debug.call(\n        //   self,\n        //   \"Releasing transaction: {0}\",\n        //   self.currentTransaction?.toString(true, true),\n        // );\n        self.currentTransaction = undefined;\n        self.lock.release();\n\n        const afterConclusionCB = () => {\n          self.lock.acquire().then(() => {\n            if (self.pendingTransactions.length > 0) {\n              const transaction =\n                self.pendingTransactions.shift() as Transaction;\n\n              const cb = () => self.fireTransaction(transaction);\n              //\n              // all(\n              //   `Releasing Transaction Lock on transaction {0}`,\n              //   transaction.id,\n              // );\n\n              if (\n                typeof (globalThis as unknown as { window: any }).window ===\n                \"undefined\"\n              )\n                globalThis.process.nextTick(cb); // if you are on node\n              else setTimeout(cb, 0); // if you are in the browser\n            } else {\n              self.counter++;\n            }\n            self.lock.release();\n            resolve();\n          });\n        };\n\n        if (self.onEnd) self.onEnd(err).then(() => afterConclusionCB());\n        else afterConclusionCB();\n      });\n    });\n  }\n}\n","export const TransactionalKeys: Record<string, string> = {\n  REFLECT: \"model.transactional.\",\n  TRANSACTIONAL: \"transactional\",\n};\n","export function getObjectName(obj: any): string | undefined {\n  if (!obj) return;\n  if (typeof obj === \"string\") return obj;\n  if (\n    obj.constructor &&\n    obj.constructor.name &&\n    [\"Function\", \"Object\"].indexOf(obj.constructor.name) === -1\n  )\n    return obj.constructor.name;\n  if (typeof obj === \"function\" && obj.name) return obj.name;\n  return obj.toString();\n}\n","import { TransactionLock } from \"./interfaces/TransactionLock\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { Callback } from \"./types\";\nimport { SyncronousLock } from \"./locks/SyncronousLock\";\nimport {\n  DBKeys,\n  getAllPropertyDecoratorsRecursive,\n} from \"@decaf-ts/db-decorators\";\nimport { getObjectName } from \"./utils\";\nimport { TransactionalKeys } from \"./constants\";\n\n/**\n * @summary Transaction Class\n *\n * @param {string} source\n * @param {string} [method]\n * @param {function(): void} [action]\n * @param {any[]} [metadata]\n *\n * @class Transaction\n *\n * @category Transactions\n */\nexport class Transaction {\n  readonly id: number;\n  protected action?: () => any;\n  readonly method?: string;\n  readonly source?: string;\n  readonly log: string[];\n  private readonly metadata?: any[];\n\n  private static lock: TransactionLock;\n\n  constructor(\n    source: string,\n    method?: string,\n    action?: () => any,\n    metadata?: any[]\n  ) {\n    this.id = Date.now();\n    this.action = action;\n    this.method = method;\n    this.log = [[this.id, source, method].join(\" | \")];\n    this.source = source;\n    this.metadata = metadata;\n  }\n\n  /**\n   * @summary Pushes a transaction to que queue and waits its resolution\n   *\n   * @param {any} issuer any class. will be used as this when calling the callbackMethod\n   * @param {Function} callbackMethod callback function containing the transaction. will be called with the issuear as this\n   * @param {any[]} args arguments to pass to the method. Last one must be the callback\n   */\n  static push(\n    issuer: any,\n    callbackMethod: (...argzz: (any | Callback)[]) => void,\n    ...args: (any | Callback)[]\n  ) {\n    const callback: Callback = args.pop();\n    if (!callback || typeof callback !== \"function\")\n      throw new Error(\"Missing callback\");\n    const cb = (err?: Error, ...args: any[]) => {\n      Transaction.getLock()\n        .release(err)\n        .then(() => callback(err, ...args));\n    };\n    const transaction: Transaction = new Transaction(\n      issuer.constructor.name,\n      callbackMethod.name ? getObjectName(callbackMethod) : \"Anonymous\",\n      () => {\n        return callbackMethod.call(\n          transaction.bindToTransaction(issuer),\n          ...args,\n          cb\n        );\n      }\n    );\n    Transaction.getLock().submit(transaction);\n  }\n\n  /**\n   * @summary Sets the lock to be used\n   * @param lock\n   */\n  static setLock(lock: TransactionLock) {\n    this.lock = lock;\n  }\n\n  /**\n   * @summary gets the lock\n   */\n  static getLock(): TransactionLock {\n    if (!this.lock) this.lock = new SyncronousLock();\n    return this.lock;\n  }\n\n  /**\n   * @summary submits a transaction\n   * @param {Transaction} transaction\n   */\n  static submit(transaction: Transaction) {\n    Transaction.getLock().submit(transaction);\n  }\n\n  /**\n   * @summary releases the lock\n   * @param {Err} err\n   */\n  static async release(err?: Error) {\n    return Transaction.getLock().release(err);\n  }\n\n  /**\n   * @summary retrieves the metadata for the transaction\n   */\n  getMetadata() {\n    return this.metadata ? [...this.metadata] : undefined;\n  }\n\n  /**\n   * @summary Binds a new operation to the current transaction\n   * @param {Transaction} nextTransaction\n   */\n  bindTransaction(nextTransaction: Transaction) {\n    // all(`Binding the {0} to {1}`, nextTransaction, this);\n    this.log.push(...nextTransaction.log);\n    nextTransaction.bindTransaction = this.bindToTransaction.bind(this);\n    nextTransaction.bindToTransaction = this.bindToTransaction.bind(this);\n    this.action = nextTransaction.action;\n  }\n\n  /**\n   * @summary Binds the Transactional Decorated Object to the transaction\n   * @description by having all {@link transactional} decorated\n   * methods always pass the current Transaction as an argument\n   *\n   * @param {any} obj\n   * @return {any} the bound {@param obj}\n   */\n  bindToTransaction(obj: any): any {\n    const transactionalMethods = getAllPropertyDecoratorsRecursive(\n      obj,\n      undefined,\n      TransactionalKeys.REFLECT\n    );\n    if (!transactionalMethods) return obj;\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n\n    const boundObj = Reflection.getAllProperties(obj).reduce(\n      (accum: any, k: string) => {\n        if (\n          Object.keys(transactionalMethods).indexOf(k) !== -1 &&\n          transactionalMethods[k].find(\n            (o) => o.key === TransactionalKeys.TRANSACTIONAL\n          )\n        )\n          accum[k] = (...args: any[]) =>\n            obj[k].call(obj.__originalObj || obj, self, ...args);\n        else if (k === \"clazz\" || k === \"constructor\") accum[k] = obj[k];\n        else if (typeof obj[k] === \"function\")\n          accum[k] = obj[k].bind(obj.__originalObj || obj);\n        else if (typeof obj[k] === \"object\" && obj[k].constructor) {\n          const decs = Reflection.getClassDecorators(\n            TransactionalKeys.REFLECT,\n            obj[k]\n          );\n          if (decs.find((e: any) => e.key === TransactionalKeys.TRANSACTIONAL))\n            accum[k] = self.bindToTransaction(obj[k]);\n          else accum[k] = obj[k];\n        } else accum[k] = obj[k];\n\n        return accum;\n      },\n      {}\n    );\n\n    boundObj[DBKeys.ORIGINAL] = obj[DBKeys.ORIGINAL] || obj;\n    boundObj.toString = () =>\n      getObjectName(boundObj[DBKeys.ORIGINAL]) +\n      \" proxy for transaction \" +\n      this.id;\n\n    return boundObj;\n  }\n\n  /**\n   * @summary Fires the Transaction\n   */\n  fire() {\n    if (!this.action) throw new Error(`Missing the method`);\n    return this.action();\n  }\n\n  /**\n   * @summary toString override\n   * @param {boolean} [withId] defaults to true\n   * @param {boolean} [withLog] defaults to true\n   */\n  toString(withId = true, withLog = false) {\n    return `${withId ? `[${this.id}]` : \"\"}[Transaction][${this.source}.${this.method}${\n      withLog ? `]\\nTransaction Log:\\n${this.log.join(\"\\n\")}` : \"]\"\n    }`;\n  }\n\n  /**\n   * @summary gets the transactions reflections key\n   * @function getRepoKey\n   * @param {string} key\n   * @memberOf module:db-decorators.Transactions\n   * */\n  static key(key: string) {\n    return TransactionalKeys.REFLECT + key;\n  }\n}\n","import { TransactionalKeys } from \"./constants\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Transaction } from \"./Transaction\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @summary Sets a class Async method as transactional\n *\n * @param {any[]}  [data] option metadata available to the {@link TransactionLock}\n *\n * @function transactional\n *\n * @memberOf module:db-decorators.Decorators.transactions\n */\nexport function transactional(...data: any[]) {\n  return function (\n    target: any,\n    propertyKey?: any,\n    descriptor?: PropertyDescriptor\n  ) {\n    if (!descriptor)\n      throw new InternalError(\"Missing descriptor. Should be impossible\");\n    metadata(Transaction.key(TransactionalKeys.TRANSACTIONAL), data)(\n      target,\n      propertyKey\n    );\n\n    const originalMethod = descriptor.value;\n\n    const methodWrapper = function (this: any, ...args: any[]): Promise<any> {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const self = this;\n      return new Promise<any>((resolve, reject) => {\n        const cb = (err?: Error, result?: any) => {\n          Transaction.release(err).then(() => {\n            if (err) return reject(err);\n            resolve(result);\n          });\n        };\n\n        let transaction = args.shift();\n        if (transaction instanceof Transaction) {\n          const updatedTransaction: Transaction = new Transaction(\n            this.constructor.name,\n            propertyKey,\n            async () => {\n              originalMethod\n                .call(updatedTransaction.bindToTransaction(self), ...args)\n                .then(resolve)\n                .catch(reject);\n            },\n            data.length ? data : undefined\n          );\n\n          transaction.bindTransaction(updatedTransaction);\n          transaction.fire();\n        } else {\n          args.unshift(transaction);\n          transaction = new Transaction(\n            this.constructor.name,\n            propertyKey,\n            () => {\n              originalMethod\n                .call(transaction.bindToTransaction(self), ...args)\n                .then((result: any) => cb(undefined, result))\n                .catch(cb);\n            },\n            data.length ? data : undefined\n          );\n          Transaction.submit(transaction);\n        }\n      });\n    };\n\n    Object.defineProperty(methodWrapper, \"name\", {\n      value: propertyKey,\n    });\n    descriptor.value = methodWrapper;\n  };\n}\n//\n// /**\n//  * @summary Sets a class Async method as transactional\n//  *\n//  * @param {any[]}  [metadata] option metadata available to the {@link TransactionLock}\n//  *\n//  * @function transactionalAsync\n//  *\n//  * @memberOf module:db-decorators.Decorators.transactions\n//  */\n// export function transactionalAsync(...metadata: any[]) {\n//   return function (\n//     target: any,\n//     propertyKey: string,\n//     descriptor: PropertyDescriptor,\n//   ) {\n//     metadasta(getTransactionalKey(TransactionalKeys.TRANSACTIONAL))\n//     Reflect.defineMetadata(\n//       ,\n//       {\n//         type: \"async\",\n//         metadata: metadata.length ? metadata : undefined,\n//       } as TransactionalMetadata,\n//       target,\n//       propertyKey,\n//     );\n//\n//     const originalMethod = descriptor.value;\n//\n//     const methodWrapper = function (this: any, ...args: any[]) {\n//       const callback: Callback = args.pop();\n//       if (!callback || typeof callback !== \"function\")\n//         throw new CriticalError(`Missing Callback`);\n//\n//       const cb = (err?: Err, ...args: any[]) => {\n//         Transaction.release(err).then((_) => callback(err, ...args));\n//       };\n//\n//       const self = this;\n//\n//       let transaction = args.shift();\n//       if (transaction instanceof Transaction) {\n//         const updatedTransaction: Transaction = new Transaction(\n//           this.constructor.name,\n//           propertyKey,\n//           () => {\n//             try {\n//               return originalMethod.call(\n//                 updatedTransaction.bindToTransaction(self),\n//                 ...args,\n//                 callback,\n//               );\n//             } catch (e: any) {\n//               return callback(e);\n//             }\n//           },\n//           metadata.length ? metadata : undefined,\n//         );\n//\n//         transaction.bindTransaction(updatedTransaction);\n//         transaction.fire();\n//       } else {\n//         args.unshift(transaction);\n//         transaction = undefined;\n//         transaction = new Transaction(\n//           this.constructor.name,\n//           propertyKey,\n//           () => {\n//             try {\n//               return originalMethod.call(\n//                 transaction.bindToTransaction(self),\n//                 ...args,\n//                 cb,\n//               );\n//             } catch (e: any) {\n//               return cb(e);\n//             }\n//           },\n//           metadata.length ? metadata : undefined,\n//         );\n//         Transaction.submit(transaction);\n//       }\n//     };\n//\n//     Object.defineProperty(methodWrapper, \"name\", {\n//       value: propertyKey,\n//     });\n//     descriptor.value = methodWrapper;\n//   };\n// }\n\n/**\n * @summary Util function to wrap super calls with the transaction when the super's method is also transactional\n *\n * @param {Function} method the super method (must be bound to the proper this), eg: super.create.bind(this)\n * @param {any[]} args the arguments to call the method with\n *\n * @memberOf module:db-decorators.Transaction\n */\nexport function transactionalSuperCall(method: any, ...args: any) {\n  const lock = Transaction.getLock();\n  const currentTransaction = lock.currentTransaction;\n  return method(currentTransaction, ...args);\n}\n","export * from \"./interfaces\";\nexport * from \"./locks\";\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./Transaction\";\nexport * from \"./types\";\n\n/**\n * @summary Module summary\n * @description Module description\n * @module ts-workspace\n */\n\n/**\n * @summary Namespace summary\n * @description Namespace description\n * @namespace Namespace\n * @memberOf module:ts-workspace\n */\n\n/**\n * @summary stores the current package version\n * @description this is how you should document a constant\n * @const VERSION\n * @memberOf module:ts-workspace\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;AAOG;SACa,sBAAsB,CAAC,MAAW,EAAE,GAAG,IAAS,EAAA;AAC9D,IAAA,MAAM,IAAI,GAAG,WAAW,CAAC,OAAO,EAAE;AAClC,IAAA,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB;AAClD,IAAA,OAAO,MAAM,CAAC,kBAAkB,EAAE,GAAG,IAAI,CAAC;AAC5C;;AChLA;;;;AAIG;AAEH;;;;;AAKG;AAEH;;;;;AAKG;AACI,MAAM,OAAO,GAAG;;;;"}
632
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"transactional-decorators.esm.cjs","sources":["../src/locks/Lock.ts","../src/locks/SyncronousLock.ts","../src/constants.ts","../src/utils.ts","../src/Transaction.ts","../src/decorators.ts","../src/index.ts"],"sourcesContent":["import { LockCallable } from \"../types\";\n\n/**\n * @description Base lock implementation for concurrency control\n * @summary Provides a basic lock mechanism for controlling access to shared resources, with support for queuing and executing functions when the lock is available\n * @class Lock\n * @example\n * // Using the Lock class to execute a function with exclusive access\n * const lock = new Lock();\n * const result = await lock.execute(async () => {\n *   // This code will run with exclusive access\n *   return await performCriticalOperation();\n * });\n */\nexport class Lock {\n  private queue: LockCallable[] = [];\n  private locked = false;\n\n  /**\n   * @description Executes a function with exclusive lock access\n   * @summary Acquires the lock, executes the provided function, and releases the lock afterward, ensuring proper cleanup even if the function throws an error\n   * @param {Function} func - The function to execute when the lock is acquired\n   * @return {Promise<any>} A promise that resolves with the result of the executed function\n   */\n  async execute(func: () => any) {\n    await this.acquire();\n    let result: any;\n    try {\n      result = await Promise.resolve(func());\n    } catch (e: any) {\n      this.release();\n      throw e;\n    }\n    this.release();\n    return result;\n  }\n\n  /**\n   * @summary waits to acquire the lock\n   * @param {string} [issuer]\n   */\n  async acquire(): Promise<void> {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    if (self.locked) {\n      return new Promise<void>((resolve) => self.queue.push(resolve));\n    } else {\n      self.locked = true;\n      return Promise.resolve();\n    }\n  }\n\n  /**\n   * @summary releases the lock\n   */\n  release() {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    const next: LockCallable | undefined = self.queue.shift();\n    if (next) {\n      if (\n        typeof (globalThis as unknown as { window: any }).window === \"undefined\"\n      )\n        globalThis.process.nextTick(next); // if you are on node\n      else setTimeout(next, 0); // if you are in the browser\n    } else {\n      self.locked = false;\n    }\n  }\n}\n","import { Transaction } from \"../Transaction\";\nimport { TransactionLock } from \"../interfaces/TransactionLock\";\nimport { Lock } from \"./Lock\";\n\n/**\n * @summary Simple Synchronous Lock implementation\n * @description for transaction management\n * adapted from {@link https://www.talkinghightech.com/en/creating-a-js-lock-for-a-resource/}\n *\n * @param {number} [counter] the number of simultaneous transactions allowed. defaults to 1\n * @param {Function} [onBegin] to be called at the start of the transaction\n * @param {Function} [onEnd] to be called at the conclusion of the transaction\n *\n * @class SyncronousLock\n * @implements TransactionLock\n */\nexport class SyncronousLock implements TransactionLock {\n  private counter: number;\n  private pendingTransactions: Transaction[];\n  currentTransaction?: Transaction = undefined;\n  private readonly onBegin?: () => Promise<void>;\n  private readonly onEnd?: (err?: Error) => Promise<void>;\n\n  private readonly lock = new Lock();\n\n  constructor(\n    counter: number = 1,\n    onBegin?: () => Promise<void>,\n    onEnd?: (err?: Error) => Promise<void>\n  ) {\n    this.counter = counter;\n    this.pendingTransactions = [];\n    this.onBegin = onBegin;\n    this.onEnd = onEnd;\n  }\n\n  /**\n   * @summary Submits a transaction to be processed\n   * @param {Transaction} transaction\n   */\n  submit(transaction: Transaction): void {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    self.lock.acquire().then(() => {\n      if (\n        self.currentTransaction &&\n        self.currentTransaction.id === transaction.id\n      ) {\n        self.lock.release();\n        return transaction.fire();\n      }\n\n      if (self.counter > 0) {\n        self.counter--;\n        self.lock.release();\n        return self.fireTransaction(transaction);\n      } else {\n        self.pendingTransactions.push(transaction);\n        self.lock.release();\n      }\n    });\n  }\n\n  /**\n   * @summary Executes a transaction\n   *\n   * @param {Transaction} transaction\n   * @private\n   */\n  private fireTransaction(transaction: Transaction) {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    self.lock.acquire().then(() => {\n      self.currentTransaction = transaction;\n      self.lock.release();\n      if (self.onBegin)\n        self.onBegin().then(() => {\n          // all.call(\n          //   self,\n          //   `Firing transaction {0}. {1} remaining...`,\n          //   transaction.id,\n          //   this.pendingTransactions.length,\n          // );\n          transaction.fire();\n        });\n      else {\n        // all.call(\n        //   self,\n        //   `Firing transaction {0}. {1} remaining...`,\n        //   transaction.id,\n        //   this.pendingTransactions.length,\n        // );\n        transaction.fire();\n      }\n    });\n  }\n  /**\n   * @summary Releases The lock after the conclusion of a transaction\n   */\n  async release(err?: Error): Promise<void> {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    return new Promise<void>((resolve) => {\n      self.lock.acquire().then(() => {\n        if (!self.currentTransaction)\n          console.warn(\n            \"Trying to release an unexisting transaction. should never happen...\"\n          );\n        // debug.call(\n        //   self,\n        //   \"Releasing transaction: {0}\",\n        //   self.currentTransaction?.toString(true, true),\n        // );\n        self.currentTransaction = undefined;\n        self.lock.release();\n\n        const afterConclusionCB = () => {\n          self.lock.acquire().then(() => {\n            if (self.pendingTransactions.length > 0) {\n              const transaction =\n                self.pendingTransactions.shift() as Transaction;\n\n              const cb = () => self.fireTransaction(transaction);\n              //\n              // all(\n              //   `Releasing Transaction Lock on transaction {0}`,\n              //   transaction.id,\n              // );\n\n              if (\n                typeof (globalThis as unknown as { window: any }).window ===\n                \"undefined\"\n              )\n                globalThis.process.nextTick(cb); // if you are on node\n              else setTimeout(cb, 0); // if you are in the browser\n            } else {\n              self.counter++;\n            }\n            self.lock.release();\n            resolve();\n          });\n        };\n\n        if (self.onEnd) self.onEnd(err).then(() => afterConclusionCB());\n        else afterConclusionCB();\n      });\n    });\n  }\n}\n","/**\n * @typedef {Object} TransactionalKeysType\n * @property {string} REFLECT - Key used for reflection metadata related to transactional models\n * @property {string} TRANSACTIONAL - Key used to identify transactional properties\n * @memberOf module:transactions\n */\n\n/**\n * @description Keys used for transactional operations\n * @summary Constant object containing string keys used throughout the transactional system for reflection and identification\n * @type {TransactionalKeysType}\n * @const TransactionalKeys\n * @memberOf module:transactions\n */\nexport const TransactionalKeys: Record<string, string> = {\n  REFLECT: \"model.transactional.\",\n  TRANSACTIONAL: \"transactional\",\n};\n","export function getObjectName(obj: any): string | undefined {\n  if (!obj) return;\n  if (typeof obj === \"string\") return obj;\n  if (\n    obj.constructor &&\n    obj.constructor.name &&\n    [\"Function\", \"Object\"].indexOf(obj.constructor.name) === -1\n  )\n    return obj.constructor.name;\n  if (typeof obj === \"function\" && obj.name) return obj.name;\n  return obj.toString();\n}\n","import { TransactionLock } from \"./interfaces/TransactionLock\";\nimport { Reflection } from \"@decaf-ts/reflection\";\nimport { Callback } from \"./types\";\nimport { SyncronousLock } from \"./locks/SyncronousLock\";\nimport {\n  DBKeys,\n  getAllPropertyDecoratorsRecursive,\n} from \"@decaf-ts/db-decorators\";\nimport { getObjectName } from \"./utils\";\nimport { TransactionalKeys } from \"./constants\";\n\n/**\n * @description Core transaction management class\n * @summary Manages transaction lifecycle, including creation, execution, and cleanup. Provides mechanisms for binding transactions to objects and methods, ensuring proper transaction context propagation.\n * @param {string} source - The source/origin of the transaction (typically a class name)\n * @param {string} [method] - The method name associated with the transaction\n * @param {function(): any} [action] - The function to execute within the transaction\n * @param {any[]} [metadata] - Additional metadata to associate with the transaction\n * @class Transaction\n * @example\n * // Creating and submitting a transaction\n * const transaction = new Transaction(\n *   'UserService',\n *   'createUser',\n *   async () => {\n *     // Transaction logic here\n *     await db.insert('users', { name: 'John' });\n *   }\n * );\n * Transaction.submit(transaction);\n * \n * // Using the transactional decorator\n * class UserService {\n *   @transactional()\n *   async createUser(data) {\n *     // Method will be executed within a transaction\n *     return await db.insert('users', data);\n *   }\n * }\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant T as Transaction\n *   participant L as TransactionLock\n *   participant O as Original Method\n *   \n *   C->>T: new Transaction(source, method, action)\n *   C->>T: Transaction.submit(transaction)\n *   T->>L: submit(transaction)\n *   L->>T: fire()\n *   T->>O: Execute action()\n *   O-->>T: Return result/error\n *   T->>L: release(error?)\n *   L-->>C: Return result/error\n */\nexport class Transaction {\n  readonly id: number;\n  protected action?: () => any;\n  readonly method?: string;\n  readonly source?: string;\n  readonly log: string[];\n  private readonly metadata?: any[];\n\n  private static lock: TransactionLock;\n\n  constructor(\n    source: string,\n    method?: string,\n    action?: () => any,\n    metadata?: any[]\n  ) {\n    this.id = Date.now();\n    this.action = action;\n    this.method = method;\n    this.log = [[this.id, source, method].join(\" | \")];\n    this.source = source;\n    this.metadata = metadata;\n  }\n\n  /**\n   * @description Queues a transaction for execution\n   * @summary Pushes a transaction to the queue and waits for its resolution. Creates a new transaction with the provided issuer and callback method, then submits it to the transaction lock.\n   * @param {any} issuer - Any class instance that will be used as 'this' when calling the callbackMethod\n   * @param {Function} callbackMethod - Callback function containing the transaction logic, will be called with the issuer as 'this'\n   * @param {any[]} args - Arguments to pass to the method. Last one must be the callback function\n   * @return {void}\n   */\n  static push(\n    issuer: any,\n    callbackMethod: (...argzz: (any | Callback)[]) => void,\n    ...args: (any | Callback)[]\n  ) {\n    const callback: Callback = args.pop();\n    if (!callback || typeof callback !== \"function\")\n      throw new Error(\"Missing callback\");\n    const cb = (err?: Error, ...args: any[]) => {\n      Transaction.getLock()\n        .release(err)\n        .then(() => callback(err, ...args));\n    };\n    const transaction: Transaction = new Transaction(\n      issuer.constructor.name,\n      callbackMethod.name ? getObjectName(callbackMethod) : \"Anonymous\",\n      () => {\n        return callbackMethod.call(\n          transaction.bindToTransaction(issuer),\n          ...args,\n          cb\n        );\n      }\n    );\n    Transaction.getLock().submit(transaction);\n  }\n\n  /**\n   * @description Configures the transaction lock implementation\n   * @summary Sets the lock implementation to be used for transaction management, allowing customization of the transaction behavior\n   * @param {TransactionLock} lock - The lock implementation to use for managing transactions\n   * @return {void}\n   */\n  static setLock(lock: TransactionLock) {\n    this.lock = lock;\n  }\n\n  /**\n   * @description Retrieves the current transaction lock\n   * @summary Gets the current transaction lock instance, creating a default SyncronousLock if none exists\n   * @return {TransactionLock} The current transaction lock implementation\n   */\n  static getLock(): TransactionLock {\n    if (!this.lock) this.lock = new SyncronousLock();\n    return this.lock;\n  }\n\n  /**\n   * @description Submits a transaction for processing\n   * @summary Submits a transaction to the current transaction lock for processing and execution\n   * @param {Transaction} transaction - The transaction to submit for processing\n   * @return {void}\n   */\n  static submit(transaction: Transaction) {\n    Transaction.getLock().submit(transaction);\n  }\n\n  /**\n   * @description Releases the transaction lock\n   * @summary Releases the current transaction lock, optionally with an error, allowing the next transaction to proceed\n   * @param {Error} [err] - Optional error that occurred during transaction execution\n   * @return {Promise<void>} A promise that resolves when the lock has been released\n   */\n  static async release(err?: Error) {\n    return Transaction.getLock().release(err);\n  }\n\n  /**\n   * @description Retrieves transaction metadata\n   * @summary Returns a copy of the metadata associated with this transaction, ensuring the original metadata remains unmodified\n   * @return {any[] | undefined} A copy of the transaction metadata or undefined if no metadata exists\n   */\n  getMetadata() {\n    return this.metadata ? [...this.metadata] : undefined;\n  }\n\n  /**\n   * @description Links a new transaction to the current one\n   * @summary Binds a new transaction operation to the current transaction, transferring logs and binding methods to maintain transaction context\n   * @param {Transaction} nextTransaction - The new transaction to bind to the current one\n   * @return {void}\n   */\n  bindTransaction(nextTransaction: Transaction) {\n    // all(`Binding the {0} to {1}`, nextTransaction, this);\n    this.log.push(...nextTransaction.log);\n    nextTransaction.bindTransaction = this.bindToTransaction.bind(this);\n    nextTransaction.bindToTransaction = this.bindToTransaction.bind(this);\n    this.action = nextTransaction.action;\n  }\n\n  /**\n   * @description Binds an object to the current transaction context\n   * @summary Binds a transactional decorated object to the transaction by ensuring all transactional methods automatically receive the current transaction as their first argument\n   * @param {any} obj - The object to bind to the transaction\n   * @return {any} The bound object with transaction-aware method wrappers\n   */\n  bindToTransaction(obj: any): any {\n    const transactionalMethods = getAllPropertyDecoratorsRecursive(\n      obj,\n      undefined,\n      TransactionalKeys.REFLECT\n    );\n    if (!transactionalMethods) return obj;\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n\n    const boundObj = Reflection.getAllProperties(obj).reduce(\n      (accum: any, k: string) => {\n        if (\n          Object.keys(transactionalMethods).indexOf(k) !== -1 &&\n          transactionalMethods[k].find(\n            (o) => o.key === TransactionalKeys.TRANSACTIONAL\n          )\n        )\n          accum[k] = (...args: any[]) =>\n            obj[k].call(obj.__originalObj || obj, self, ...args);\n        else if (k === \"clazz\" || k === \"constructor\") accum[k] = obj[k];\n        else if (typeof obj[k] === \"function\")\n          accum[k] = obj[k].bind(obj.__originalObj || obj);\n        else if (typeof obj[k] === \"object\" && obj[k].constructor) {\n          const decs = Reflection.getClassDecorators(\n            TransactionalKeys.REFLECT,\n            obj[k]\n          );\n          if (decs.find((e: any) => e.key === TransactionalKeys.TRANSACTIONAL))\n            accum[k] = self.bindToTransaction(obj[k]);\n          else accum[k] = obj[k];\n        } else accum[k] = obj[k];\n\n        return accum;\n      },\n      {}\n    );\n\n    boundObj[DBKeys.ORIGINAL] = obj[DBKeys.ORIGINAL] || obj;\n    boundObj.toString = () =>\n      getObjectName(boundObj[DBKeys.ORIGINAL]) +\n      \" proxy for transaction \" +\n      this.id;\n\n    return boundObj;\n  }\n\n  /**\n   * @description Executes the transaction action\n   * @summary Fires the transaction by executing its associated action function, throwing an error if no action is defined\n   * @return {any} The result of the transaction action\n   */\n  fire() {\n    if (!this.action) throw new Error(`Missing the method`);\n    return this.action();\n  }\n\n  /**\n   * @description Provides a string representation of the transaction\n   * @summary Overrides the default toString method to provide a formatted string representation of the transaction, optionally including the transaction ID and log\n   * @param {boolean} [withId=true] - Whether to include the transaction ID in the output\n   * @param {boolean} [withLog=false] - Whether to include the transaction log in the output\n   * @return {string} A string representation of the transaction\n   */\n  toString(withId = true, withLog = false) {\n    return `${withId ? `[${this.id}]` : \"\"}[Transaction][${this.source}.${this.method}${\n      withLog ? `]\\nTransaction Log:\\n${this.log.join(\"\\n\")}` : \"]\"\n    }`;\n  }\n\n  /**\n   * @description Generates a reflection metadata key for transactions\n   * @summary Creates a prefixed reflection key for transaction-related metadata, ensuring proper namespacing\n   * @param {string} key - The base key to prefix with the transaction reflection namespace\n   * @return {string} The complete reflection key for transaction metadata\n   * @function key\n   */\n  static key(key: string) {\n    return TransactionalKeys.REFLECT + key;\n  }\n}\n","import { TransactionalKeys } from \"./constants\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Transaction } from \"./Transaction\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Method decorator that enables transactional behavior\n * @summary Sets a class async method as transactional, wrapping it in a transaction context that can be managed by the transaction system. This decorator handles transaction creation, binding, and error handling.\n * @param {any[]} [data] - Optional metadata available to the {@link TransactionLock} implementation\n * @return {Function} A decorator function that wraps the original method with transactional behavior\n * @function transactional\n * @category Method Decorators\n * @mermaid\n * sequenceDiagram\n *   participant C as Client Code\n *   participant D as Decorator\n *   participant T as Transaction\n *   participant O as Original Method\n *\n *   C->>D: Call decorated method\n *   D->>D: Check if transaction exists in args\n *\n *   alt Transaction exists in args\n *     D->>T: Create updated transaction\n *     T->>T: Bind to original transaction\n *     T->>T: Fire transaction\n *   else No transaction\n *     D->>T: Create new transaction\n *     T->>T: Submit transaction\n *   end\n *\n *   T->>O: Execute original method\n *   O-->>T: Return result/error\n *   T->>T: Release transaction\n *   T-->>C: Return result/error\n * @category Decorators\n */\nexport function transactional(...data: any[]) {\n  return function (\n    target: any,\n    propertyKey?: any,\n    descriptor?: PropertyDescriptor\n  ) {\n    if (!descriptor)\n      throw new InternalError(\"Missing descriptor. Should be impossible\");\n    metadata(Transaction.key(TransactionalKeys.TRANSACTIONAL), data)(\n      target,\n      propertyKey\n    );\n\n    const originalMethod = descriptor.value;\n\n    const methodWrapper = function (this: any, ...args: any[]): Promise<any> {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const self = this;\n      return new Promise<any>((resolve, reject) => {\n        const cb = (err?: Error, result?: any) => {\n          Transaction.release(err).then(() => {\n            if (err) return reject(err);\n            resolve(result);\n          });\n        };\n\n        let transaction = args.shift();\n        if (transaction instanceof Transaction) {\n          const updatedTransaction: Transaction = new Transaction(\n            this.constructor.name,\n            propertyKey,\n            async () => {\n              originalMethod\n                .call(updatedTransaction.bindToTransaction(self), ...args)\n                .then(resolve)\n                .catch(reject);\n            },\n            data.length ? data : undefined\n          );\n\n          transaction.bindTransaction(updatedTransaction);\n          transaction.fire();\n        } else {\n          args.unshift(transaction);\n          transaction = new Transaction(\n            this.constructor.name,\n            propertyKey,\n            () => {\n              originalMethod\n                .call(transaction.bindToTransaction(self), ...args)\n                .then((result: any) => cb(undefined, result))\n                .catch(cb);\n            },\n            data.length ? data : undefined\n          );\n          Transaction.submit(transaction);\n        }\n      });\n    };\n\n    Object.defineProperty(methodWrapper, \"name\", {\n      value: propertyKey,\n    });\n    descriptor.value = methodWrapper;\n  };\n}\n//\n// /**\n//  * @summary Sets a class Async method as transactional\n//  *\n//  * @param {any[]}  [metadata] option metadata available to the {@link TransactionLock}\n//  *\n//  * @function transactionalAsync\n//  *\n//  * @memberOf module:db-decorators.Decorators.transactions\n//  */\n// export function transactionalAsync(...metadata: any[]) {\n//   return function (\n//     target: any,\n//     propertyKey: string,\n//     descriptor: PropertyDescriptor,\n//   ) {\n//     metadasta(getTransactionalKey(TransactionalKeys.TRANSACTIONAL))\n//     Reflect.defineMetadata(\n//       ,\n//       {\n//         type: \"async\",\n//         metadata: metadata.length ? metadata : undefined,\n//       } as TransactionalMetadata,\n//       target,\n//       propertyKey,\n//     );\n//\n//     const originalMethod = descriptor.value;\n//\n//     const methodWrapper = function (this: any, ...args: any[]) {\n//       const callback: Callback = args.pop();\n//       if (!callback || typeof callback !== \"function\")\n//         throw new CriticalError(`Missing Callback`);\n//\n//       const cb = (err?: Err, ...args: any[]) => {\n//         Transaction.release(err).then((_) => callback(err, ...args));\n//       };\n//\n//       const self = this;\n//\n//       let transaction = args.shift();\n//       if (transaction instanceof Transaction) {\n//         const updatedTransaction: Transaction = new Transaction(\n//           this.constructor.name,\n//           propertyKey,\n//           () => {\n//             try {\n//               return originalMethod.call(\n//                 updatedTransaction.bindToTransaction(self),\n//                 ...args,\n//                 callback,\n//               );\n//             } catch (e: any) {\n//               return callback(e);\n//             }\n//           },\n//           metadata.length ? metadata : undefined,\n//         );\n//\n//         transaction.bindTransaction(updatedTransaction);\n//         transaction.fire();\n//       } else {\n//         args.unshift(transaction);\n//         transaction = undefined;\n//         transaction = new Transaction(\n//           this.constructor.name,\n//           propertyKey,\n//           () => {\n//             try {\n//               return originalMethod.call(\n//                 transaction.bindToTransaction(self),\n//                 ...args,\n//                 cb,\n//               );\n//             } catch (e: any) {\n//               return cb(e);\n//             }\n//           },\n//           metadata.length ? metadata : undefined,\n//         );\n//         Transaction.submit(transaction);\n//       }\n//     };\n//\n//     Object.defineProperty(methodWrapper, \"name\", {\n//       value: propertyKey,\n//     });\n//     descriptor.value = methodWrapper;\n//   };\n// }\n\n/**\n * @description Utility for handling super calls in transactional methods\n * @summary Wraps super method calls with the current transaction context when the super's method is also transactional, ensuring transaction continuity through the inheritance chain\n * @param {Function} method - The super method (must be bound to the proper this), e.g., super.create.bind(this)\n * @param {any[]} args - The arguments to call the method with\n * @return {any} The result of the super method call\n * @function transactionalSuperCall\n * @memberOf module:transactions\n */\nexport function transactionalSuperCall(method: any, ...args: any) {\n  const lock = Transaction.getLock();\n  const currentTransaction = lock.currentTransaction;\n  return method(currentTransaction, ...args);\n}\n","export * from \"./interfaces\";\nexport * from \"./locks\";\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./Transaction\";\nexport * from \"./types\";\n\n/**\n * @description Transactional decorators for TypeScript\n * @summary A comprehensive module providing transaction management capabilities for TypeScript applications. This module exposes decorators, locks, and utilities for implementing transactional behavior in your code, allowing for atomic operations, concurrency control, and error handling.\n * @module transactions\n */\n\n/**\n * @description Package version identifier\n * @summary Stores the current package version string, used for version tracking and compatibility checks\n * @const VERSION\n * @memberOf module:transactions\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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ACnB,SAAA,CAAC;AACF,QAAA,UAAU,CAAC,KAAK,GAAG,aAAa;AAClC,KAAC;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;AAQG;SACa,sBAAsB,CAAC,MAAW,EAAE,GAAG,IAAS,EAAA;AAC9D,IAAA,MAAM,IAAI,GAAG,WAAW,CAAC,OAAO,EAAE;AAClC,IAAA,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB;AAClD,IAAA,OAAO,MAAM,CAAC,kBAAkB,EAAE,GAAG,IAAI,CAAC;AAC5C;;ACxMA;;;;AAIG;AAEH;;;;;AAKG;AACI,MAAM,OAAO,GAAG;;;;"}