redis-smq-common 8.1.0 → 8.2.1

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 (117) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/cjs/src/logger/console-logger/console-logger.d.ts +14 -0
  3. package/dist/cjs/src/logger/console-logger/console-logger.d.ts.map +1 -0
  4. package/dist/cjs/src/logger/console-logger/console-logger.js +61 -0
  5. package/dist/cjs/src/logger/console-logger/console-logger.js.map +1 -0
  6. package/dist/cjs/src/logger/console-logger/console-message-formatter.d.ts +17 -0
  7. package/dist/cjs/src/logger/console-logger/console-message-formatter.d.ts.map +1 -0
  8. package/dist/cjs/src/logger/console-logger/console-message-formatter.js +48 -0
  9. package/dist/cjs/src/logger/console-logger/console-message-formatter.js.map +1 -0
  10. package/dist/cjs/src/logger/console-logger/index.d.ts +3 -0
  11. package/dist/cjs/src/logger/console-logger/index.d.ts.map +1 -0
  12. package/dist/cjs/src/logger/console-logger/index.js +19 -0
  13. package/dist/cjs/src/logger/console-logger/index.js.map +1 -0
  14. package/dist/cjs/src/logger/console-logger/types/console-logger.d.ts +15 -0
  15. package/dist/cjs/src/logger/console-logger/types/console-logger.d.ts.map +1 -0
  16. package/dist/cjs/src/logger/console-logger/types/console-logger.js +11 -0
  17. package/dist/cjs/src/logger/console-logger/types/console-logger.js.map +1 -0
  18. package/dist/cjs/src/logger/console-logger/types/index.d.ts +2 -0
  19. package/dist/cjs/src/logger/console-logger/types/index.d.ts.map +1 -0
  20. package/dist/cjs/src/logger/console-logger/types/index.js +18 -0
  21. package/dist/cjs/src/logger/console-logger/types/index.js.map +1 -0
  22. package/dist/cjs/src/logger/index.d.ts +1 -0
  23. package/dist/cjs/src/logger/index.d.ts.map +1 -1
  24. package/dist/cjs/src/logger/index.js +1 -0
  25. package/dist/cjs/src/logger/index.js.map +1 -1
  26. package/dist/cjs/src/logger/logger.d.ts +1 -1
  27. package/dist/cjs/src/logger/logger.d.ts.map +1 -1
  28. package/dist/cjs/src/logger/logger.js +27 -5
  29. package/dist/cjs/src/logger/logger.js.map +1 -1
  30. package/dist/cjs/src/logger/types/index.d.ts +1 -7
  31. package/dist/cjs/src/logger/types/index.d.ts.map +1 -1
  32. package/dist/cjs/src/logger/types/index.js +1 -1
  33. package/dist/cjs/src/logger/types/logger.d.ts +12 -0
  34. package/dist/cjs/src/logger/types/logger.d.ts.map +1 -0
  35. package/dist/cjs/src/logger/types/{config.js → logger.js} +1 -1
  36. package/dist/cjs/src/logger/types/logger.js.map +1 -0
  37. package/dist/cjs/src/redis-lock/redis-lock.d.ts +2 -0
  38. package/dist/cjs/src/redis-lock/redis-lock.d.ts.map +1 -1
  39. package/dist/cjs/src/redis-lock/redis-lock.js +114 -19
  40. package/dist/cjs/src/redis-lock/redis-lock.js.map +1 -1
  41. package/dist/cjs/src/worker/worker-callable.d.ts +2 -1
  42. package/dist/cjs/src/worker/worker-callable.d.ts.map +1 -1
  43. package/dist/cjs/src/worker/worker-callable.js +31 -3
  44. package/dist/cjs/src/worker/worker-callable.js.map +1 -1
  45. package/dist/cjs/src/worker/worker-resource-group.d.ts.map +1 -1
  46. package/dist/cjs/src/worker/worker-resource-group.js +100 -17
  47. package/dist/cjs/src/worker/worker-resource-group.js.map +1 -1
  48. package/dist/cjs/src/worker/worker-runnable.d.ts +2 -1
  49. package/dist/cjs/src/worker/worker-runnable.d.ts.map +1 -1
  50. package/dist/cjs/src/worker/worker-runnable.js +33 -4
  51. package/dist/cjs/src/worker/worker-runnable.js.map +1 -1
  52. package/dist/cjs/src/worker/worker.d.ts +4 -1
  53. package/dist/cjs/src/worker/worker.d.ts.map +1 -1
  54. package/dist/cjs/src/worker/worker.js +206 -57
  55. package/dist/cjs/src/worker/worker.js.map +1 -1
  56. package/dist/esm/src/logger/console-logger/console-logger.d.ts +14 -0
  57. package/dist/esm/src/logger/console-logger/console-logger.d.ts.map +1 -0
  58. package/dist/esm/src/logger/console-logger/console-logger.js +59 -0
  59. package/dist/esm/src/logger/console-logger/console-logger.js.map +1 -0
  60. package/dist/esm/src/logger/console-logger/console-message-formatter.d.ts +17 -0
  61. package/dist/esm/src/logger/console-logger/console-message-formatter.d.ts.map +1 -0
  62. package/dist/esm/src/logger/console-logger/console-message-formatter.js +47 -0
  63. package/dist/esm/src/logger/console-logger/console-message-formatter.js.map +1 -0
  64. package/dist/esm/src/logger/console-logger/index.d.ts +3 -0
  65. package/dist/esm/src/logger/console-logger/index.d.ts.map +1 -0
  66. package/dist/esm/src/logger/console-logger/index.js +3 -0
  67. package/dist/esm/src/logger/console-logger/index.js.map +1 -0
  68. package/dist/esm/src/logger/console-logger/types/console-logger.d.ts +15 -0
  69. package/dist/esm/src/logger/console-logger/types/console-logger.d.ts.map +1 -0
  70. package/dist/esm/src/logger/console-logger/types/console-logger.js +8 -0
  71. package/dist/esm/src/logger/console-logger/types/console-logger.js.map +1 -0
  72. package/dist/esm/src/logger/console-logger/types/index.d.ts +2 -0
  73. package/dist/esm/src/logger/console-logger/types/index.d.ts.map +1 -0
  74. package/dist/esm/src/logger/console-logger/types/index.js +2 -0
  75. package/dist/esm/src/logger/console-logger/types/index.js.map +1 -0
  76. package/dist/esm/src/logger/index.d.ts +1 -0
  77. package/dist/esm/src/logger/index.d.ts.map +1 -1
  78. package/dist/esm/src/logger/index.js +1 -0
  79. package/dist/esm/src/logger/index.js.map +1 -1
  80. package/dist/esm/src/logger/logger.d.ts +1 -1
  81. package/dist/esm/src/logger/logger.d.ts.map +1 -1
  82. package/dist/esm/src/logger/logger.js +25 -3
  83. package/dist/esm/src/logger/logger.js.map +1 -1
  84. package/dist/esm/src/logger/types/index.d.ts +1 -7
  85. package/dist/esm/src/logger/types/index.d.ts.map +1 -1
  86. package/dist/esm/src/logger/types/index.js +1 -1
  87. package/dist/esm/src/logger/types/logger.d.ts +12 -0
  88. package/dist/esm/src/logger/types/logger.d.ts.map +1 -0
  89. package/dist/esm/src/logger/types/logger.js +2 -0
  90. package/dist/esm/src/logger/types/logger.js.map +1 -0
  91. package/dist/esm/src/redis-lock/redis-lock.d.ts +2 -0
  92. package/dist/esm/src/redis-lock/redis-lock.d.ts.map +1 -1
  93. package/dist/esm/src/redis-lock/redis-lock.js +114 -19
  94. package/dist/esm/src/redis-lock/redis-lock.js.map +1 -1
  95. package/dist/esm/src/worker/worker-callable.d.ts +2 -1
  96. package/dist/esm/src/worker/worker-callable.d.ts.map +1 -1
  97. package/dist/esm/src/worker/worker-callable.js +31 -3
  98. package/dist/esm/src/worker/worker-callable.js.map +1 -1
  99. package/dist/esm/src/worker/worker-resource-group.d.ts.map +1 -1
  100. package/dist/esm/src/worker/worker-resource-group.js +100 -17
  101. package/dist/esm/src/worker/worker-resource-group.js.map +1 -1
  102. package/dist/esm/src/worker/worker-runnable.d.ts +2 -1
  103. package/dist/esm/src/worker/worker-runnable.d.ts.map +1 -1
  104. package/dist/esm/src/worker/worker-runnable.js +33 -4
  105. package/dist/esm/src/worker/worker-runnable.js.map +1 -1
  106. package/dist/esm/src/worker/worker.d.ts +4 -1
  107. package/dist/esm/src/worker/worker.d.ts.map +1 -1
  108. package/dist/esm/src/worker/worker.js +206 -55
  109. package/dist/esm/src/worker/worker.js.map +1 -1
  110. package/package.json +1 -1
  111. package/dist/cjs/src/logger/types/config.d.ts +0 -4
  112. package/dist/cjs/src/logger/types/config.d.ts.map +0 -1
  113. package/dist/cjs/src/logger/types/config.js.map +0 -1
  114. package/dist/esm/src/logger/types/config.d.ts +0 -4
  115. package/dist/esm/src/logger/types/config.d.ts.map +0 -1
  116. package/dist/esm/src/logger/types/config.js +0 -2
  117. package/dist/esm/src/logger/types/config.js.map +0 -1
