@decaf-ts/logging 0.3.6 → 0.3.7
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/README.md +223 -307
- package/dist/logging.cjs +87 -25
- package/dist/logging.esm.cjs +87 -26
- package/lib/LoggedClass.cjs +39 -1
- package/lib/LoggedClass.d.ts +38 -0
- package/lib/constants.cjs +2 -1
- package/lib/constants.d.ts +1 -0
- package/lib/decorators.cjs +11 -7
- package/lib/decorators.d.ts +13 -8
- package/lib/esm/LoggedClass.d.ts +38 -0
- package/lib/esm/LoggedClass.js +39 -1
- package/lib/esm/constants.d.ts +1 -0
- package/lib/esm/constants.js +2 -1
- package/lib/esm/decorators.d.ts +13 -8
- package/lib/esm/decorators.js +11 -7
- package/lib/esm/index.d.ts +8 -2
- package/lib/esm/index.js +9 -3
- package/lib/esm/logging.d.ts +8 -17
- package/lib/esm/logging.js +23 -17
- package/lib/esm/types.d.ts +15 -0
- package/lib/esm/types.js +1 -1
- package/lib/index.cjs +9 -3
- package/lib/index.d.ts +8 -2
- package/lib/logging.cjs +23 -17
- package/lib/logging.d.ts +8 -17
- package/lib/types.cjs +1 -1
- package/lib/types.d.ts +15 -0
- package/package.json +2 -1
package/lib/decorators.cjs
CHANGED
|
@@ -15,7 +15,6 @@ const logging_1 = require("./logging.cjs");
|
|
|
15
15
|
* @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)
|
|
16
16
|
* @return {Function} A method decorator that wraps the original method with logging
|
|
17
17
|
* @function log
|
|
18
|
-
* @category Decorators
|
|
19
18
|
* @mermaid
|
|
20
19
|
* sequenceDiagram
|
|
21
20
|
* participant Client
|
|
@@ -37,6 +36,7 @@ const logging_1 = require("./logging.cjs");
|
|
|
37
36
|
* Decorator->>Logger: log benchmark (if enabled)
|
|
38
37
|
* Decorator-->>Client: return result
|
|
39
38
|
* end
|
|
39
|
+
* @category Method Decorators
|
|
40
40
|
*/
|
|
41
41
|
function log(level = constants_1.LogLevel.info, benchmark = false, verbosity = 0) {
|
|
42
42
|
return function (target, propertyKey, descriptor) {
|
|
@@ -73,7 +73,7 @@ function log(level = constants_1.LogLevel.info, benchmark = false, verbosity = 0
|
|
|
73
73
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
74
74
|
* @return {Function} A method decorator that wraps the original method with debug logging
|
|
75
75
|
* @function debug
|
|
76
|
-
* @category Decorators
|
|
76
|
+
* @category Method Decorators
|
|
77
77
|
*/
|
|
78
78
|
function debug(benchmark = false) {
|
|
79
79
|
return log(constants_1.LogLevel.debug, benchmark);
|
|
@@ -84,7 +84,7 @@ function debug(benchmark = false) {
|
|
|
84
84
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
85
85
|
* @return {Function} A method decorator that wraps the original method with info logging
|
|
86
86
|
* @function info
|
|
87
|
-
* @category Decorators
|
|
87
|
+
* @category Method Decorators
|
|
88
88
|
*/
|
|
89
89
|
function info(benchmark = false) {
|
|
90
90
|
return log(constants_1.LogLevel.info, benchmark);
|
|
@@ -95,7 +95,7 @@ function info(benchmark = false) {
|
|
|
95
95
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
96
96
|
* @return {Function} A method decorator that wraps the original method with silly logging
|
|
97
97
|
* @function silly
|
|
98
|
-
* @category Decorators
|
|
98
|
+
* @category Method Decorators
|
|
99
99
|
*/
|
|
100
100
|
function silly(benchmark = false) {
|
|
101
101
|
return log(constants_1.LogLevel.silly, benchmark);
|
|
@@ -107,9 +107,13 @@ function silly(benchmark = false) {
|
|
|
107
107
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
108
108
|
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
109
109
|
* @function verbose
|
|
110
|
-
* @category Decorators
|
|
110
|
+
* @category Method Decorators
|
|
111
111
|
*/
|
|
112
|
-
function verbose(verbosity = 0, benchmark
|
|
112
|
+
function verbose(verbosity = 0, benchmark) {
|
|
113
|
+
if (typeof verbosity === "boolean") {
|
|
114
|
+
benchmark = verbosity;
|
|
115
|
+
verbosity = 0;
|
|
116
|
+
}
|
|
113
117
|
return log(constants_1.LogLevel.verbose, benchmark, verbosity);
|
|
114
118
|
}
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":";;AAkCA,kBAmCC;AAUD,sBAEC;AAUD,oBAEC;AAUD,sBAEC;AA4BD,0BAMC;AA3ID,+CAAuC;AACvC,2CAAoC;AAEpC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,SAAgB,GAAG,CACjB,QAAkB,oBAAQ,CAAC,IAAI,EAC/B,YAAqB,KAAK,EAC1B,SAAS,GAAG,CAAC;IAEb,OAAO,UACL,MAAW,EACX,WAAmB,EACnB,UAA8B;QAE9B,MAAM,GAAG,GAAG,iBAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpC,MAAM,cAAc,GAAG,UAAU,CAAC,KAAK,CAAC;QACxC,UAAU,CAAC,KAAK,GAAG,UAAU,GAAG,IAAW;YACzC,MAAM,CAAC,eAAe,IAAI,EAAE,EAAE,SAAS,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACzB,IAAI,GAAW,CAAC;YAChB,MAAM,MAAM,GAAQ,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACrD,IAAI,MAAM,YAAY,OAAO,EAAE,CAAC;gBAC9B,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;oBACvB,IAAI,SAAS,EAAE,CAAC;wBACd,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;wBACjB,IAAI,SAAS;4BAAE,MAAM,CAAC,gBAAgB,GAAG,GAAG,KAAK,IAAI,EAAE,SAAS,CAAC,CAAC;oBACpE,CAAC;oBACD,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC,CAAC;YACL,CAAC;YACD,IAAI,SAAS,EAAE,CAAC;gBACd,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACjB,IAAI,SAAS;oBAAE,MAAM,CAAC,gBAAgB,GAAG,GAAG,KAAK,IAAI,EAAE,SAAS,CAAC,CAAC;YACpE,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,KAAK,CAAC,YAAqB,KAAK;IAC9C,OAAO,GAAG,CAAC,oBAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxC,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,IAAI,CAAC,YAAqB,KAAK;IAC7C,OAAO,GAAG,CAAC,oBAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;AACvC,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,KAAK,CAAC,YAAqB,KAAK;IAC9C,OAAO,GAAG,CAAC,oBAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxC,CAAC;AAmBD;;;;;;;;GAQG;AACH,SAAgB,OAAO,CAAC,YAA8B,CAAC,EAAE,SAAmB;IAC1E,IAAI,OAAO,SAAS,KAAK,SAAS,EAAE,CAAC;QACnC,SAAS,GAAG,SAAS,CAAC;QACtB,SAAS,GAAG,CAAC,CAAC;IAChB,CAAC;IACD,OAAO,GAAG,CAAC,oBAAQ,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;AACrD,CAAC","sourcesContent":["import { LogLevel } from \"./constants\";\nimport { Logging } from \"./logging\";\n\n/**\n * @description Method decorator for logging function calls\n * @summary Creates a decorator that logs method calls with specified level, benchmarking, and verbosity\n * @param {LogLevel} level - The log level to use (default: LogLevel.info)\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)\n * @return {Function} A method decorator that wraps the original method with logging\n * @function log\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as log decorator\n *   participant Method as Original Method\n *   participant Logger as Logging instance\n *\n *   Client->>Decorator: call decorated method\n *   Decorator->>Logger: log method call\n *   Decorator->>Method: call original method\n *   alt result is Promise\n *     Method-->>Decorator: return Promise\n *     Decorator->>Decorator: attach then handler\n *     Note over Decorator: Promise resolves\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   else result is not Promise\n *     Method-->>Decorator: return result\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   end\n * @category Method Decorators\n */\nexport function log(\n  level: LogLevel = LogLevel.info,\n  benchmark: boolean = false,\n  verbosity = 0\n) {\n  return function (\n    target: any,\n    propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const log = Logging.for(target).for(target[propertyKey]);\n    const method = log[level].bind(log);\n    const originalMethod = descriptor.value;\n    descriptor.value = function (...args: any[]) {\n      method(`called with ${args}`, verbosity);\n      const start = Date.now();\n      let end: number;\n      const result: any = originalMethod.apply(this, args);\n      if (result instanceof Promise) {\n        return result.then((r) => {\n          if (benchmark) {\n            end = Date.now();\n            if (benchmark) method(`completed in ${end - start}ms`, verbosity);\n          }\n          return r;\n        });\n      }\n      if (benchmark) {\n        end = Date.now();\n        if (benchmark) method(`completed in ${end - start}ms`, verbosity);\n      }\n\n      return result;\n    };\n  };\n}\n\n/**\n * @description Method decorator for logging function calls with debug level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.debug\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with debug logging\n * @function debug\n * @category Method Decorators\n */\nexport function debug(benchmark: boolean = false) {\n  return log(LogLevel.debug, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with info level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.info\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with info logging\n * @function info\n * @category Method Decorators\n */\nexport function info(benchmark: boolean = false) {\n  return log(LogLevel.info, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with silly level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.silly\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with silly logging\n * @function silly\n * @category Method Decorators\n */\nexport function silly(benchmark: boolean = false) {\n  return log(LogLevel.silly, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n */\nexport function verbose(): void;\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @param {boolean} benchmark - Whether to log execution time\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n */\nexport function verbose(benchmark: boolean): void;\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @param {number} verbosity - The verbosity level for the log messages (default: 0)\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(verbosity: number | boolean = 0, benchmark?: boolean) {\n  if (typeof verbosity === \"boolean\") {\n    benchmark = verbosity;\n    verbosity = 0;\n  }\n  return log(LogLevel.verbose, benchmark, verbosity);\n}\n"]}
|
package/lib/decorators.d.ts
CHANGED
|
@@ -7,7 +7,6 @@ import { LogLevel } from "./constants";
|
|
|
7
7
|
* @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)
|
|
8
8
|
* @return {Function} A method decorator that wraps the original method with logging
|
|
9
9
|
* @function log
|
|
10
|
-
* @category Decorators
|
|
11
10
|
* @mermaid
|
|
12
11
|
* sequenceDiagram
|
|
13
12
|
* participant Client
|
|
@@ -29,6 +28,7 @@ import { LogLevel } from "./constants";
|
|
|
29
28
|
* Decorator->>Logger: log benchmark (if enabled)
|
|
30
29
|
* Decorator-->>Client: return result
|
|
31
30
|
* end
|
|
31
|
+
* @category Method Decorators
|
|
32
32
|
*/
|
|
33
33
|
export declare function log(level?: LogLevel, benchmark?: boolean, verbosity?: number): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
34
34
|
/**
|
|
@@ -37,7 +37,7 @@ export declare function log(level?: LogLevel, benchmark?: boolean, verbosity?: n
|
|
|
37
37
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
38
38
|
* @return {Function} A method decorator that wraps the original method with debug logging
|
|
39
39
|
* @function debug
|
|
40
|
-
* @category Decorators
|
|
40
|
+
* @category Method Decorators
|
|
41
41
|
*/
|
|
42
42
|
export declare function debug(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
43
43
|
/**
|
|
@@ -46,7 +46,7 @@ export declare function debug(benchmark?: boolean): (target: any, propertyKey: s
|
|
|
46
46
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
47
47
|
* @return {Function} A method decorator that wraps the original method with info logging
|
|
48
48
|
* @function info
|
|
49
|
-
* @category Decorators
|
|
49
|
+
* @category Method Decorators
|
|
50
50
|
*/
|
|
51
51
|
export declare function info(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
52
52
|
/**
|
|
@@ -55,16 +55,21 @@ export declare function info(benchmark?: boolean): (target: any, propertyKey: st
|
|
|
55
55
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
56
56
|
* @return {Function} A method decorator that wraps the original method with silly logging
|
|
57
57
|
* @function silly
|
|
58
|
-
* @category Decorators
|
|
58
|
+
* @category Method Decorators
|
|
59
59
|
*/
|
|
60
60
|
export declare function silly(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
61
61
|
/**
|
|
62
62
|
* @description Method decorator for logging function calls with verbose level
|
|
63
63
|
* @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
|
|
64
|
-
* @param {number} verbosity - The verbosity level for the log messages (default: 0)
|
|
65
|
-
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
66
64
|
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
67
65
|
* @function verbose
|
|
68
|
-
* @category Decorators
|
|
69
66
|
*/
|
|
70
|
-
export declare function verbose(
|
|
67
|
+
export declare function verbose(): void;
|
|
68
|
+
/**
|
|
69
|
+
* @description Method decorator for logging function calls with verbose level
|
|
70
|
+
* @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
|
|
71
|
+
* @param {boolean} benchmark - Whether to log execution time
|
|
72
|
+
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
73
|
+
* @function verbose
|
|
74
|
+
*/
|
|
75
|
+
export declare function verbose(benchmark: boolean): void;
|
package/lib/esm/LoggedClass.d.ts
CHANGED
|
@@ -1,5 +1,43 @@
|
|
|
1
1
|
import { Logger } from "./types";
|
|
2
|
+
/**
|
|
3
|
+
* @description Base class that provides a ready-to-use logger instance
|
|
4
|
+
* @summary LoggedClass is a convenience abstract class that injects a type-safe logger
|
|
5
|
+
* into derived classes through a protected getter. Subclasses can directly access
|
|
6
|
+
* this.log to emit messages without manually creating a logger. This promotes
|
|
7
|
+
* consistent, context-aware logging across the codebase.
|
|
8
|
+
* @param {void} [constructor] - No constructor arguments; subclasses may define their own
|
|
9
|
+
* @class LoggedClass
|
|
10
|
+
* @example
|
|
11
|
+
* class UserService extends LoggedClass {
|
|
12
|
+
* create(user: User) {
|
|
13
|
+
* this.log.info(`Creating user ${user.id}`);
|
|
14
|
+
* }
|
|
15
|
+
* }
|
|
16
|
+
*
|
|
17
|
+
* const svc = new UserService();
|
|
18
|
+
* svc.create({ id: "42" });
|
|
19
|
+
* @mermaid
|
|
20
|
+
* sequenceDiagram
|
|
21
|
+
* participant Client
|
|
22
|
+
* participant Instance as Subclass Instance
|
|
23
|
+
* participant Getter as LoggedClass.log
|
|
24
|
+
* participant Logging as Logging
|
|
25
|
+
* participant Logger as Logger
|
|
26
|
+
*
|
|
27
|
+
* Client->>Instance: call someMethod()
|
|
28
|
+
* Instance->>Getter: access this.log
|
|
29
|
+
* Getter->>Logging: Logging.for(this)
|
|
30
|
+
* Logging-->>Getter: return Logger
|
|
31
|
+
* Getter-->>Instance: return Logger
|
|
32
|
+
* Instance->>Logger: info/debug/error(...)
|
|
33
|
+
*/
|
|
2
34
|
export declare abstract class LoggedClass {
|
|
35
|
+
/**
|
|
36
|
+
* @description Lazily provides a context-aware logger for the current instance
|
|
37
|
+
* @summary Uses Logging.for(this) to create a logger whose context is the
|
|
38
|
+
* subclass name, allowing uniform and structured logs from any inheriting class.
|
|
39
|
+
* @return {Logger} A logger bound to the subclass context
|
|
40
|
+
*/
|
|
3
41
|
protected get log(): Logger;
|
|
4
42
|
protected constructor();
|
|
5
43
|
}
|
package/lib/esm/LoggedClass.js
CHANGED
|
@@ -1,8 +1,46 @@
|
|
|
1
1
|
import { Logging } from "./logging.js";
|
|
2
|
+
/**
|
|
3
|
+
* @description Base class that provides a ready-to-use logger instance
|
|
4
|
+
* @summary LoggedClass is a convenience abstract class that injects a type-safe logger
|
|
5
|
+
* into derived classes through a protected getter. Subclasses can directly access
|
|
6
|
+
* this.log to emit messages without manually creating a logger. This promotes
|
|
7
|
+
* consistent, context-aware logging across the codebase.
|
|
8
|
+
* @param {void} [constructor] - No constructor arguments; subclasses may define their own
|
|
9
|
+
* @class LoggedClass
|
|
10
|
+
* @example
|
|
11
|
+
* class UserService extends LoggedClass {
|
|
12
|
+
* create(user: User) {
|
|
13
|
+
* this.log.info(`Creating user ${user.id}`);
|
|
14
|
+
* }
|
|
15
|
+
* }
|
|
16
|
+
*
|
|
17
|
+
* const svc = new UserService();
|
|
18
|
+
* svc.create({ id: "42" });
|
|
19
|
+
* @mermaid
|
|
20
|
+
* sequenceDiagram
|
|
21
|
+
* participant Client
|
|
22
|
+
* participant Instance as Subclass Instance
|
|
23
|
+
* participant Getter as LoggedClass.log
|
|
24
|
+
* participant Logging as Logging
|
|
25
|
+
* participant Logger as Logger
|
|
26
|
+
*
|
|
27
|
+
* Client->>Instance: call someMethod()
|
|
28
|
+
* Instance->>Getter: access this.log
|
|
29
|
+
* Getter->>Logging: Logging.for(this)
|
|
30
|
+
* Logging-->>Getter: return Logger
|
|
31
|
+
* Getter-->>Instance: return Logger
|
|
32
|
+
* Instance->>Logger: info/debug/error(...)
|
|
33
|
+
*/
|
|
2
34
|
export class LoggedClass {
|
|
35
|
+
/**
|
|
36
|
+
* @description Lazily provides a context-aware logger for the current instance
|
|
37
|
+
* @summary Uses Logging.for(this) to create a logger whose context is the
|
|
38
|
+
* subclass name, allowing uniform and structured logs from any inheriting class.
|
|
39
|
+
* @return {Logger} A logger bound to the subclass context
|
|
40
|
+
*/
|
|
3
41
|
get log() {
|
|
4
42
|
return Logging.for(this);
|
|
5
43
|
}
|
|
6
44
|
constructor() { }
|
|
7
45
|
}
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9nZ2VkQ2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvTG9nZ2VkQ2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxxQkFBa0I7QUFHcEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0ErQkc7QUFDSCxNQUFNLE9BQWdCLFdBQVc7SUFDL0I7Ozs7O09BS0c7SUFDSCxJQUFjLEdBQUc7UUFDZixPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBVyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGdCQUF5QixDQUFDO0NBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTG9nZ2luZyB9IGZyb20gXCIuL2xvZ2dpbmdcIjtcbmltcG9ydCB7IExvZ2dlciB9IGZyb20gXCIuL3R5cGVzXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEJhc2UgY2xhc3MgdGhhdCBwcm92aWRlcyBhIHJlYWR5LXRvLXVzZSBsb2dnZXIgaW5zdGFuY2VcbiAqIEBzdW1tYXJ5IExvZ2dlZENsYXNzIGlzIGEgY29udmVuaWVuY2UgYWJzdHJhY3QgY2xhc3MgdGhhdCBpbmplY3RzIGEgdHlwZS1zYWZlIGxvZ2dlclxuICogaW50byBkZXJpdmVkIGNsYXNzZXMgdGhyb3VnaCBhIHByb3RlY3RlZCBnZXR0ZXIuIFN1YmNsYXNzZXMgY2FuIGRpcmVjdGx5IGFjY2Vzc1xuICogdGhpcy5sb2cgdG8gZW1pdCBtZXNzYWdlcyB3aXRob3V0IG1hbnVhbGx5IGNyZWF0aW5nIGEgbG9nZ2VyLiBUaGlzIHByb21vdGVzXG4gKiBjb25zaXN0ZW50LCBjb250ZXh0LWF3YXJlIGxvZ2dpbmcgYWNyb3NzIHRoZSBjb2RlYmFzZS5cbiAqIEBwYXJhbSB7dm9pZH0gW2NvbnN0cnVjdG9yXSAtIE5vIGNvbnN0cnVjdG9yIGFyZ3VtZW50czsgc3ViY2xhc3NlcyBtYXkgZGVmaW5lIHRoZWlyIG93blxuICogQGNsYXNzIExvZ2dlZENsYXNzXG4gKiBAZXhhbXBsZVxuICogY2xhc3MgVXNlclNlcnZpY2UgZXh0ZW5kcyBMb2dnZWRDbGFzcyB7XG4gKiAgIGNyZWF0ZSh1c2VyOiBVc2VyKSB7XG4gKiAgICAgdGhpcy5sb2cuaW5mbyhgQ3JlYXRpbmcgdXNlciAke3VzZXIuaWR9YCk7XG4gKiAgIH1cbiAqIH1cbiAqXG4gKiBjb25zdCBzdmMgPSBuZXcgVXNlclNlcnZpY2UoKTtcbiAqIHN2Yy5jcmVhdGUoeyBpZDogXCI0MlwiIH0pO1xuICogQG1lcm1haWRcbiAqIHNlcXVlbmNlRGlhZ3JhbVxuICogICBwYXJ0aWNpcGFudCBDbGllbnRcbiAqICAgcGFydGljaXBhbnQgSW5zdGFuY2UgYXMgU3ViY2xhc3MgSW5zdGFuY2VcbiAqICAgcGFydGljaXBhbnQgR2V0dGVyIGFzIExvZ2dlZENsYXNzLmxvZ1xuICogICBwYXJ0aWNpcGFudCBMb2dnaW5nIGFzIExvZ2dpbmdcbiAqICAgcGFydGljaXBhbnQgTG9nZ2VyIGFzIExvZ2dlclxuICpcbiAqICAgQ2xpZW50LT4+SW5zdGFuY2U6IGNhbGwgc29tZU1ldGhvZCgpXG4gKiAgIEluc3RhbmNlLT4+R2V0dGVyOiBhY2Nlc3MgdGhpcy5sb2dcbiAqICAgR2V0dGVyLT4+TG9nZ2luZzogTG9nZ2luZy5mb3IodGhpcylcbiAqICAgTG9nZ2luZy0tPj5HZXR0ZXI6IHJldHVybiBMb2dnZXJcbiAqICAgR2V0dGVyLS0+Pkluc3RhbmNlOiByZXR1cm4gTG9nZ2VyXG4gKiAgIEluc3RhbmNlLT4+TG9nZ2VyOiBpbmZvL2RlYnVnL2Vycm9yKC4uLilcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIExvZ2dlZENsYXNzIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBMYXppbHkgcHJvdmlkZXMgYSBjb250ZXh0LWF3YXJlIGxvZ2dlciBmb3IgdGhlIGN1cnJlbnQgaW5zdGFuY2VcbiAgICogQHN1bW1hcnkgVXNlcyBMb2dnaW5nLmZvcih0aGlzKSB0byBjcmVhdGUgYSBsb2dnZXIgd2hvc2UgY29udGV4dCBpcyB0aGVcbiAgICogc3ViY2xhc3MgbmFtZSwgYWxsb3dpbmcgdW5pZm9ybSBhbmQgc3RydWN0dXJlZCBsb2dzIGZyb20gYW55IGluaGVyaXRpbmcgY2xhc3MuXG4gICAqIEByZXR1cm4ge0xvZ2dlcn0gQSBsb2dnZXIgYm91bmQgdG8gdGhlIHN1YmNsYXNzIGNvbnRleHRcbiAgICovXG4gIHByb3RlY3RlZCBnZXQgbG9nKCk6IExvZ2dlciB7XG4gICAgcmV0dXJuIExvZ2dpbmcuZm9yKHRoaXMgYXMgYW55KTtcbiAgfVxuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
|
package/lib/esm/constants.d.ts
CHANGED
package/lib/esm/constants.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
* @description Enum for log levels.
|
|
3
3
|
* @summary Defines different levels of logging for the application.
|
|
4
4
|
* @enum {string}
|
|
5
|
+
* @readonly
|
|
5
6
|
* @memberOf module:Logging
|
|
6
7
|
*/
|
|
7
8
|
export var LogLevel;
|
|
@@ -130,4 +131,4 @@ export const DefaultLoggingConfig = {
|
|
|
130
131
|
context: true,
|
|
131
132
|
theme: DefaultTheme,
|
|
132
133
|
};
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AACH,MAAM,CAAN,IAAY,QAWX;AAXD,WAAY,QAAQ;IAClB,sDAAsD;IACtD,2BAAe,CAAA;IACf,kEAAkE;IAClE,yBAAa,CAAA;IACb,uCAAuC;IACvC,+BAAmB,CAAA;IACnB,kCAAkC;IAClC,2BAAe,CAAA;IACf,4CAA4C;IAC5C,2BAAe,CAAA;AACjB,CAAC,EAXW,QAAQ,KAAR,QAAQ,QAWnB;AAED;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,CAAC;IACR,KAAK,EAAE,CAAC;CACT,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAN,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,4CAA4C;IAC5C,0BAAW,CAAA;IACX,sCAAsC;IACtC,4BAAa,CAAA;AACf,CAAC,EALW,WAAW,KAAX,WAAW,QAKtB;AAED;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,CAAC,MAAM,YAAY,GAAU;IACjC,KAAK,EAAE;QACL,EAAE,EAAE,EAAE;KACP;IACD,EAAE,EAAE;QACF,EAAE,EAAE,EAAE;KACP;IACD,KAAK,EAAE,EAAE;IACT,SAAS,EAAE,EAAE;IACb,OAAO,EAAE;QACP,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;SACP;KACF;IACD,MAAM,EAAE,EAAE;IACV,QAAQ,EAAE;QACR,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,IAAI,EAAE,EAAE;QACR,OAAO,EAAE,EAAE;QACX,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;SACP;KACF;CACF,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAkB;IACjD,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,QAAQ,CAAC,IAAI;IACpB,QAAQ,EAAE,IAAI;IACd,IAAI,EAAE,WAAW,CAAC,GAAG;IACrB,KAAK,EAAE,KAAK;IACZ,gBAAgB,EAAE,GAAG;IACrB,SAAS,EAAE,KAAK;IAChB,SAAS,EAAE,IAAI;IACf,eAAe,EAAE,cAAc;IAC/B,OAAO,EAAE,IAAI;IACb,KAAK,EAAE,YAAY;CACpB,CAAC","sourcesContent":["import { LoggingConfig, Theme } from \"./types\";\n\n/**\n * @description Enum for log levels.\n * @summary Defines different levels of logging for the application.\n * @enum {string}\n * @readonly\n * @memberOf module:Logging\n */\nexport enum LogLevel {\n  /** Error events that are likely to cause problems. */\n  error = \"error\",\n  /** Routine information, such as ongoing status or performance. */\n  info = \"info\",\n  /** Additional relevant information. */\n  verbose = \"verbose\",\n  /** Debug or trace information. */\n  debug = \"debug\",\n  /** way too verbose or silly information. */\n  silly = \"silly\",\n}\n\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @const NumericLogLevels\n * @property {number} error - Numeric value for error level (2).\n * @property {number} info - Numeric value for info level (4).\n * @property {number} verbose - Numeric value for verbose level (6).\n * @property {number} debug - Numeric value for debug level (7).\n * @property {number} silly - Numeric value for silly level (9).\n * @memberOf module:Logging\n */\nexport const NumericLogLevels = {\n  error: 2,\n  info: 4,\n  verbose: 6,\n  debug: 7,\n  silly: 9,\n};\n\n/**\n * @description Enum for logging output modes.\n * @summary Defines different output formats for log messages.\n * @enum {string}\n * @memberOf module:Logging\n */\nexport enum LoggingMode {\n  /** Raw text format for human readability */\n  RAW = \"raw\",\n  /** JSON format for machine parsing */\n  JSON = \"json\",\n}\n\n/**\n * @description Default theme for styling log output.\n * @summary Defines the default color and style settings for various components of log messages.\n * @const DefaultTheme\n * @typedef {Theme} DefaultTheme\n * @property {Object} class - Styling for class names.\n * @property {number} class.fg - Foreground color code for class names (34).\n * @property {Object} id - Styling for identifiers.\n * @property {number} id.fg - Foreground color code for identifiers (36).\n * @property {Object} stack - Styling for stack traces (empty object).\n * @property {Object} timestamp - Styling for timestamps (empty object).\n * @property {Object} message - Styling for different types of messages.\n * @property {Object} message.error - Styling for error messages.\n * @property {number} message.error.fg - Foreground color code for error messages (31).\n * @property {Object} method - Styling for method names (empty object).\n * @property {Object} logLevel - Styling for different log levels.\n * @property {Object} logLevel.error - Styling for error level logs.\n * @property {number} logLevel.error.fg - Foreground color code for error level logs (31).\n * @property {string[]} logLevel.error.style - Style attributes for error level logs ([\"bold\"]).\n * @property {Object} logLevel.info - Styling for info level logs (empty object).\n * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).\n * @property {Object} logLevel.debug - Styling for debug level logs.\n * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (33).\n * @memberOf module:Logging\n */\nexport const DefaultTheme: Theme = {\n  class: {\n    fg: 34,\n  },\n  id: {\n    fg: 36,\n  },\n  stack: {},\n  timestamp: {},\n  message: {\n    error: {\n      fg: 31,\n    },\n  },\n  method: {},\n  logLevel: {\n    error: {\n      fg: 31,\n      style: [\"bold\"],\n    },\n    info: {},\n    verbose: {},\n    debug: {\n      fg: 33,\n    },\n  },\n};\n\n/**\n * @description Default configuration for logging.\n * @summary Defines the default settings for the logging system, including verbosity, log level, styling, and timestamp format.\n * @const DefaultLoggingConfig\n * @typedef {LoggingConfig} DefaultLoggingConfig\n * @property {number} verbose - Verbosity level (0).\n * @property {LogLevel} level - Default log level (LogLevel.info).\n * @property {boolean} logLevel - Whether to display log level in output (true).\n * @property {LoggingMode} mode - Output format mode (LoggingMode.RAW).\n * @property {boolean} style - Whether to apply styling to log output (false).\n * @property {string} separator - Separator between log components (\" - \").\n * @property {boolean} timestamp - Whether to include timestamps in log messages (true).\n * @property {string} timestampFormat - Format for timestamps (\"HH:mm:ss.SSS\").\n * @property {boolean} context - Whether to include context information in log messages (true).\n * @property {Theme} theme - The theme to use for styling log messages (DefaultTheme).\n * @memberOf module:Logging\n */\nexport const DefaultLoggingConfig: LoggingConfig = {\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  mode: LoggingMode.RAW,\n  style: false,\n  contextSeparator: \".\",\n  separator: \" - \",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  theme: DefaultTheme,\n};\n"]}
|
package/lib/esm/decorators.d.ts
CHANGED
|
@@ -7,7 +7,6 @@ import { LogLevel } from "./constants";
|
|
|
7
7
|
* @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)
|
|
8
8
|
* @return {Function} A method decorator that wraps the original method with logging
|
|
9
9
|
* @function log
|
|
10
|
-
* @category Decorators
|
|
11
10
|
* @mermaid
|
|
12
11
|
* sequenceDiagram
|
|
13
12
|
* participant Client
|
|
@@ -29,6 +28,7 @@ import { LogLevel } from "./constants";
|
|
|
29
28
|
* Decorator->>Logger: log benchmark (if enabled)
|
|
30
29
|
* Decorator-->>Client: return result
|
|
31
30
|
* end
|
|
31
|
+
* @category Method Decorators
|
|
32
32
|
*/
|
|
33
33
|
export declare function log(level?: LogLevel, benchmark?: boolean, verbosity?: number): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
34
34
|
/**
|
|
@@ -37,7 +37,7 @@ export declare function log(level?: LogLevel, benchmark?: boolean, verbosity?: n
|
|
|
37
37
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
38
38
|
* @return {Function} A method decorator that wraps the original method with debug logging
|
|
39
39
|
* @function debug
|
|
40
|
-
* @category Decorators
|
|
40
|
+
* @category Method Decorators
|
|
41
41
|
*/
|
|
42
42
|
export declare function debug(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
43
43
|
/**
|
|
@@ -46,7 +46,7 @@ export declare function debug(benchmark?: boolean): (target: any, propertyKey: s
|
|
|
46
46
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
47
47
|
* @return {Function} A method decorator that wraps the original method with info logging
|
|
48
48
|
* @function info
|
|
49
|
-
* @category Decorators
|
|
49
|
+
* @category Method Decorators
|
|
50
50
|
*/
|
|
51
51
|
export declare function info(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
52
52
|
/**
|
|
@@ -55,16 +55,21 @@ export declare function info(benchmark?: boolean): (target: any, propertyKey: st
|
|
|
55
55
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
56
56
|
* @return {Function} A method decorator that wraps the original method with silly logging
|
|
57
57
|
* @function silly
|
|
58
|
-
* @category Decorators
|
|
58
|
+
* @category Method Decorators
|
|
59
59
|
*/
|
|
60
60
|
export declare function silly(benchmark?: boolean): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => void;
|
|
61
61
|
/**
|
|
62
62
|
* @description Method decorator for logging function calls with verbose level
|
|
63
63
|
* @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
|
|
64
|
-
* @param {number} verbosity - The verbosity level for the log messages (default: 0)
|
|
65
|
-
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
66
64
|
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
67
65
|
* @function verbose
|
|
68
|
-
* @category Decorators
|
|
69
66
|
*/
|
|
70
|
-
export declare function verbose(
|
|
67
|
+
export declare function verbose(): void;
|
|
68
|
+
/**
|
|
69
|
+
* @description Method decorator for logging function calls with verbose level
|
|
70
|
+
* @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
|
|
71
|
+
* @param {boolean} benchmark - Whether to log execution time
|
|
72
|
+
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
73
|
+
* @function verbose
|
|
74
|
+
*/
|
|
75
|
+
export declare function verbose(benchmark: boolean): void;
|
package/lib/esm/decorators.js
CHANGED
|
@@ -8,7 +8,6 @@ import { Logging } from "./logging.js";
|
|
|
8
8
|
* @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)
|
|
9
9
|
* @return {Function} A method decorator that wraps the original method with logging
|
|
10
10
|
* @function log
|
|
11
|
-
* @category Decorators
|
|
12
11
|
* @mermaid
|
|
13
12
|
* sequenceDiagram
|
|
14
13
|
* participant Client
|
|
@@ -30,6 +29,7 @@ import { Logging } from "./logging.js";
|
|
|
30
29
|
* Decorator->>Logger: log benchmark (if enabled)
|
|
31
30
|
* Decorator-->>Client: return result
|
|
32
31
|
* end
|
|
32
|
+
* @category Method Decorators
|
|
33
33
|
*/
|
|
34
34
|
export function log(level = LogLevel.info, benchmark = false, verbosity = 0) {
|
|
35
35
|
return function (target, propertyKey, descriptor) {
|
|
@@ -66,7 +66,7 @@ export function log(level = LogLevel.info, benchmark = false, verbosity = 0) {
|
|
|
66
66
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
67
67
|
* @return {Function} A method decorator that wraps the original method with debug logging
|
|
68
68
|
* @function debug
|
|
69
|
-
* @category Decorators
|
|
69
|
+
* @category Method Decorators
|
|
70
70
|
*/
|
|
71
71
|
export function debug(benchmark = false) {
|
|
72
72
|
return log(LogLevel.debug, benchmark);
|
|
@@ -77,7 +77,7 @@ export function debug(benchmark = false) {
|
|
|
77
77
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
78
78
|
* @return {Function} A method decorator that wraps the original method with info logging
|
|
79
79
|
* @function info
|
|
80
|
-
* @category Decorators
|
|
80
|
+
* @category Method Decorators
|
|
81
81
|
*/
|
|
82
82
|
export function info(benchmark = false) {
|
|
83
83
|
return log(LogLevel.info, benchmark);
|
|
@@ -88,7 +88,7 @@ export function info(benchmark = false) {
|
|
|
88
88
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
89
89
|
* @return {Function} A method decorator that wraps the original method with silly logging
|
|
90
90
|
* @function silly
|
|
91
|
-
* @category Decorators
|
|
91
|
+
* @category Method Decorators
|
|
92
92
|
*/
|
|
93
93
|
export function silly(benchmark = false) {
|
|
94
94
|
return log(LogLevel.silly, benchmark);
|
|
@@ -100,9 +100,13 @@ export function silly(benchmark = false) {
|
|
|
100
100
|
* @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
|
|
101
101
|
* @return {Function} A method decorator that wraps the original method with verbose logging
|
|
102
102
|
* @function verbose
|
|
103
|
-
* @category Decorators
|
|
103
|
+
* @category Method Decorators
|
|
104
104
|
*/
|
|
105
|
-
export function verbose(verbosity = 0, benchmark
|
|
105
|
+
export function verbose(verbosity = 0, benchmark) {
|
|
106
|
+
if (typeof verbosity === "boolean") {
|
|
107
|
+
benchmark = verbosity;
|
|
108
|
+
verbosity = 0;
|
|
109
|
+
}
|
|
106
110
|
return log(LogLevel.verbose, benchmark, verbosity);
|
|
107
111
|
}
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,uBAAoB;AACvC,OAAO,EAAE,OAAO,EAAE,qBAAkB;AAEpC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,MAAM,UAAU,GAAG,CACjB,QAAkB,QAAQ,CAAC,IAAI,EAC/B,YAAqB,KAAK,EAC1B,SAAS,GAAG,CAAC;IAEb,OAAO,UACL,MAAW,EACX,WAAmB,EACnB,UAA8B;QAE9B,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpC,MAAM,cAAc,GAAG,UAAU,CAAC,KAAK,CAAC;QACxC,UAAU,CAAC,KAAK,GAAG,UAAU,GAAG,IAAW;YACzC,MAAM,CAAC,eAAe,IAAI,EAAE,EAAE,SAAS,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACzB,IAAI,GAAW,CAAC;YAChB,MAAM,MAAM,GAAQ,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACrD,IAAI,MAAM,YAAY,OAAO,EAAE,CAAC;gBAC9B,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;oBACvB,IAAI,SAAS,EAAE,CAAC;wBACd,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;wBACjB,IAAI,SAAS;4BAAE,MAAM,CAAC,gBAAgB,GAAG,GAAG,KAAK,IAAI,EAAE,SAAS,CAAC,CAAC;oBACpE,CAAC;oBACD,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC,CAAC;YACL,CAAC;YACD,IAAI,SAAS,EAAE,CAAC;gBACd,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACjB,IAAI,SAAS;oBAAE,MAAM,CAAC,gBAAgB,GAAG,GAAG,KAAK,IAAI,EAAE,SAAS,CAAC,CAAC;YACpE,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,KAAK,CAAC,YAAqB,KAAK;IAC9C,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxC,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,IAAI,CAAC,YAAqB,KAAK;IAC7C,OAAO,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;AACvC,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,KAAK,CAAC,YAAqB,KAAK;IAC9C,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxC,CAAC;AAmBD;;;;;;;;GAQG;AACH,MAAM,UAAU,OAAO,CAAC,YAA8B,CAAC,EAAE,SAAmB;IAC1E,IAAI,OAAO,SAAS,KAAK,SAAS,EAAE,CAAC;QACnC,SAAS,GAAG,SAAS,CAAC;QACtB,SAAS,GAAG,CAAC,CAAC;IAChB,CAAC;IACD,OAAO,GAAG,CAAC,QAAQ,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;AACrD,CAAC","sourcesContent":["import { LogLevel } from \"./constants\";\nimport { Logging } from \"./logging\";\n\n/**\n * @description Method decorator for logging function calls\n * @summary Creates a decorator that logs method calls with specified level, benchmarking, and verbosity\n * @param {LogLevel} level - The log level to use (default: LogLevel.info)\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)\n * @return {Function} A method decorator that wraps the original method with logging\n * @function log\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as log decorator\n *   participant Method as Original Method\n *   participant Logger as Logging instance\n *\n *   Client->>Decorator: call decorated method\n *   Decorator->>Logger: log method call\n *   Decorator->>Method: call original method\n *   alt result is Promise\n *     Method-->>Decorator: return Promise\n *     Decorator->>Decorator: attach then handler\n *     Note over Decorator: Promise resolves\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   else result is not Promise\n *     Method-->>Decorator: return result\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   end\n * @category Method Decorators\n */\nexport function log(\n  level: LogLevel = LogLevel.info,\n  benchmark: boolean = false,\n  verbosity = 0\n) {\n  return function (\n    target: any,\n    propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const log = Logging.for(target).for(target[propertyKey]);\n    const method = log[level].bind(log);\n    const originalMethod = descriptor.value;\n    descriptor.value = function (...args: any[]) {\n      method(`called with ${args}`, verbosity);\n      const start = Date.now();\n      let end: number;\n      const result: any = originalMethod.apply(this, args);\n      if (result instanceof Promise) {\n        return result.then((r) => {\n          if (benchmark) {\n            end = Date.now();\n            if (benchmark) method(`completed in ${end - start}ms`, verbosity);\n          }\n          return r;\n        });\n      }\n      if (benchmark) {\n        end = Date.now();\n        if (benchmark) method(`completed in ${end - start}ms`, verbosity);\n      }\n\n      return result;\n    };\n  };\n}\n\n/**\n * @description Method decorator for logging function calls with debug level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.debug\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with debug logging\n * @function debug\n * @category Method Decorators\n */\nexport function debug(benchmark: boolean = false) {\n  return log(LogLevel.debug, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with info level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.info\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with info logging\n * @function info\n * @category Method Decorators\n */\nexport function info(benchmark: boolean = false) {\n  return log(LogLevel.info, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with silly level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.silly\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with silly logging\n * @function silly\n * @category Method Decorators\n */\nexport function silly(benchmark: boolean = false) {\n  return log(LogLevel.silly, benchmark);\n}\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n */\nexport function verbose(): void;\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @param {boolean} benchmark - Whether to log execution time\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n */\nexport function verbose(benchmark: boolean): void;\n\n/**\n * @description Method decorator for logging function calls with verbose level\n * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity\n * @param {number} verbosity - The verbosity level for the log messages (default: 0)\n * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)\n * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(verbosity: number | boolean = 0, benchmark?: boolean) {\n  if (typeof verbosity === \"boolean\") {\n    benchmark = verbosity;\n    verbosity = 0;\n  }\n  return log(LogLevel.verbose, benchmark, verbosity);\n}\n"]}
|
package/lib/esm/index.d.ts
CHANGED
|
@@ -1,10 +1,16 @@
|
|
|
1
1
|
export * from "./constants";
|
|
2
2
|
export * from "./decorators";
|
|
3
|
+
export * from "./LoggedClass";
|
|
3
4
|
export * from "./logging";
|
|
4
5
|
export * from "./types";
|
|
5
6
|
/**
|
|
6
7
|
* @description A logging module for TypeScript applications
|
|
7
|
-
* @summary
|
|
8
|
+
* @summary Provides a comprehensive, flexible logging solution. This module exposes:
|
|
9
|
+
* - Core classes like {@link Logging} and {@link MiniLogger}
|
|
10
|
+
* - Decorators such as {@link log} for instrumenting methods
|
|
11
|
+
* - Configuration and constants like {@link LogLevel} and {@link DefaultLoggingConfig}
|
|
12
|
+
* - Type definitions including {@link Logger} and {@link LoggingConfig}
|
|
13
|
+
* These exports enable consistent, context-aware, and optionally themed logging across projects.
|
|
8
14
|
* @module Logging
|
|
9
15
|
*/
|
|
10
16
|
/**
|
|
@@ -13,4 +19,4 @@ export * from "./types";
|
|
|
13
19
|
* @const VERSION
|
|
14
20
|
* @memberOf module:Logging
|
|
15
21
|
*/
|
|
16
|
-
export declare const VERSION = "0.3.
|
|
22
|
+
export declare const VERSION = "0.3.7";
|
package/lib/esm/index.js
CHANGED
|
@@ -1,10 +1,16 @@
|
|
|
1
1
|
export * from "./constants.js";
|
|
2
2
|
export * from "./decorators.js";
|
|
3
|
+
export * from "./LoggedClass.js";
|
|
3
4
|
export * from "./logging.js";
|
|
4
5
|
export * from "./types.js";
|
|
5
6
|
/**
|
|
6
7
|
* @description A logging module for TypeScript applications
|
|
7
|
-
* @summary
|
|
8
|
+
* @summary Provides a comprehensive, flexible logging solution. This module exposes:
|
|
9
|
+
* - Core classes like {@link Logging} and {@link MiniLogger}
|
|
10
|
+
* - Decorators such as {@link log} for instrumenting methods
|
|
11
|
+
* - Configuration and constants like {@link LogLevel} and {@link DefaultLoggingConfig}
|
|
12
|
+
* - Type definitions including {@link Logger} and {@link LoggingConfig}
|
|
13
|
+
* These exports enable consistent, context-aware, and optionally themed logging across projects.
|
|
8
14
|
* @module Logging
|
|
9
15
|
*/
|
|
10
16
|
/**
|
|
@@ -13,5 +19,5 @@ export * from "./types.js";
|
|
|
13
19
|
* @const VERSION
|
|
14
20
|
* @memberOf module:Logging
|
|
15
21
|
*/
|
|
16
|
-
export const VERSION = "0.3.
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
export const VERSION = "0.3.7";
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0JBQTRCO0FBQzVCLGdDQUE2QjtBQUM3QixpQ0FBOEI7QUFDOUIsNkJBQTBCO0FBQzFCLDJCQUF3QjtBQUV4Qjs7Ozs7Ozs7O0dBU0c7QUFFSDs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0xvZ2dlZENsYXNzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9sb2dnaW5nXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBBIGxvZ2dpbmcgbW9kdWxlIGZvciBUeXBlU2NyaXB0IGFwcGxpY2F0aW9uc1xuICogQHN1bW1hcnkgUHJvdmlkZXMgYSBjb21wcmVoZW5zaXZlLCBmbGV4aWJsZSBsb2dnaW5nIHNvbHV0aW9uLiBUaGlzIG1vZHVsZSBleHBvc2VzOlxuICogLSBDb3JlIGNsYXNzZXMgbGlrZSB7QGxpbmsgTG9nZ2luZ30gYW5kIHtAbGluayBNaW5pTG9nZ2VyfVxuICogLSBEZWNvcmF0b3JzIHN1Y2ggYXMge0BsaW5rIGxvZ30gZm9yIGluc3RydW1lbnRpbmcgbWV0aG9kc1xuICogLSBDb25maWd1cmF0aW9uIGFuZCBjb25zdGFudHMgbGlrZSB7QGxpbmsgTG9nTGV2ZWx9IGFuZCB7QGxpbmsgRGVmYXVsdExvZ2dpbmdDb25maWd9XG4gKiAtIFR5cGUgZGVmaW5pdGlvbnMgaW5jbHVkaW5nIHtAbGluayBMb2dnZXJ9IGFuZCB7QGxpbmsgTG9nZ2luZ0NvbmZpZ31cbiAqIFRoZXNlIGV4cG9ydHMgZW5hYmxlIGNvbnNpc3RlbnQsIGNvbnRleHQtYXdhcmUsIGFuZCBvcHRpb25hbGx5IHRoZW1lZCBsb2dnaW5nIGFjcm9zcyBwcm9qZWN0cy5cbiAqIEBtb2R1bGUgTG9nZ2luZ1xuICovXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uIHN0cmluZ1xuICogQHN1bW1hcnkgU3RvcmVzIHRoZSBjdXJyZW50IHBhY2thZ2UgdmVyc2lvbiwgdXNlZCBmb3IgdmVyc2lvbiB0cmFja2luZyBhbmQgY29tcGF0aWJpbGl0eSBjaGVja3NcbiAqIEBjb25zdCBWRVJTSU9OXG4gKiBAbWVtYmVyT2YgbW9kdWxlOkxvZ2dpbmdcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
package/lib/esm/logging.d.ts
CHANGED
|
@@ -29,15 +29,8 @@ export declare class MiniLogger implements Logger {
|
|
|
29
29
|
protected conf?: Partial<LoggingConfig> | undefined;
|
|
30
30
|
constructor(context: string, conf?: Partial<LoggingConfig> | undefined);
|
|
31
31
|
protected config(key: keyof LoggingConfig): LoggingConfig[keyof LoggingConfig];
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
* @summary Returns a new logger instance with the current context extended by the specified method name
|
|
35
|
-
* @param {string | Function} method - The method name or function to create a logger for
|
|
36
|
-
* @param {Partial<LoggingConfig>} config - Optional configuration to override settings
|
|
37
|
-
* @param {...any} args - Additional arguments to pass to the logger factory
|
|
38
|
-
* @return {Logger} A new logger instance for the specified method
|
|
39
|
-
*/
|
|
40
|
-
for(method?: string | ((...args: any[]) => any), config?: Partial<LoggingConfig>): Logger;
|
|
32
|
+
for(method: string | ((...args: any[]) => any)): Logger;
|
|
33
|
+
for(config: Partial<LoggingConfig>): Logger;
|
|
41
34
|
/**
|
|
42
35
|
* @description Creates a formatted log string
|
|
43
36
|
* @summary Generates a log string with timestamp, colored log level, context, and message
|
|
@@ -257,14 +250,12 @@ export declare class Logging {
|
|
|
257
250
|
*/
|
|
258
251
|
static for(object: LoggingContext, config?: Partial<LoggingConfig>, ...args: any[]): Logger;
|
|
259
252
|
/**
|
|
260
|
-
* @description Creates a logger for a specific reason or context
|
|
261
|
-
*
|
|
262
|
-
*
|
|
263
|
-
*
|
|
264
|
-
*
|
|
265
|
-
* @
|
|
266
|
-
* @param id
|
|
267
|
-
* @returns A new VerbosityLogger or ClassLogger instance.
|
|
253
|
+
* @description Creates a logger for a specific reason or correlation context
|
|
254
|
+
* @summary Utility to quickly create a logger labeled with a free-form reason and optional identifier
|
|
255
|
+
* so that ad-hoc operations can be traced without tying the logger to a class or method name.
|
|
256
|
+
* @param {string} reason - A textual reason or context label for this logger instance
|
|
257
|
+
* @param {string} [id] - Optional identifier to help correlate related log entries
|
|
258
|
+
* @return {Logger} A new logger instance labeled with the provided reason and id
|
|
268
259
|
*/
|
|
269
260
|
static because(reason: string, id?: string): Logger;
|
|
270
261
|
/**
|