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.
- package/CHANGELOG.md +20 -0
- package/dist/cjs/src/logger/console-logger/console-logger.d.ts +14 -0
- package/dist/cjs/src/logger/console-logger/console-logger.d.ts.map +1 -0
- package/dist/cjs/src/logger/console-logger/console-logger.js +61 -0
- package/dist/cjs/src/logger/console-logger/console-logger.js.map +1 -0
- package/dist/cjs/src/logger/console-logger/console-message-formatter.d.ts +17 -0
- package/dist/cjs/src/logger/console-logger/console-message-formatter.d.ts.map +1 -0
- package/dist/cjs/src/logger/console-logger/console-message-formatter.js +48 -0
- package/dist/cjs/src/logger/console-logger/console-message-formatter.js.map +1 -0
- package/dist/cjs/src/logger/console-logger/index.d.ts +3 -0
- package/dist/cjs/src/logger/console-logger/index.d.ts.map +1 -0
- package/dist/cjs/src/logger/console-logger/index.js +19 -0
- package/dist/cjs/src/logger/console-logger/index.js.map +1 -0
- package/dist/cjs/src/logger/console-logger/types/console-logger.d.ts +15 -0
- package/dist/cjs/src/logger/console-logger/types/console-logger.d.ts.map +1 -0
- package/dist/cjs/src/logger/console-logger/types/console-logger.js +11 -0
- package/dist/cjs/src/logger/console-logger/types/console-logger.js.map +1 -0
- package/dist/cjs/src/logger/console-logger/types/index.d.ts +2 -0
- package/dist/cjs/src/logger/console-logger/types/index.d.ts.map +1 -0
- package/dist/cjs/src/logger/console-logger/types/index.js +18 -0
- package/dist/cjs/src/logger/console-logger/types/index.js.map +1 -0
- package/dist/cjs/src/logger/index.d.ts +1 -0
- package/dist/cjs/src/logger/index.d.ts.map +1 -1
- package/dist/cjs/src/logger/index.js +1 -0
- package/dist/cjs/src/logger/index.js.map +1 -1
- package/dist/cjs/src/logger/logger.d.ts +1 -1
- package/dist/cjs/src/logger/logger.d.ts.map +1 -1
- package/dist/cjs/src/logger/logger.js +27 -5
- package/dist/cjs/src/logger/logger.js.map +1 -1
- package/dist/cjs/src/logger/types/index.d.ts +1 -7
- package/dist/cjs/src/logger/types/index.d.ts.map +1 -1
- package/dist/cjs/src/logger/types/index.js +1 -1
- package/dist/cjs/src/logger/types/logger.d.ts +12 -0
- package/dist/cjs/src/logger/types/logger.d.ts.map +1 -0
- package/dist/cjs/src/logger/types/{config.js → logger.js} +1 -1
- package/dist/cjs/src/logger/types/logger.js.map +1 -0
- package/dist/cjs/src/redis-lock/redis-lock.d.ts +2 -0
- package/dist/cjs/src/redis-lock/redis-lock.d.ts.map +1 -1
- package/dist/cjs/src/redis-lock/redis-lock.js +114 -19
- package/dist/cjs/src/redis-lock/redis-lock.js.map +1 -1
- package/dist/cjs/src/worker/worker-callable.d.ts +2 -1
- package/dist/cjs/src/worker/worker-callable.d.ts.map +1 -1
- package/dist/cjs/src/worker/worker-callable.js +31 -3
- package/dist/cjs/src/worker/worker-callable.js.map +1 -1
- package/dist/cjs/src/worker/worker-resource-group.d.ts.map +1 -1
- package/dist/cjs/src/worker/worker-resource-group.js +100 -17
- package/dist/cjs/src/worker/worker-resource-group.js.map +1 -1
- package/dist/cjs/src/worker/worker-runnable.d.ts +2 -1
- package/dist/cjs/src/worker/worker-runnable.d.ts.map +1 -1
- package/dist/cjs/src/worker/worker-runnable.js +33 -4
- package/dist/cjs/src/worker/worker-runnable.js.map +1 -1
- package/dist/cjs/src/worker/worker.d.ts +4 -1
- package/dist/cjs/src/worker/worker.d.ts.map +1 -1
- package/dist/cjs/src/worker/worker.js +206 -57
- package/dist/cjs/src/worker/worker.js.map +1 -1
- package/dist/esm/src/logger/console-logger/console-logger.d.ts +14 -0
- package/dist/esm/src/logger/console-logger/console-logger.d.ts.map +1 -0
- package/dist/esm/src/logger/console-logger/console-logger.js +59 -0
- package/dist/esm/src/logger/console-logger/console-logger.js.map +1 -0
- package/dist/esm/src/logger/console-logger/console-message-formatter.d.ts +17 -0
- package/dist/esm/src/logger/console-logger/console-message-formatter.d.ts.map +1 -0
- package/dist/esm/src/logger/console-logger/console-message-formatter.js +47 -0
- package/dist/esm/src/logger/console-logger/console-message-formatter.js.map +1 -0
- package/dist/esm/src/logger/console-logger/index.d.ts +3 -0
- package/dist/esm/src/logger/console-logger/index.d.ts.map +1 -0
- package/dist/esm/src/logger/console-logger/index.js +3 -0
- package/dist/esm/src/logger/console-logger/index.js.map +1 -0
- package/dist/esm/src/logger/console-logger/types/console-logger.d.ts +15 -0
- package/dist/esm/src/logger/console-logger/types/console-logger.d.ts.map +1 -0
- package/dist/esm/src/logger/console-logger/types/console-logger.js +8 -0
- package/dist/esm/src/logger/console-logger/types/console-logger.js.map +1 -0
- package/dist/esm/src/logger/console-logger/types/index.d.ts +2 -0
- package/dist/esm/src/logger/console-logger/types/index.d.ts.map +1 -0
- package/dist/esm/src/logger/console-logger/types/index.js +2 -0
- package/dist/esm/src/logger/console-logger/types/index.js.map +1 -0
- package/dist/esm/src/logger/index.d.ts +1 -0
- package/dist/esm/src/logger/index.d.ts.map +1 -1
- package/dist/esm/src/logger/index.js +1 -0
- package/dist/esm/src/logger/index.js.map +1 -1
- package/dist/esm/src/logger/logger.d.ts +1 -1
- package/dist/esm/src/logger/logger.d.ts.map +1 -1
- package/dist/esm/src/logger/logger.js +25 -3
- package/dist/esm/src/logger/logger.js.map +1 -1
- package/dist/esm/src/logger/types/index.d.ts +1 -7
- package/dist/esm/src/logger/types/index.d.ts.map +1 -1
- package/dist/esm/src/logger/types/index.js +1 -1
- package/dist/esm/src/logger/types/logger.d.ts +12 -0
- package/dist/esm/src/logger/types/logger.d.ts.map +1 -0
- package/dist/esm/src/logger/types/logger.js +2 -0
- package/dist/esm/src/logger/types/logger.js.map +1 -0
- package/dist/esm/src/redis-lock/redis-lock.d.ts +2 -0
- package/dist/esm/src/redis-lock/redis-lock.d.ts.map +1 -1
- package/dist/esm/src/redis-lock/redis-lock.js +114 -19
- package/dist/esm/src/redis-lock/redis-lock.js.map +1 -1
- package/dist/esm/src/worker/worker-callable.d.ts +2 -1
- package/dist/esm/src/worker/worker-callable.d.ts.map +1 -1
- package/dist/esm/src/worker/worker-callable.js +31 -3
- package/dist/esm/src/worker/worker-callable.js.map +1 -1
- package/dist/esm/src/worker/worker-resource-group.d.ts.map +1 -1
- package/dist/esm/src/worker/worker-resource-group.js +100 -17
- package/dist/esm/src/worker/worker-resource-group.js.map +1 -1
- package/dist/esm/src/worker/worker-runnable.d.ts +2 -1
- package/dist/esm/src/worker/worker-runnable.d.ts.map +1 -1
- package/dist/esm/src/worker/worker-runnable.js +33 -4
- package/dist/esm/src/worker/worker-runnable.js.map +1 -1
- package/dist/esm/src/worker/worker.d.ts +4 -1
- package/dist/esm/src/worker/worker.d.ts.map +1 -1
- package/dist/esm/src/worker/worker.js +206 -55
- package/dist/esm/src/worker/worker.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/src/logger/types/config.d.ts +0 -4
- package/dist/cjs/src/logger/types/config.d.ts.map +0 -1
- package/dist/cjs/src/logger/types/config.js.map +0 -1
- package/dist/esm/src/logger/types/config.d.ts +0 -4
- package/dist/esm/src/logger/types/config.d.ts.map +0 -1
- package/dist/esm/src/logger/types/config.js +0 -2
- 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
|
-
|
|
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":";;;
|
|
1
|
+
{"version":3,"file":"worker-runnable.js","sourceRoot":"","sources":["../../../../src/worker/worker-runnable.ts"],"names":[],"mappings":";;;AAWA,uDAAuD;AACvD,gDAG2B;AAC3B,+CAI0B;AAC1B,2CAAqC;AAErC,MAAa,cACX,SAAQ,kBAAkB;IAM1B,YACE,cAAsB,EACtB,cAA+B,EAC/B,MAAgB;QAEhB,KAAK,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;QARrB,SAAI,GAAgB,sBAAW,CAAC,QAAQ,CAAC;QAS1D,IAAI,CAAC,MAAM,GAAG,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,IAAI,CAAC,MAAM,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,IAAI,sBAAW,EAAE,CAAC;QACrC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,cAAc,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,uCAAuC,EAAE;YACzD,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,IAAI,EAAE,sBAAW,CAAC,IAAI,CAAC,IAAI,CAAC;YAC5B,eAAe,EAAE,CAAC,CAAC,MAAM;YACzB,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM;SAC1D,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,EAAmB;QACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;QAExD,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QACrC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;YAE5D,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;YAC9D,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAE1B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1D,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,qCAA0B,CAAC,GAAG,EAAE,CAAC,CAAC;YAE3D,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1D,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAE1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,EAAE,uBAAuB,CAAC,CAAC;YAC3D,EAAE,EAAE,CAAC;QACP,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,IAAI,CAAC,EAAE,mBAAmB,CAAC,CAAC;YACpE,EAAE,CAAC,IAAI,oCAAyB,EAAE,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAEQ,QAAQ,CAAC,EAAmB;QACnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;QAE9D,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;YAE9D,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;YACpD,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE;gBACrB,IAAI,GAAG,EAAE,CAAC;oBACR,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,uBAAuB,IAAI,CAAC,EAAE,cAAc,GAAG,CAAC,OAAO,EAAE,EACzD;wBACE,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,KAAK,EAAE,GAAG,CAAC,KAAK;qBACjB,CACF,CAAC;gBACJ,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;gBAC1D,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;gBAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,EAAE,yBAAyB,CAAC,CAAC;gBAC7D,EAAE,EAAE,CAAC;YACP,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,IAAI,CAAC,EAAE,gBAAgB,CAAC,CAAC;YACrE,EAAE,CAAC,IAAI,iCAAsB,EAAE,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;CACF;AA5ED,wCA4EC"}
|
|
@@ -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
|
-
|
|
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":"
|
|
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("
|
|
9
|
-
const index_js_4 = require("./
|
|
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
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
worker
|
|
43
|
-
|
|
44
|
-
.
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
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
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
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
|
-
|
|
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.
|
|
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":";;;AASA,+BAA+B;AAC/B,mDAAwD;AAExD,8CAAsC;AACtC,gDAAiD;AACjD,gDAAsD;AACtD,+
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../src/worker/worker.ts"],"names":[],"mappings":";;;AASA,6CAAyC;AACzC,+BAA+B;AAC/B,mDAAwD;AAExD,8CAAsC;AACtC,gDAAiD;AACjD,iDAA4C;AAC5C,gDAAsD;AACtD,+CAO0B;AAO1B,MAAM,GAAG,GAAG,cAAG,CAAC,aAAa,EAAE,CAAC;AAUhC,MAAsB,MAGpB,SAAQ,uBAA0B;IAQlC,YAAsB,cAAsB,EAAE,cAAwB;QACpE,KAAK,EAAE,CAAC;QAJA,iBAAY,GAAwB,IAAI,CAAC;QAKjD,IAAI,CAAC,EAAE,GAAG,IAAA,wBAAU,GAAE,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,iBAAM,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACnD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+BAA+B,cAAc,EAAE,CAAC,CAAC;QAClE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,+BAA+B,EAAE;YACjD,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,QAAQ,EAAE,cAAc;YACxB,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM;SAC1D,CAAC,CAAC;IACL,CAAC;IAOD,KAAK;QACH,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAgBS,eAAe;QACvB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,MAAM,gBAAgB,GAAG,IAAA,cAAO,EAAC,GAAG,EAAE,kCAAkC,CAAC,CAAC;YAC1E,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mCAAmC,gBAAgB,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,6BAA6B,EAAE;gBAC/C,QAAQ,EAAE,IAAI,CAAC,cAAc;gBAC7B,IAAI,EAAE,sBAAW,CAAC,IAAI,CAAC,IAAI,CAAC;gBAC5B,gBAAgB;aACjB,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,IAAI,CAAC,YAAY,GAAG,IAAI,uBAAY,CAAC,gBAAgB,EAAE;oBACrD,UAAU,EAAE;wBACV,QAAQ,EAAE,IAAI,CAAC,cAAc;wBAC7B,cAAc,EAAE,IAAI,CAAC,cAAc;wBACnC,IAAI,EAAE,IAAI,CAAC,IAAI;qBAChB;oBACD,MAAM,EAAE,IAAI;iBACb,CAAC,CAAC;gBACH,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;gBAGxD,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;oBAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;oBACjE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;wBACnD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;wBACtC,IAAI,MAAM,EAAE,CAAC;4BACX,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;wBAC5B,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;gBAC5D,CAAC;gBAGD,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;oBAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;oBACjE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;wBACnD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;wBACtC,IAAI,MAAM,EAAE,CAAC;4BACX,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;wBAC5B,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;gBAC5D,CAAC;gBAED,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,GAAG,EAAE,EAAE;oBAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,yCAAyC,GAAG,CAAC,OAAO,EAAE,EACtD;wBACE,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,KAAK,EAAE,GAAG,CAAC,KAAK;wBAChB,IAAI,EAAE,GAAG,CAAC,IAAI;qBACf,CACF,CAAC;gBACJ,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;oBACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,8BAA8B,GAAG,CAAC,OAAO,EAAE,EAAE;wBAC7D,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,KAAK,EAAE,GAAG,CAAC,KAAK;wBAChB,IAAI,EAAE,GAAG,CAAC,IAAI;qBACf,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;oBACpC,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;wBACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;oBACpE,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,IAAI,EAAE,CAAC,CAAC;oBAC7D,CAAC;oBACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBAC3B,CAAC,CAAC,CAAC;YACL,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;gBACtE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mCAAmC,KAAK,CAAC,OAAO,EAAE,EAAE;oBACpE,KAAK,EAAE,KAAK,CAAC,OAAO;oBACpB,KAAK,EAAE,KAAK,CAAC,KAAK;iBACnB,CAAC,CAAC;gBACH,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAgBS,cAAc,CACtB,EAA6C;QAE7C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;YAE9D,MAAM,OAAO,GAAG,GAAG,EAAE;gBACnB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,2CAA2C,CAAC,CAAC;gBAC/D,MAAM;qBACH,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC;qBACpC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YACpC,CAAC,CAAC;YAEF,MAAM,QAAQ,GAAqB,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;gBAC/C,IAAI,GAAG,EAAE,CAAC;oBACR,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,GAAG,CAAC,OAAO,EAAE,EAAE;wBACzD,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,KAAK,EAAE,GAAG,CAAC,KAAK;wBAChB,IAAI,EAAE,GAAG,CAAC,IAAI;qBACf,CAAC,CAAC;oBACH,IAAI,EAAE,YAAY,MAAM,EAAE,CAAC;wBACzB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;wBACjD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;oBACjC,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;wBAC5C,EAAE,CAAC,GAAG,CAAC,CAAC;oBACV,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC;oBAC7C,IAAI,EAAE,YAAY,MAAM,EAAE,CAAC;wBACzB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;wBAChD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;oBACjC,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;wBAC9C,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;oBACjB,CAAC;gBACH,CAAC;YACH,CAAC,CAAC;YAEF,MAAM,SAAS,GAAG,CAAC,GAAqC,EAAE,EAAE;gBAC1D,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,iDAAiD,GAAG,CAAC,IAAI,EAAE,EAC3D;oBACE,IAAI,EAAE,GAAG,CAAC,IAAI;oBACd,OAAO,EAAE,GAAG,CAAC,IAAI,KAAK,SAAS;oBAC/B,QAAQ,EAAE,GAAG,CAAC,KAAK,KAAK,IAAI,IAAI,GAAG,CAAC,KAAK,KAAK,SAAS;iBACxD,CACF,CAAC;gBAEF,OAAO,EAAE,CAAC;gBAEV,IAAI,GAAG,CAAC,IAAI,KAAK,0CAA+B,CAAC,EAAE,EAAE,CAAC;oBACpD,MAAM,SAAS,GACb,0CAA+B,CAAC,GAAG,CAAC,IAAI,CAAC;wBACzC,qCAA0B,CAAC,GAAG,CAAC,IAAI,CAAC;wBACpC,WAAW,GAAG,CAAC,IAAI,GAAG,CAAC;oBAEzB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,SAAS,EAAE,EAAE;wBAC/D,IAAI,EAAE,GAAG,CAAC,IAAI;wBACd,SAAS;wBACT,KAAK,EAAE,GAAG,CAAC,KAAK;qBACjB,CAAC,CAAC;oBACH,QAAQ,CAAC,IAAI,4BAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;gBACvC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;oBACxD,QAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC,CAAC;YAEF,MAAM,MAAM,GAAG,CAAC,IAAY,EAAE,EAAE;gBAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+CAA+C,IAAI,EAAE,CAAC,CAAC;gBACxE,OAAO,EAAE,CAAC;gBACV,MAAM,GAAG,GAAG;oBACV,IAAI,EAAE,qCAA0B,CAAC,UAAU;oBAC3C,KAAK,EAAE,IAAI;iBACZ,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE;oBAC5C,QAAQ,EAAE,IAAI;oBACd,SAAS,EACP,qCAA0B,CAAC,qCAA0B,CAAC,UAAU,CAAC;iBACpE,CAAC,CAAC;gBACH,QAAQ,CAAC,IAAI,4BAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;YACvC,CAAC,CAAC;YAEF,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;YAClC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC5E,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,4CAA4C,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,EAAE,EAClG,GAAG,CACJ,CAAC;YACF,MAAM,GAAG,CAAC;QACZ,CAAC;IACH,CAAC;IAOD,WAAW,CAAC,OAAmC;QAC7C,IAAI,CAAC;YACH,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,qCAAqC,qCAA0B,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAC/E;gBACE,WAAW,EAAE,qCAA0B,CAAC,OAAO,CAAC,IAAI,CAAC;gBACrD,UAAU,EAAE,SAAS,IAAI,OAAO,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS;aAClE,CACF,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACtC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAE5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,8CAA8C,CAAC,CAAC;QACpE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;YACtE,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,4CAA4C,KAAK,CAAC,OAAO,EAAE,EAC3D;gBACE,KAAK,EAAE,KAAK,CAAC,OAAO;gBACpB,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,WAAW,EAAE,OAAO,CAAC,IAAI;aAC1B,CACF,CAAC;YACF,MAAM,GAAG,CAAC;QACZ,CAAC;IACH,CAAC;IAOD,QAAQ,CAAC,EAAmB;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;QAEhD,MAAM,QAAQ,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAC;YACpD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,EAAE,EAAE,CAAC;QACP,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAC;YAEtD,IAAI,CAAC,YAAY;iBACd,SAAS,EAAE;iBACX,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;gBACb,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,2CAA2C,IAAI,EAAE,CAAC,CAAC;gBACrE,QAAQ,EAAE,CAAC;YACb,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;gBACpB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oCAAoC,GAAG,CAAC,OAAO,EAAE,EAAE;oBACnE,KAAK,EAAE,GAAG,CAAC,OAAO;oBAClB,KAAK,EAAE,GAAG,CAAC,KAAK;iBACjB,CAAC,CAAC;gBACH,QAAQ,EAAE,CAAC;YACb,CAAC,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1D,EAAE,EAAE,CAAC;QACP,CAAC;IACH,CAAC;CACF;AA3TD,wBA2TC"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|