@decaf-ts/logging 0.3.12 → 0.3.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/dist/logging.cjs +542 -99
  2. package/dist/logging.esm.cjs +539 -100
  3. package/lib/LoggedClass.cjs +9 -12
  4. package/lib/LoggedClass.d.ts +6 -10
  5. package/lib/constants.cjs +40 -8
  6. package/lib/constants.d.ts +35 -7
  7. package/lib/decorators.cjs +114 -50
  8. package/lib/decorators.d.ts +58 -43
  9. package/lib/environment.cjs +73 -22
  10. package/lib/environment.d.ts +46 -29
  11. package/lib/esm/LoggedClass.d.ts +6 -10
  12. package/lib/esm/LoggedClass.js +9 -12
  13. package/lib/esm/constants.d.ts +35 -7
  14. package/lib/esm/constants.js +40 -8
  15. package/lib/esm/decorators.d.ts +58 -43
  16. package/lib/esm/decorators.js +113 -50
  17. package/lib/esm/environment.d.ts +46 -29
  18. package/lib/esm/environment.js +73 -22
  19. package/lib/esm/filters/LogFilter.d.ts +37 -0
  20. package/lib/esm/filters/LogFilter.js +30 -1
  21. package/lib/esm/filters/PatternFilter.d.ts +46 -0
  22. package/lib/esm/filters/PatternFilter.js +41 -1
  23. package/lib/esm/index.d.ts +7 -10
  24. package/lib/esm/index.js +8 -11
  25. package/lib/esm/logging.d.ts +14 -0
  26. package/lib/esm/logging.js +22 -1
  27. package/lib/esm/time.d.ts +149 -0
  28. package/lib/esm/time.js +212 -0
  29. package/lib/esm/types.d.ts +89 -51
  30. package/lib/esm/types.js +1 -1
  31. package/lib/filters/LogFilter.cjs +30 -1
  32. package/lib/filters/LogFilter.d.ts +37 -0
  33. package/lib/filters/PatternFilter.cjs +41 -1
  34. package/lib/filters/PatternFilter.d.ts +46 -0
  35. package/lib/index.cjs +8 -11
  36. package/lib/index.d.ts +7 -10
  37. package/lib/logging.cjs +22 -1
  38. package/lib/logging.d.ts +14 -0
  39. package/lib/time.cjs +217 -0
  40. package/lib/time.d.ts +149 -0
  41. package/lib/types.cjs +1 -1
  42. package/lib/types.d.ts +89 -51
  43. package/package.json +2 -2
@@ -1,10 +1,27 @@
1
1
  import { LoggingConfig, Theme } from "./types";
2
+ /**
3
+ * @description Global key used to store environment variables in browser contexts.
4
+ * @summary Enables the logging environment helpers to locate serialized environment configuration on `globalThis`.
5
+ * @const BrowserEnvKey
6
+ * @type {string}
7
+ * @memberOf module:Logging
8
+ */
2
9
  export declare const BrowserEnvKey = "ENV";
3
10
  /**
4
11
  * @description Delimiter used for composing nested environment variable names.
5
12
  * @summary Joins parent and child keys when mapping object paths to ENV strings.
13
+ * @const ENV_PATH_DELIMITER
14
+ * @type {string}
15
+ * @memberOf module:Logging
6
16
  */
7
17
  export declare const ENV_PATH_DELIMITER = "__";
18
+ /**
19
+ * @description Default prefix and suffix used for template placeholders.
20
+ * @summary Provides wrapper strings applied when interpolating messages with {@link patchPlaceholders}.
21
+ * @const DefaultPlaceholderWrappers
22
+ * @type {string[]}
23
+ * @memberOf module:Logging
24
+ */
8
25
  export declare const DefaultPlaceholderWrappers: string[];
9
26
  /**
10
27
  * @description Enum for log levels.
@@ -14,21 +31,24 @@ export declare const DefaultPlaceholderWrappers: string[];
14
31
  * @memberOf module:Logging
15
32
  */