@@ -6,32 +6,61 @@ const index_js_2 = require("./errors/index.js");
6
6
  const index_js_3 = require("./types/index.js");
7
7
  const worker_js_1 = require("./worker.js");
8
8
  class WorkerRunnable extends worker_js_1.Worker {
9
- constructor(workerFilename, initialPayload) {
9
+ constructor(workerFilename, initialPayload, logger) {
10
10
  super(workerFilename, initialPayload);
11
11
  this.type = index_js_3.EWorkerType.RUNNABLE;
12
+ this.logger = logger !== null && logger !== void 0 ? logger : this.logger;
12
13
  this.powerSwitch = new index_js_1.PowerSwitch();
14
+ this.logger.info(`WorkerRunnable instance created for ${workerFilename}`);
15
+ this.logger.debug('WorkerRunnable initialization details', {
16
+ id: this.id,
17
+ type: index_js_3.EWorkerType[this.type],
18
+ hasCustomLogger: !!logger,
19
+ initialPayload: this.initialPayload ? 'provided' : 'none',
20
+ });
13
21
  }
14
22
  run(cb) {
23
+ this.logger.info(`Attempting to run worker ${this.id}`);
15
24
  const r = this.powerSwitch.goingUp();
16
25
  if (r) {
26
+ this.logger.debug('Power switch state changed to going up');
27
+ this.logger.debug('Registering worker thread event handlers');
17
28
  this.registerEvents(this);
29
+ this.logger.debug(`Posting RUN message to worker thread`);
18
30
  this.postMessage({ type: index_js_3.EWorkerThreadParentMessage.RUN });
31
+ this.logger.debug('Committing power switch state change');
19
32
  this.powerSwitch.commit();
33
+ this.logger.info(`Worker ${this.id} started successfully`);
20
34
  cb();
21
35
  }
22
- else
36
+ else {
37
+ this.logger.warn(`Cannot start worker ${this.id}: already running`);
23
38
  cb(new index_js_2.WorkerAlreadyRunningError());
39
+ }
24
40
  }
25
41
  shutdown(cb) {
42
+ this.logger.info(`Attempting to shut down worker ${this.id}`);
26
43
  const r = this.powerSwitch.goingDown();
27
44
  if (r) {
28
- super.shutdown(() => {
45
+ this.logger.debug('Power switch state changed to going down');
46
+ this.logger.debug('Calling parent shutdown method');
47
+ super.shutdown((err) => {
48
+ if (err) {
49
+ this.logger.warn(`Error during worker ${this.id} shutdown: ${err.message}`, {
50
+ error: err.message,
51
+ stack: err.stack,
52
+ });
53
+ }
54
+ this.logger.debug('Committing power switch state change');
29
55
  this.powerSwitch.commit();
56
+ this.logger.info(`Worker ${this.id} shut down successfully`);
30
57
  cb();
31
58
  });
32
59
  }
33
- else
60
+ else {
61
+ this.logger.warn(`Cannot shut down worker ${this.id}: already down`);
34
62
  cb(new index_js_2.WorkerAlreadyDownError());
63
+ }
35
64
  }
36
65
  }
37
66
  exports.WorkerRunnable = WorkerRunnable;
@@ -1 +1 @@
1
- {"version":3,"file":"worker-runnable.js","sourceRoot":"","sources":["../../../../src/worker/worker-runnable.ts"],"names":[],"mappings":";;;AAUA,uDAAuD;AACvD,gDAG2B;AAC3B,+CAI0B;AAC1B,2CAAqC;AAErC,MAAa,cACX,SAAQ,kBAAkB;IAM1B,YAAY,cAAsB,EAAE,cAA+B;QACjE,KAAK,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;QAJrB,SAAI,GAAgB,sBAAW,CAAC,QAAQ,CAAC;QAK1D,IAAI,CAAC,WAAW,GAAG,IAAI,sBAAW,EAAE,CAAC;IACvC,CAAC;IAED,GAAG,CAAC,EAAmB;QACrB,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QACrC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC1B,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,qCAA0B,CAAC,GAAG,EAAE,CAAC,CAAC;YAC3D,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAC1B,EAAE,EAAE,CAAC;QACP,CAAC;;YAAM,EAAE,CAAC,IAAI,oCAAyB,EAAE,CAAC,CAAC;IAC7C,CAAC;IAEQ,QAAQ,CAAC,EAAmB;QACnC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;gBAC1B,EAAE,EAAE,CAAC;YACP,CAAC,CAAC,CAAC;QACL,CAAC;;YAAM,EAAE,CAAC,IAAI,iCAAsB,EAAE,CAAC,CAAC;IAC1C,CAAC;CACF;AA/BD,wCA+BC"}
1
+ {"version":3,"file":"worker-runnable.js","sourceRoot":"","sources":["../../../../src/worker/worker-runnable.ts"],"names":[],"mappings":"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"}
@@ -8,10 +8,13 @@ export type TWorkerEvent = {
8
8
  };
9
9
  export declare abstract class Worker<Payload, Reply> extends EventEmitter<TWorkerEvent> {
10
10
  protected abstract readonly type: EWorkerType;
11
+ protected readonly id: `${string}-${string}-${string}-${string}-${string}`;
11
12
  protected readonly workerFilename: string;
12
13
  protected readonly initialPayload: unknown;
13
14
  protected workerThread: WorkerThread | null;
14
- constructor(workerFilename: string, initialPayload?: unknown);
15
+ protected logger: import("../logger/index.js").ILogger;
16
+ protected constructor(workerFilename: string, initialPayload?: unknown);
17
+ getId(): string;
15
18
  protected getWorkerThread(): WorkerThread;
16
19
  protected registerEvents(cb: ICallback<Reply> | Worker<Payload, Reply>): void;
17
20
  postMessage(message: TWorkerThreadParentMessage): void;
@@ -1 +1 @@
1
- {"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../../../src/worker/worker.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAE/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,OAAO,EAGL,WAAW,EAEX,0BAA0B,EAC3B,MAAM,kBAAkB,CAAC;AAE1B,MAAM,MAAM,YAAY,GAAG;IACzB,cAAc,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAI,CAAC;IACrC,aAAa,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC3C,CAAC;AAYF,8BAAsB,MAAM,CAC1B,OAAO,EACP,KAAK,CACL,SAAQ,YAAY,CAAC,YAAY,CAAC;IAClC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC;IAC9C,SAAS,CAAC,QAAQ,CAAC,cAAc,SAAC;IAClC,SAAS,CAAC,QAAQ,CAAC,cAAc,UAAC;IAClC,SAAS,CAAC,YAAY,EAAE,YAAY,GAAG,IAAI,CAAQ;gBAEvC,cAAc,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO;IAoB5D,SAAS,CAAC,eAAe,IAAI,YAAY;IAuCzC,SAAS,CAAC,cAAc,CACtB,EAAE,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAC5C,IAAI;IAmCP,WAAW,CAAC,OAAO,EAAE,0BAA0B,GAAG,IAAI;IAItD,QAAQ,CAAC,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC;CAS7B"}
1
+ {"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../../../src/worker/worker.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAE/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAGjD,OAAO,EAIL,WAAW,EAEX,0BAA0B,EAC3B,MAAM,kBAAkB,CAAC;AAE1B,MAAM,MAAM,YAAY,GAAG;IACzB,cAAc,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAI,CAAC;IACrC,aAAa,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC3C,CAAC;AAYF,8BAAsB,MAAM,CAC1B,OAAO,EACP,KAAK,CACL,SAAQ,YAAY,CAAC,YAAY,CAAC;IAClC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC;IAC9C,SAAS,CAAC,QAAQ,CAAC,EAAE,sDAAC;IACtB,SAAS,CAAC,QAAQ,CAAC,cAAc,SAAC;IAClC,SAAS,CAAC,QAAQ,CAAC,cAAc,UAAC;IAClC,SAAS,CAAC,YAAY,EAAE,YAAY,GAAG,IAAI,CAAQ;IACnD,SAAS,CAAC,MAAM,uCAAC;IAEjB,SAAS,aAAa,cAAc,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO;IAmBtE,KAAK,IAAI,MAAM;IAkBf,SAAS,CAAC,eAAe,IAAI,YAAY;IAsGzC,SAAS,CAAC,cAAc,CACtB,EAAE,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAC5C,IAAI;IAoGP,WAAW,CAAC,OAAO,EAAE,0BAA0B,GAAG,IAAI;IAiCtD,QAAQ,CAAC,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC;CA8B7B"}
@@ -1,95 +1,244 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Worker = void 0;
4
+ const node_crypto_1 = require("node:crypto");
4
5
  const path_1 = require("path");
5
6
  const worker_threads_1 = require("worker_threads");
6
7
  const index_js_1 = require("../env/index.js");
7
8
  const index_js_2 = require("../event/index.js");
8
- const index_js_3 = require("./errors/index.js");
9
- const index_js_4 = require("./types/index.js");
9
+ const index_js_3 = require("../logger/index.js");
10
+ const index_js_4 = require("./errors/index.js");
11
+ const index_js_5 = require("./types/index.js");
10
12
  const dir = index_js_1.env.getCurrentDir();
11
13
  class Worker extends index_js_2.EventEmitter {
12
14
  constructor(workerFilename, initialPayload) {
13
15
  super();
14
16
  this.workerThread = null;
17
+ this.id = (0, node_crypto_1.randomUUID)();
15
18
  this.workerFilename = workerFilename;
16
19
  this.initialPayload = initialPayload;
20
+ this.logger = index_js_3.logger.getLogger({ enabled: false });
21
+ this.logger.info(`Worker instance created for ${workerFilename}`);
22
+ this.logger.debug('Worker initialization details', {
23
+ id: this.id,
24
+ filename: workerFilename,
25
+ initialPayload: this.initialPayload ? 'provided' : 'none',
26
+ });
27
+ }
28
+ getId() {
29
+ return this.id;
17
30
  }
18
31
  getWorkerThread() {
19
32
  if (!this.workerThread) {
20
- this.workerThread = new worker_threads_1.Worker((0, path_1.resolve)(dir, './worker-thread/worker-thread.js'), {
21
- workerData: {
22
- filename: this.workerFilename,
23
- initialPayload: this.initialPayload,
24
- type: this.type,
25
- },
26
- });
27
- this.workerThread.on('messageerror', (err) => {
28
- console.error(err);
29
- });
30
- this.workerThread.on('error', (err) => {
31
- console.error(err);
32
- });
33
- this.workerThread.on('exit', () => {
34
- this.workerThread = null;
33
+ const workerThreadPath = (0, path_1.resolve)(dir, './worker-thread/worker-thread.js');
34
+ this.logger.info(`Creating new worker thread from ${workerThreadPath}`);
35
+ this.logger.debug('Worker thread configuration', {
36
+ filename: this.workerFilename,
37
+ type: index_js_5.EWorkerType[this.type],
38
+ workerThreadPath,
35
39
  });
40
+ try {
41
+ this.workerThread = new worker_threads_1.Worker(workerThreadPath, {
42
+ workerData: {
43
+ filename: this.workerFilename,
44
+ initialPayload: this.initialPayload,
45
+ type: this.type,
46
+ },
47
+ stdout: true,
48
+ });
49
+ this.logger.debug('Worker thread created successfully');
50
+ if (this.workerThread.stdout) {
51
+ this.logger.debug('Setting up stdout capture for worker thread');
52
+ this.workerThread.stdout.on('data', (data) => {
53
+ const output = data.toString().trim();
54
+ if (output) {
55
+ this.logger.debug(output);
56
+ }
57
+ });
58
+ }
59
+ else {
60
+ this.logger.warn('Worker thread stdout is not available');
61
+ }
62
+ if (this.workerThread.stderr) {
63
+ this.logger.debug('Setting up stderr capture for worker thread');
64
+ this.workerThread.stderr.on('data', (data) => {
65
+ const output = data.toString().trim();
66
+ if (output) {
67
+ this.logger.error(output);
68
+ }
69
+ });
70
+ }
71
+ else {
72
+ this.logger.warn('Worker thread stderr is not available');
73
+ }
74
+ this.workerThread.on('messageerror', (err) => {
75
+ this.logger.error(`Worker message deserialization error: ${err.message}`, {
76
+ error: err.message,
77
+ stack: err.stack,
78
+ name: err.name,
79
+ });
80
+ });
81
+ this.workerThread.on('error', (err) => {
82
+ this.logger.error(`Worker uncaught exception: ${err.message}`, {
83
+ error: err.message,
84
+ stack: err.stack,
85
+ name: err.name,
86
+ });
87
+ });
88
+ this.workerThread.on('exit', (code) => {
89
+ if (code === 0) {
90
+ this.logger.info('Worker thread exited successfully with code 0');
91
+ }
92
+ else {
93
+ this.logger.warn(`Worker thread exited with code ${code}`);
94
+ }
95
+ this.workerThread = null;
96
+ });
97
+ }
98
+ catch (err) {
99
+ const error = err instanceof Error ? err : new Error('Unknown error');
100
+ this.logger.error(`Failed to create worker thread: ${error.message}`, {
101
+ error: error.message,
102
+ stack: error.stack,
103
+ });
104
+ throw err;
105
+ }
106
+ }
107
+ else {
108
+ this.logger.debug('Reusing existing worker thread');
36
109
  }
37
110
  return this.workerThread;
38
111
  }
39
112
  registerEvents(cb) {
40
- const worker = this.getWorkerThread();
41
- const cleanUp = () => {
42
- worker
43
- .removeListener('message', onMessage)
44
- .removeListener('exit', onExit);
45
- };
46
- const callback = (err, data) => {
47
- if (err) {
48
- if (cb instanceof Worker) {
49
- this.emit('worker.error', err);
113
+ try {
114
+ const worker = this.getWorkerThread();
115
+ this.logger.debug('Registering worker thread event handlers');
116
+ const cleanUp = () => {
117
+ this.logger.debug('Cleaning up worker thread event listeners');
118
+ worker
119
+ .removeListener('message', onMessage)
120
+ .removeListener('exit', onExit);
121
+ };
122
+ const callback = (err, data) => {
123
+ if (err) {
124
+ this.logger.error(`Worker callback error: ${err.message}`, {
125
+ error: err.message,
126
+ stack: err.stack,
127
+ name: err.name,
128
+ });
129
+ if (cb instanceof Worker) {
130
+ this.logger.debug('Emitting worker.error event');
131
+ this.emit('worker.error', err);
132
+ }
133
+ else {
134
+ this.logger.debug('Calling error callback');
135
+ cb(err);
136
+ }
137
+ }
138
+ else {
139
+ this.logger.debug('Worker callback success');
140
+ if (cb instanceof Worker) {
141
+ this.logger.debug('Emitting worker.data event');
142
+ this.emit('worker.data', data);
143
+ }
144
+ else {
145
+ this.logger.debug('Calling success callback');
146
+ cb(null, data);
147
+ }
50
148
  }
51
- else
52
- cb(err);
53
- }
54
- else {
55
- if (cb instanceof Worker)
56
- this.emit('worker.data', data);
57
- else
58
- cb(null, data);
59
- }
60
- };
61
- const onMessage = (msg) => {
62
- cleanUp();
63
- if (msg.code !== index_js_4.EWorkerThreadChildExecutionCode.OK) {
64
- callback(new index_js_3.WorkerThreadError(msg));
65
- }
66
- else
67
- callback(null, msg.data);
68
- };
69
- const onExit = () => {
70
- cleanUp();
71
- const msg = {
72
- code: index_js_4.EWorkerThreadChildExitCode.TERMINATED,
73
- error: null,
74
149
  };
75
- callback(new index_js_3.WorkerThreadError(msg));
76
- };
77
- worker.once('message', onMessage);
78
- worker.once('exit', onExit);
150
+ const onMessage = (msg) => {
151
+ this.logger.debug(`Received message from worker thread with code ${msg.code}`, {
152
+ code: msg.code,
153
+ hasData: msg.data !== undefined,
154
+ hasError: msg.error !== null && msg.error !== undefined,
155
+ });
156
+ cleanUp();
157
+ if (msg.code !== index_js_5.EWorkerThreadChildExecutionCode.OK) {
158
+ const errorCode = index_js_5.EWorkerThreadChildExecutionCode[msg.code] ||
159
+ index_js_5.EWorkerThreadChildExitCode[msg.code] ||
160
+ `Unknown(${msg.code})`;
161
+ this.logger.error(`Worker thread execution error: ${errorCode}`, {
162
+ code: msg.code,
163
+ errorCode,
164
+ error: msg.error,
165
+ });
166
+ callback(new index_js_4.WorkerThreadError(msg));
167
+ }
168
+ else {
169
+ this.logger.debug('Worker thread execution successful');
170
+ callback(null, msg.data);
171
+ }
172
+ };
173
+ const onExit = (code) => {
174
+ this.logger.warn(`Worker thread exited unexpectedly with code ${code}`);
175
+ cleanUp();
176
+ const msg = {
177
+ code: index_js_5.EWorkerThreadChildExitCode.TERMINATED,
178
+ error: null,
179
+ };
180
+ this.logger.error('Worker thread terminated', {
181
+ exitCode: code,
182
+ errorCode: index_js_5.EWorkerThreadChildExitCode[index_js_5.EWorkerThreadChildExitCode.TERMINATED],
183
+ });
184
+ callback(new index_js_4.WorkerThreadError(msg));
185
+ };
186
+ worker.once('message', onMessage);
187
+ worker.once('exit', onExit);
188
+ this.logger.debug('Worker thread event handlers registered successfully');
189
+ }
190
+ catch (err) {
191
+ this.logger.error(`Failed to register worker thread events: ${err instanceof Error ? err.message : 'unknown error'}`, err);
192
+ throw err;
193
+ }
79
194
  }
80
195
  postMessage(message) {
81
- this.getWorkerThread().postMessage(message);
196
+ try {
197
+ this.logger.debug(`Posting message to worker thread: ${index_js_5.EWorkerThreadParentMessage[message.type]}`, {
198
+ messageType: index_js_5.EWorkerThreadParentMessage[message.type],
199
+ hasPayload: 'payload' in message && message.payload !== undefined,
200
+ });
201
+ const worker = this.getWorkerThread();
202
+ worker.postMessage(message);
203
+ this.logger.debug('Message posted successfully to worker thread');
204
+ }
205
+ catch (err) {
206
+ const error = err instanceof Error ? err : new Error('Unknown error');
207
+ this.logger.error(`Failed to post message to worker thread: ${error.message}`, {
208
+ error: error.message,
209
+ stack: error.stack,
210
+ messageType: message.type,
211
+ });
212
+ throw err;
213
+ }
82
214
  }
83
215
  shutdown(cb) {
216
+ this.logger.info('Shutting down worker thread');
84
217
  const callback = () => {
218
+ this.logger.info('Worker thread shutdown complete');
85
219
  this.workerThread = null;
86
220
  cb();
87
221
  };
88
222
  if (this.workerThread) {
89
- this.workerThread.terminate().then(callback).catch(callback);
223
+ this.logger.debug('Terminating active worker thread');
224
+ this.workerThread
225
+ .terminate()
226
+ .then((code) => {
227
+ this.logger.debug(`Worker thread terminated with exit code ${code}`);
228
+ callback();
229
+ })
230
+ .catch((err) => {
231
+ this.logger.error(`Error terminating worker thread: ${err.message}`, {
232
+ error: err.message,
233
+ stack: err.stack,
234
+ });
235
+ callback();
236
+ });
90
237
  }
91
- else
238
+ else {
239
+ this.logger.debug('No active worker thread to terminate');
92
240
  cb();
241
+ }
93
242
  }
94
243
  }
95
244
  exports.Worker = Worker;
@@ -1 +1 @@
1
- {"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../src/worker/worker.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../src/worker/worker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { ILogger } from '../types/index.js';
2
+ import { IConsoleLoggerOptions } from './types/index.js';
3
+ export declare class ConsoleLogger implements ILogger {
4
+ private readonly logLevel;
5
+ private readonly formatter;
6
+ constructor(options?: IConsoleLoggerOptions);
7
+ private shouldLog;
8
+ isFormatted(message: unknown): boolean;
9
+ debug(message: unknown, ...params: unknown[]): void;
10
+ error(message: unknown, ...params: unknown[]): void;
11
+ info(message: unknown, ...params: unknown[]): void;
12
+ warn(message: unknown, ...params: unknown[]): void;
13
+ }
14
+ //# sourceMappingURL=console-logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console-logger.d.ts","sourceRoot":"","sources":["../../../../../src/logger/console-logger/console-logger.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAuB,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAM9E,qBAAa,aAAc,YAAW,OAAO;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAsB;IAC/C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA0B;gBAWxC,OAAO,GAAE,qBAA0B;IAwB/C,OAAO,CAAC,SAAS;IAWV,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;IAUtC,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI;IAgBnD,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI;IAgBnD,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI;IAgBlD,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI;CAS1D"}
@@ -0,0 +1,59 @@
1
+ import { ConsoleMessageFormatter } from './console-message-formatter.js';
2
+ import { EConsoleLoggerLevel } from './types/index.js';
3
+ export class ConsoleLogger {
4
+ logLevel;
5
+ formatter;
6
+ constructor(options = {}) {
7
+ const { includeTimestamp = true, colorize = true, logLevel = EConsoleLoggerLevel.INFO, dateFormat, } = options;
8
+ this.logLevel =
9
+ typeof logLevel === 'number' ? logLevel : EConsoleLoggerLevel[logLevel];
10
+ this.formatter = new ConsoleMessageFormatter({
11
+ includeTimestamp,
12
+ colorize,
13
+ dateFormat,
14
+ });
15
+ }
16
+ shouldLog(level) {
17
+ return level >= this.logLevel;
18
+ }
19
+ isFormatted(message) {
20
+ return this.formatter.isFormatted(message);
21
+ }
22
+ debug(message, ...params) {
23
+ if (!this.shouldLog(EConsoleLoggerLevel.DEBUG))
24
+ return;
25
+ if (this.isFormatted(message)) {
26
+ return console.debug(message, ...params);
27
+ }
28
+ const formattedMessage = this.formatter.format('DEBUG', message);
29
+ console.debug(formattedMessage, ...params);
30
+ }
31
+ error(message, ...params) {
32
+ if (!this.shouldLog(EConsoleLoggerLevel.ERROR))
33
+ return;
34
+ if (this.isFormatted(message)) {
35
+ return console.error(message, ...params);
36
+ }
37
+ const formattedMessage = this.formatter.format('ERROR', message);
38
+ console.error(formattedMessage, ...params);
39
+ }
40
+ info(message, ...params) {
41
+ if (!this.shouldLog(EConsoleLoggerLevel.INFO))
42
+ return;
43
+ if (this.isFormatted(message)) {
44
+ return console.info(message, ...params);
45
+ }
46
+ const formattedMessage = this.formatter.format('INFO', message);
47
+ console.info(formattedMessage, ...params);
48
+ }
49
+ warn(message, ...params) {
50
+ if (!this.shouldLog(EConsoleLoggerLevel.WARN))
51
+ return;
52
+ if (this.isFormatted(message)) {
53
+ return console.warn(message, ...params);
54
+ }
55
+ const formattedMessage = this.formatter.format('WARN', message);
56
+ console.warn(formattedMessage, ...params);
57
+ }
58
+ }
59
+ //# sourceMappingURL=console-logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console-logger.js","sourceRoot":"","sources":["../../../../../src/logger/console-logger/console-logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { TConsoleLoggerLevelName, TConsoleLoggerOptionsDateFormatter } from './types/index.js';
2
+ export declare class ConsoleMessageFormatter {
3
+ private readonly includeTimestamp;
4
+ private readonly colorize;
5
+ private readonly dateFormatter;
6
+ private readonly levelColors;
7
+ private resetColor;
8
+ constructor(options?: {
9
+ includeTimestamp?: boolean;
10
+ colorize?: boolean;
11
+ dateFormat?: TConsoleLoggerOptionsDateFormatter;
12
+ });
13
+ stripColorCodes(str: string): string;
14
+ isFormatted(message: unknown): boolean;
15
+ format(level: TConsoleLoggerLevelName, message: unknown): string;
16
+ }
17
+ //# sourceMappingURL=console-message-formatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console-message-formatter.d.ts","sourceRoot":"","sources":["../../../../../src/logger/console-logger/console-message-formatter.ts"],"names":[],"mappings":"AASA,OAAO,EACL,uBAAuB,EACvB,kCAAkC,EACnC,MAAM,kBAAkB,CAAC;AAM1B,qBAAa,uBAAuB;IAClC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAU;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;IACnC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqC;IAGnE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAK1B;IAEF,OAAO,CAAC,UAAU,CAAe;gBAW/B,OAAO,GAAE;QACP,gBAAgB,CAAC,EAAE,OAAO,CAAC;QAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,UAAU,CAAC,EAAE,kCAAkC,CAAC;KAC5C;IAcD,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM;IAgBpC,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;IA0BtC,MAAM,CAAC,KAAK,EAAE,uBAAuB,EAAE,OAAO,EAAE,OAAO,GAAG,MAAM;CAuBxE"}
@@ -0,0 +1,47 @@
1
+ export class ConsoleMessageFormatter {
2
+ includeTimestamp;
3
+ colorize;
4
+ dateFormatter;
5
+ levelColors = {
6
+ DEBUG: '\u001b[36m',
7
+ INFO: '\u001b[32m',
8
+ WARN: '\u001b[33m',
9
+ ERROR: '\u001b[31m',
10
+ };
11
+ resetColor = '\u001b[0m';
12
+ constructor(options = {}) {
13
+ const { includeTimestamp, colorize, dateFormat } = options;
14
+ this.includeTimestamp = includeTimestamp !== false;
15
+ this.colorize = colorize !== false;
16
+ this.dateFormatter = dateFormat || ((date) => date.toISOString());
17
+ }
18
+ stripColorCodes(str) {
19
+ return str.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '');
20
+ }
21
+ isFormatted(message) {
22
+ if (typeof message !== 'string')
23
+ return false;
24
+ const strippedMessage = this.stripColorCodes(message);
25
+ const timestampLevelPattern = /^\[.+\] \[[A-Z]+\]/;
26
+ if (!this.includeTimestamp) {
27
+ const anyLevelPattern = /^\[[A-Z]+\]/;
28
+ return anyLevelPattern.test(strippedMessage);
29
+ }
30
+ return timestampLevelPattern.test(strippedMessage);
31
+ }
32
+ format(level, message) {
33
+ if (this.isFormatted(message)) {
34
+ return String(message);
35
+ }
36
+ const timestamp = this.includeTimestamp
37
+ ? `[${this.dateFormatter(new Date())}] `
38
+ : '';
39
+ const formattedMessage = typeof message === 'string' ? message : JSON.stringify(message);
40
+ const baseMessage = `${timestamp}[${level}] ${this.stripColorCodes(formattedMessage)}`;
41
+ if (this.colorize && this.levelColors[level]) {
42
+ return `${this.levelColors[level]}${baseMessage}${this.resetColor}`;
43
+ }
44
+ return baseMessage;
45
+ }
46
+ }
47
+ //# sourceMappingURL=console-message-formatter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console-message-formatter.js","sourceRoot":"","sources":["../../../../../src/logger/console-logger/console-message-formatter.ts"],"names":[],"mappings":"AAkBA,MAAM,OAAO,uBAAuB;IACjB,gBAAgB,CAAU;IAC1B,QAAQ,CAAU;IAClB,aAAa,CAAqC;IAGlD,WAAW,GAA4C;QACtE,KAAK,EAAE,YAAY;QACnB,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,YAAY;QAClB,KAAK,EAAE,YAAY;KACpB,CAAC;IAEM,UAAU,GAAG,WAAW,CAAC;IAUjC,YACE,UAII,EAAE;QAEN,MAAM,EAAE,gBAAgB,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;QAC3D,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,KAAK,KAAK,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,QAAQ,KAAK,KAAK,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,UAAU,IAAI,CAAC,CAAC,IAAU,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC1E,CAAC;IAQM,eAAe,CAAC,GAAW;QAEhC,OAAO,GAAG,CAAC,OAAO,CAEhB,6EAA6E,EAC7E,EAAE,CACH,CAAC;IACJ,CAAC;IASM,WAAW,CAAC,OAAgB;QACjC,IAAI,OAAO,OAAO,KAAK,QAAQ;YAAE,OAAO,KAAK,CAAC;QAG9C,MAAM,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAItD,MAAM,qBAAqB,GAAG,oBAAoB,CAAC;QAGnD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC3B,MAAM,eAAe,GAAG,aAAa,CAAC;YACtC,OAAO,eAAe,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC/C,CAAC;QAED,OAAO,qBAAqB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACrD,CAAC;IASM,MAAM,CAAC,KAA8B,EAAE,OAAgB;QAE5D,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB;YACrC,CAAC,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI;YACxC,CAAC,CAAC,EAAE,CAAC;QAEP,MAAM,gBAAgB,GACpB,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAGlE,MAAM,WAAW,GAAG,GAAG,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,EAAE,CAAC;QAGvF,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YAC7C,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACtE,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1,3 @@
1
+ export * from './console-logger.js';
2
+ export * from './types/index.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/logger/console-logger/index.ts"],"names":[],"mappings":"AASA,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from './console-logger.js';
2
+ export * from './types/index.js';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/logger/console-logger/index.ts"],"names":[],"mappings":"AASA,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,15 @@
1
+ export declare enum EConsoleLoggerLevel {
2
+ DEBUG = 0,
3
+ INFO = 1,
4
+ WARN = 2,
5
+ ERROR = 3
6
+ }
7
+ export type TConsoleLoggerLevelName = keyof typeof EConsoleLoggerLevel;
8
+ export type TConsoleLoggerOptionsDateFormatter = (date: Date) => string;
9
+ export interface IConsoleLoggerOptions {
10
+ includeTimestamp?: boolean;
11
+ colorize?: boolean;
12
+ logLevel?: TConsoleLoggerLevelName | EConsoleLoggerLevel;
13
+ dateFormat?: TConsoleLoggerOptionsDateFormatter;
14
+ }
15
+ //# sourceMappingURL=console-logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console-logger.d.ts","sourceRoot":"","sources":["../../../../../../src/logger/console-logger/types/console-logger.ts"],"names":[],"mappings":"AAaA,oBAAY,mBAAmB;IAC7B,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAKD,MAAM,MAAM,uBAAuB,GAAG,MAAM,OAAO,mBAAmB,CAAC;AAKvE,MAAM,MAAM,kCAAkC,GAAG,CAAC,IAAI,EAAE,IAAI,KAAK,MAAM,CAAC;AAExE,MAAM,WAAW,qBAAqB;IAKpC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAM3B,QAAQ,CAAC,EAAE,OAAO,CAAC;IASnB,QAAQ,CAAC,EAAE,uBAAuB,GAAG,mBAAmB,CAAC;IAczD,UAAU,CAAC,EAAE,kCAAkC,CAAC;CACjD"}