16
33
  export declare enum LogLevel {
17
- /** Error events that are likely to cause problems. */
34
+ /** @description Benchmark events that capture performance metrics. */
35
+ benchmark = "benchmark",
36
+ /** @description Error events that indicate failures requiring attention. */
18
37
  error = "error",
19
- /** Routine information, such as ongoing status or performance. */
38
+ /** @description Informational events describing normal operation. */
20
39
  info = "info",
21
- /** Additional relevant information. */
40
+ /** @description Verbose diagnostic information for detailed tracing. */
22
41
  verbose = "verbose",
23
- /** Debug or trace information. */
42
+ /** @description Debug or trace details aimed at developers. */
24
43
  debug = "debug",
25
- /** way too verbose or silly information. */
44
+ /** @description Extremely chatty or playful log entries. */
26
45
  silly = "silly"
27
46
  }
28
47
  /**
29
48
  * @description Numeric values associated with log levels.
30
49
  * @summary Provides a numeric representation of log levels for comparison and filtering.
31
- * @const NumericLogLevels
50
+ * @typedef {Object} NumericLogLevelsShape
51
+ * @property {number} benchmark - Numeric value for benchmark level (0).
32
52
  * @property {number} error - Numeric value for error level (2).
33
53
  * @property {number} info - Numeric value for info level (4).
34
54
  * @property {number} verbose - Numeric value for verbose level (6).
@@ -36,7 +56,15 @@ export declare enum LogLevel {
36
56
  * @property {number} silly - Numeric value for silly level (9).
37
57
  * @memberOf module:Logging
38
58
  */
59
+ /**
60
+ * @description Numeric values associated with log levels.
61
+ * @summary Provides a numeric representation of log levels for comparison and filtering.
62
+ * @const NumericLogLevels
63
+ * @type {NumericLogLevelsShape}
64
+ * @memberOf module:Logging
65
+ */
39
66
  export declare const NumericLogLevels: {
67
+ benchmark: number;
40
68
  error: number;
41
69
  info: number;
42
70
  verbose: number;
@@ -58,7 +86,6 @@ export declare enum LoggingMode {
58
86
  /**
59
87
  * @description Default theme for styling log output.
60
88
  * @summary Defines the default color and style settings for various components of log messages.
61
- * @const DefaultTheme
62
89
  * @typedef {Theme} DefaultTheme
63
90
  * @property {Object} class - Styling for class names.
64
91
  * @property {number} class.fg - Foreground color code for class names (34).
@@ -78,6 +105,7 @@ export declare enum LoggingMode {
78
105
  * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).
79
106
  * @property {Object} logLevel.debug - Styling for debug level logs.
80
107
  * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (33).
108
+ * @const DefaultTheme
81
109
  * @memberOf module:Logging
82
110
  */
83
111
  export declare const DefaultTheme: Theme;
@@ -1,9 +1,26 @@
1
+ /**
2
+ * @description Global key used to store environment variables in browser contexts.
3
+ * @summary Enables the logging environment helpers to locate serialized environment configuration on `globalThis`.
4
+ * @const BrowserEnvKey
5
+ * @type {string}
6
+ * @memberOf module:Logging
7
+ */
1
8
  export const BrowserEnvKey = "ENV";
2
9
  /**
3
10
  * @description Delimiter used for composing nested environment variable names.
4
11
  * @summary Joins parent and child keys when mapping object paths to ENV strings.
12
+ * @const ENV_PATH_DELIMITER
13
+ * @type {string}
14
+ * @memberOf module:Logging
5
15
  */
6
16
  export const ENV_PATH_DELIMITER = "__";
17
+ /**
18
+ * @description Default prefix and suffix used for template placeholders.
19
+ * @summary Provides wrapper strings applied when interpolating messages with {@link patchPlaceholders}.
20
+ * @const DefaultPlaceholderWrappers
21
+ * @type {string[]}
22
+ * @memberOf module:Logging
23
+ */
7
24
  export const DefaultPlaceholderWrappers = ["${", "}"];
8
25
  /**
9
26
  * @description Enum for log levels.
@@ -14,21 +31,24 @@ export const DefaultPlaceholderWrappers = ["${", "}"];
14
31
  */
15
32
  export var LogLevel;
16
33
  (function (LogLevel) {
17
- /** Error events that are likely to cause problems. */
34
+ /** @description Benchmark events that capture performance metrics. */
35
+ LogLevel["benchmark"] = "benchmark";
36
+ /** @description Error events that indicate failures requiring attention. */
18
37
  LogLevel["error"] = "error";
19
- /** Routine information, such as ongoing status or performance. */
38
+ /** @description Informational events describing normal operation. */
20
39
  LogLevel["info"] = "info";
21
- /** Additional relevant information. */
40
+ /** @description Verbose diagnostic information for detailed tracing. */
22
41
  LogLevel["verbose"] = "verbose";
23
- /** Debug or trace information. */
42
+ /** @description Debug or trace details aimed at developers. */
24
43
  LogLevel["debug"] = "debug";
25
- /** way too verbose or silly information. */
44
+ /** @description Extremely chatty or playful log entries. */
26
45
  LogLevel["silly"] = "silly";
27
46
  })(LogLevel || (LogLevel = {}));
28
47
  /**
29
48
  * @description Numeric values associated with log levels.
30
49
  * @summary Provides a numeric representation of log levels for comparison and filtering.
31
- * @const NumericLogLevels
50
+ * @typedef {Object} NumericLogLevelsShape
51
+ * @property {number} benchmark - Numeric value for benchmark level (0).
32
52
  * @property {number} error - Numeric value for error level (2).
33
53
  * @property {number} info - Numeric value for info level (4).
34
54
  * @property {number} verbose - Numeric value for verbose level (6).
@@ -36,7 +56,15 @@ export var LogLevel;
36
56
  * @property {number} silly - Numeric value for silly level (9).
37
57
  * @memberOf module:Logging
38
58
  */
59
+ /**
60
+ * @description Numeric values associated with log levels.
61
+ * @summary Provides a numeric representation of log levels for comparison and filtering.
62
+ * @const NumericLogLevels
63
+ * @type {NumericLogLevelsShape}
64
+ * @memberOf module:Logging
65
+ */
39
66
  export const NumericLogLevels = {
67
+ benchmark: 0,
40
68
  error: 2,
41
69
  info: 4,
42
70
  verbose: 6,
@@ -59,7 +87,6 @@ export var LoggingMode;
59
87
  /**
60
88
  * @description Default theme for styling log output.
61
89
  * @summary Defines the default color and style settings for various components of log messages.
62
- * @const DefaultTheme
63
90
  * @typedef {Theme} DefaultTheme
64
91
  * @property {Object} class - Styling for class names.
65
92
  * @property {number} class.fg - Foreground color code for class names (34).
@@ -79,6 +106,7 @@ export var LoggingMode;
79
106
  * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).
80
107
  * @property {Object} logLevel.debug - Styling for debug level logs.
81
108
  * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (33).
109
+ * @const DefaultTheme
82
110
  * @memberOf module:Logging
83
111
  */
84
112
  export const DefaultTheme = {
@@ -99,6 +127,10 @@ export const DefaultTheme = {
99
127
  },
100
128
  method: {},
101
129
  logLevel: {
130
+ benchmark: {
131
+ fg: 32,
132
+ style: ["bold"],
133
+ },
102
134
  error: {
103
135
  fg: 31,
104
136
  style: ["bold"],
@@ -149,4 +181,4 @@ export const DefaultLoggingConfig = {
149
181
  pattern: "{level} [{timestamp}] {app} {context} {separator} {message} {stack}",
150
182
  theme: DefaultTheme,
151
183
  };
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC;AAEnC;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,CAAC;AAEvC,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;AAEtD;;;;;;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,GAAG,EAAE,EAAE;IACP,SAAS,EAAE,EAAE;IACb,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;YACJ,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,OAAO,EAAE;YACP,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;KACF;CACF,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAkB;IACjD,GAAG,EAAE,aAAa;IAClB,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,QAAQ,CAAC,IAAI;IACpB,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,KAAK;IACZ,gBAAgB,EAAE,GAAG;IACrB,SAAS,EAAE,GAAG;IACd,SAAS,EAAE,IAAI;IACf,eAAe,EAAE,cAAc;IAC/B,OAAO,EAAE,IAAI;IACb,MAAM,EAAE,WAAW,CAAC,GAAG;IACvB,OAAO,EACL,qEAAqE;IACvE,KAAK,EAAE,YAAY;CACpB,CAAC","sourcesContent":["import { LoggingConfig, Theme } from \"./types\";\n\nexport const BrowserEnvKey = \"ENV\";\n\n/**\n * @description Delimiter used for composing nested environment variable names.\n * @summary Joins parent and child keys when mapping object paths to ENV strings.\n */\nexport const ENV_PATH_DELIMITER = \"__\";\n\nexport const DefaultPlaceholderWrappers = [\"${\", \"}\"];\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  app: {},\n  separator: {},\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      fg: 34,\n      style: [\"bold\"],\n    },\n    verbose: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    debug: {\n      fg: 33,\n      style: [\"bold\"],\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  env: \"development\",\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  style: false,\n  contextSeparator: \".\",\n  separator: \"-\",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  format: LoggingMode.RAW,\n  pattern:\n    \"{level} [{timestamp}] {app} {context} {separator} {message} {stack}\",\n  theme: DefaultTheme,\n};\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC;AAEnC;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,CAAC;AAEvC;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;AAEtD;;;;;;GAMG;AACH,MAAM,CAAN,IAAY,QAaX;AAbD,WAAY,QAAQ;IAClB,sEAAsE;IACtE,mCAAuB,CAAA;IACvB,4EAA4E;IAC5E,2BAAe,CAAA;IACf,qEAAqE;IACrE,yBAAa,CAAA;IACb,wEAAwE;IACxE,+BAAmB,CAAA;IACnB,+DAA+D;IAC/D,2BAAe,CAAA;IACf,4DAA4D;IAC5D,2BAAe,CAAA;AACjB,CAAC,EAbW,QAAQ,KAAR,QAAQ,QAanB;AAED;;;;;;;;;;;GAWG;AACH;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,SAAS,EAAE,CAAC;IACZ,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,GAAG,EAAE,EAAE;IACP,SAAS,EAAE,EAAE;IACb,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,SAAS,EAAE;YACT,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,IAAI,EAAE;YACJ,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,OAAO,EAAE;YACP,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;QACD,KAAK,EAAE;YACL,EAAE,EAAE,EAAE;YACN,KAAK,EAAE,CAAC,MAAM,CAAC;SAChB;KACF;CACF,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAkB;IACjD,GAAG,EAAE,aAAa;IAClB,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,QAAQ,CAAC,IAAI;IACpB,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,KAAK;IACZ,gBAAgB,EAAE,GAAG;IACrB,SAAS,EAAE,GAAG;IACd,SAAS,EAAE,IAAI;IACf,eAAe,EAAE,cAAc;IAC/B,OAAO,EAAE,IAAI;IACb,MAAM,EAAE,WAAW,CAAC,GAAG;IACvB,OAAO,EACL,qEAAqE;IACvE,KAAK,EAAE,YAAY;CACpB,CAAC","sourcesContent":["import { LoggingConfig, Theme } from \"./types\";\n\n/**\n * @description Global key used to store environment variables in browser contexts.\n * @summary Enables the logging environment helpers to locate serialized environment configuration on `globalThis`.\n * @const BrowserEnvKey\n * @type {string}\n * @memberOf module:Logging\n */\nexport const BrowserEnvKey = \"ENV\";\n\n/**\n * @description Delimiter used for composing nested environment variable names.\n * @summary Joins parent and child keys when mapping object paths to ENV strings.\n * @const ENV_PATH_DELIMITER\n * @type {string}\n * @memberOf module:Logging\n */\nexport const ENV_PATH_DELIMITER = \"__\";\n\n/**\n * @description Default prefix and suffix used for template placeholders.\n * @summary Provides wrapper strings applied when interpolating messages with {@link patchPlaceholders}.\n * @const DefaultPlaceholderWrappers\n * @type {string[]}\n * @memberOf module:Logging\n */\nexport const DefaultPlaceholderWrappers = [\"${\", \"}\"];\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  /** @description Benchmark events that capture performance metrics. */\n  benchmark = \"benchmark\",\n  /** @description Error events that indicate failures requiring attention. */\n  error = \"error\",\n  /** @description Informational events describing normal operation. */\n  info = \"info\",\n  /** @description Verbose diagnostic information for detailed tracing. */\n  verbose = \"verbose\",\n  /** @description Debug or trace details aimed at developers. */\n  debug = \"debug\",\n  /** @description Extremely chatty or playful log entries. */\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 * @typedef {Object} NumericLogLevelsShape\n * @property {number} benchmark - Numeric value for benchmark level (0).\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 */\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 * @type {NumericLogLevelsShape}\n * @memberOf module:Logging\n */\nexport const NumericLogLevels = {\n  benchmark: 0,\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 * @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 * @const DefaultTheme\n * @memberOf module:Logging\n */\nexport const DefaultTheme: Theme = {\n  app: {},\n  separator: {},\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    benchmark: {\n      fg: 32,\n      style: [\"bold\"],\n    },\n    error: {\n      fg: 31,\n      style: [\"bold\"],\n    },\n    info: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    verbose: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    debug: {\n      fg: 33,\n      style: [\"bold\"],\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  env: \"development\",\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  style: false,\n  contextSeparator: \".\",\n  separator: \"-\",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  format: LoggingMode.RAW,\n  pattern:\n    \"{level} [{timestamp}] {app} {context} {separator} {message} {stack}\",\n  theme: DefaultTheme,\n};\n"]}
@@ -1,11 +1,14 @@
1
1
  import { LogLevel } from "./constants";
2
+ export type ArgFormatFunction = (...args: any[]) => string;
3
+ export type ReturnFormatFunction = (e?: Error, result?: any) => string;
2
4
  /**
3
- * @description Method decorator for logging function calls
4
- * @summary Creates a decorator that logs method calls with specified level, benchmarking, and verbosity
5
- * @param {LogLevel} level - The log level to use (default: LogLevel.info)
6
- * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
7
- * @param {number} [verbosity=0] - The verbosity level for the log messages (default: 0)
8
- * @return {Function} A method decorator that wraps the original method with logging
5
+ * @description Method decorator for logging function calls.
6
+ * @summary Wraps class methods to automatically log entry, exit, timing, and optional custom messages at a configurable {@link LogLevel}.
7
+ * @param {LogLevel} level - Log level applied to the generated log statements (defaults to `LogLevel.info`).
8
+ * @param {number} [verbosity=0] - Verbosity threshold required for the entry log to appear.
9
+ * @param {ArgFormatFunction} [entryMessage] - Formatter invoked with the original method arguments to describe the invocation.
10
+ * @param {ReturnFormatFunction} [exitMessage] - Optional formatter that describes the outcome or failure of the call.
11
+ * @return {function(any, any, PropertyDescriptor): void} Method decorator proxy that injects logging behavior.
9
12
  * @function log
10
13
  * @mermaid
11
14
  * sequenceDiagram
@@ -30,64 +33,76 @@ import { LogLevel } from "./constants";
30
33
  * end
31
34
  * @category Method Decorators
32
35
  */
33
- export declare function log(level?: LogLevel, benchmark?: boolean, verbosity?: number): (target: any, propertyKey?: any, descriptor?: PropertyDescriptor) => void;
36
+ export declare function log(level?: LogLevel, verbosity?: number, entryMessage?: ArgFormatFunction, exitMessage?: ReturnFormatFunction): (target: any, propertyKey?: any, descriptor?: any) => any;
34
37
  /**
35
- * @description Method decorator for logging function calls with debug level
36
- * @summary Convenience wrapper around the log decorator that uses LogLevel.debug
37
- * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
38
- * @return {Function} A method decorator that wraps the original method with debug logging
38
+ * @description Method decorator that records execution time at the benchmark level.
39
+ * @summary Wraps the target method to emit {@link Logger.benchmark} entries capturing completion time or failure latency.
40
+ * @return {function(any, any, PropertyDescriptor): void} Method decorator proxy that benchmarks the original implementation.
41
+ * @function benchmark
42
+ * @mermaid
43
+ * sequenceDiagram
44
+ * participant Caller
45
+ * participant Decorator as benchmark
46
+ * participant Method as Original Method
47
+ * Caller->>Decorator: invoke()
48
+ * Decorator->>Method: Reflect.apply(...)
49
+ * alt Promise result
50
+ * Method-->>Decorator: Promise
51
+ * Decorator->>Decorator: attach then()
52
+ * Decorator->>Decorator: log completion duration
53
+ * else Synchronous result
54
+ * Method-->>Decorator: value
55
+ * Decorator->>Decorator: log completion duration
56
+ * end
57
+ * Decorator-->>Caller: return result
58
+ * @category Method Decorators
59
+ */
60
+ export declare function benchmark(): (target: any, propertyKey?: any, descriptor?: any) => any;
61
+ /**
62
+ * @description Method decorator for logging function calls with debug level.
63
+ * @summary Convenience wrapper around {@link log} that logs using `LogLevel.debug`.
64
+ * @return {function(any, any, PropertyDescriptor): void} Debug-level logging decorator.
39
65
  * @function debug
40
66
  * @category Method Decorators
41
67
  */
42
- export declare function debug(benchmark?: boolean): (target: any, propertyKey?: any, descriptor?: PropertyDescriptor) => void;
68
+ export declare function debug(): (target: any, propertyKey?: any, descriptor?: any) => any;
43
69
  /**
44
- * @description Method decorator for logging function calls with info level
45
- * @summary Convenience wrapper around the log decorator that uses LogLevel.info
46
- * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
47
- * @return {Function} A method decorator that wraps the original method with info logging
70
+ * @description Method decorator for logging function calls with info level.
71
+ * @summary Convenience wrapper around {@link log} that logs using `LogLevel.info`.
72
+ * @return {function(any, any, PropertyDescriptor): void} Info-level logging decorator.
48
73
  * @function info
49
74
  * @category Method Decorators
50
75
  */
51
- export declare function info(benchmark?: boolean): (target: any, propertyKey?: any, descriptor?: PropertyDescriptor) => void;
76
+ export declare function info(): (target: any, propertyKey?: any, descriptor?: any) => any;
52
77
  /**
53
- * @description Method decorator for logging function calls with silly level
54
- * @summary Convenience wrapper around the log decorator that uses LogLevel.silly
55
- * @param {boolean} [benchmark=false] - Whether to log execution time (default: false)
56
- * @return {Function} A method decorator that wraps the original method with silly logging
78
+ * @description Method decorator for logging function calls with silly level.
79
+ * @summary Convenience wrapper around {@link log} that logs using `LogLevel.silly`.
80
+ * @return {function(any, any, PropertyDescriptor): void} Silly-level logging decorator.
57
81
  * @function silly
58
82
  * @category Method Decorators
59
83
  */
60
- export declare function silly(benchmark?: boolean): (target: any, propertyKey?: any, descriptor?: PropertyDescriptor) => void;
84
+ export declare function silly(): (target: any, propertyKey?: any, descriptor?: any) => any;
61
85
  /**
62
- * @description Method decorator for logging function calls with verbose level
63
- * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
64
- * @return {Function} A method decorator that wraps the original method with verbose logging
86
+ * @description Method decorator for logging function calls with verbose level.
87
+ * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` with configurable verbosity.
88
+ * @return {function(any, any, PropertyDescriptor): void} Verbose logging decorator.
65
89
  * @function verbose
90
+ * @category Method Decorators
66
91
  */
67
92
  export declare function verbose(): (target: any, propertyKey?: any, descriptor?: any) => void;
68
93
  /**
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): (target: any, propertyKey?: any, descriptor?: any) => void;
76
- /**
77
- * @description Method decorator for logging function calls with verbose level
78
- * @summary Convenience wrapper around the log decorator that uses LogLevel.verbose with configurable verbosity
79
- * @param {number} verbosity - The verbosity level for the log messages (default: 0)
80
- * @return {Function} A method decorator that wraps the original method with verbose logging
94
+ * @description Method decorator for logging function calls with verbose level.
95
+ * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` while toggling benchmarking.
96
+ * @return {function(any, PropertyDescriptor): void} Verbose logging decorator.
81
97
  * @function verbose
82
98
  * @category Method Decorators
83
99
  */
84
- export declare function verbose(verbosity: number | boolean): (target: any, propertyKey?: any, descriptor?: any) => void;
100
+ export declare function verbose(): (target: any, propertyKey?: any, descriptor?: any) => void;
85
101
  /**
86
- * @description Creates a decorator that makes a method non-configurable
87
- * @summary This decorator prevents a method from being overridden by making it non-configurable.
88
- * It throws an error if used on anything other than a method.
89
- * @return {Function} A decorator function that can be applied to methods
102
+ * @description Creates a decorator that makes a method non-configurable.
103
+ * @summary Prevents overriding by marking the method descriptor as non-configurable, throwing if applied to non-method targets.
104
+ * @return {function(object, any, PropertyDescriptor): PropertyDescriptor|undefined} Decorator that hardens the method descriptor.
90
105
  * @function final
91
106
  * @category Method Decorators
92
107
  */
93
- export declare function final(): (target: object, propertyKey?: any, descriptor?: PropertyDescriptor) => PropertyDescriptor;
108
+ export declare function final(): (target: object, propertyKey?: any, descriptor?: any) => any;