@decaf-ts/logging 0.3.8 → 0.3.9
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/dist/logging.cjs +587 -105
- package/dist/logging.esm.cjs +567 -102
- package/lib/constants.cjs +15 -6
- package/lib/constants.d.ts +7 -0
- package/lib/decorators.cjs +44 -27
- package/lib/decorators.d.ts +9 -0
- package/lib/environment.cjs +204 -0
- package/lib/environment.d.ts +86 -0
- package/lib/esm/constants.d.ts +7 -0
- package/lib/esm/constants.js +14 -5
- package/lib/esm/decorators.d.ts +9 -0
- package/lib/esm/decorators.js +43 -27
- package/lib/esm/environment.d.ts +86 -0
- package/lib/esm/environment.js +200 -0
- package/lib/esm/filters/LogFilter.d.ts +6 -0
- package/lib/esm/filters/LogFilter.js +7 -0
- package/lib/esm/filters/PatternFilter.d.ts +10 -0
- package/lib/esm/filters/PatternFilter.js +43 -0
- package/lib/esm/filters/index.d.ts +2 -0
- package/lib/esm/filters/index.js +3 -0
- package/lib/esm/index.d.ts +5 -2
- package/lib/esm/index.js +6 -3
- package/lib/esm/logging.d.ts +10 -11
- package/lib/esm/logging.js +38 -27
- package/lib/esm/text.d.ts +156 -0
- package/lib/esm/text.js +214 -0
- package/lib/esm/types.d.ts +31 -5
- package/lib/esm/types.js +1 -1
- package/lib/esm/web.d.ts +8 -0
- package/lib/esm/web.js +12 -0
- package/lib/esm/winston/winston.d.ts +2 -2
- package/lib/esm/winston/winston.js +4 -4
- package/lib/filters/LogFilter.cjs +11 -0
- package/lib/filters/LogFilter.d.ts +6 -0
- package/lib/filters/PatternFilter.cjs +47 -0
- package/lib/filters/PatternFilter.d.ts +10 -0
- package/lib/filters/index.cjs +19 -0
- package/lib/filters/index.d.ts +2 -0
- package/lib/index.cjs +6 -3
- package/lib/index.d.ts +5 -2
- package/lib/logging.cjs +37 -26
- package/lib/logging.d.ts +10 -11
- package/lib/text.cjs +227 -0
- package/lib/text.d.ts +156 -0
- package/lib/types.cjs +1 -1
- package/lib/types.d.ts +31 -5
- package/lib/web.cjs +15 -0
- package/lib/web.d.ts +8 -0
- package/lib/winston/winston.cjs +4 -4
- package/lib/winston/winston.d.ts +2 -2
- package/package.json +12 -3
- package/lib/esm/utils.d.ts +0 -12
- package/lib/esm/utils.js +0 -31
- package/lib/utils.cjs +0 -34
- package/lib/utils.d.ts +0 -12
package/dist/logging.esm.cjs
CHANGED
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
import { style } from 'styled-string-builder';
|
|
2
|
+
import { ObjectAccumulator } from 'typed-object-accumulator';
|
|
3
|
+
import { __decorate, __metadata } from 'tslib';
|
|
2
4
|
|
|
5
|
+
const BrowserEnvKey = "ENV";
|
|
6
|
+
/**
|
|
7
|
+
* @description Delimiter used for composing nested environment variable names.
|
|
8
|
+
* @summary Joins parent and child keys when mapping object paths to ENV strings.
|
|
9
|
+
*/
|
|
10
|
+
const ENV_PATH_DELIMITER = "__";
|
|
11
|
+
const DefaultPlaceholderWrappers = ["${", "}"];
|
|
3
12
|
/**
|
|
4
13
|
* @description Enum for log levels.
|
|
5
14
|
* @summary Defines different levels of logging for the application.
|
|
@@ -77,6 +86,8 @@ var LoggingMode;
|
|
|
77
86
|
* @memberOf module:Logging
|
|
78
87
|
*/
|
|
79
88
|
const DefaultTheme = {
|
|
89
|
+
app: {},
|
|
90
|
+
separator: {},
|
|
80
91
|
class: {
|
|
81
92
|
fg: 34,
|
|
82
93
|
},
|
|
@@ -128,21 +139,194 @@ const DefaultTheme = {
|
|
|
128
139
|
* @memberOf module:Logging
|
|
129
140
|
*/
|
|
130
141
|
const DefaultLoggingConfig = {
|
|
142
|
+
env: "development",
|
|
131
143
|
verbose: 0,
|
|
132
144
|
level: LogLevel.info,
|
|
133
145
|
logLevel: true,
|
|
134
|
-
mode: LoggingMode.RAW,
|
|
135
146
|
style: false,
|
|
136
147
|
contextSeparator: ".",
|
|
137
|
-
separator: "
|
|
148
|
+
separator: "-",
|
|
138
149
|
timestamp: true,
|
|
139
150
|
timestampFormat: "HH:mm:ss.SSS",
|
|
140
151
|
context: true,
|
|
141
|
-
format:
|
|
142
|
-
pattern: "{level} [{timestamp}] {context}
|
|
152
|
+
format: LoggingMode.RAW,
|
|
153
|
+
pattern: "{level} [{timestamp}] {app} {context} {separator} {message} {stack}",
|
|
143
154
|
theme: DefaultTheme,
|
|
144
155
|
};
|
|
145
156
|
|
|
157
|
+
/**
|
|
158
|
+
* @description Pads the end of a string with a specified character.
|
|
159
|
+
* @summary Extends the input string to a specified length by adding a padding character to the end.
|
|
160
|
+
* If the input string is already longer than the specified length, it is returned unchanged.
|
|
161
|
+
*
|
|
162
|
+
* @param {string} str - The input string to be padded.
|
|
163
|
+
* @param {number} length - The desired total length of the resulting string.
|
|
164
|
+
* @param {string} [char=" "] - The character to use for padding. Defaults to a space.
|
|
165
|
+
* @return {string} The padded string.
|
|
166
|
+
* @throws {Error} If the padding character is not exactly one character long.
|
|
167
|
+
*
|
|
168
|
+
* @function padEnd
|
|
169
|
+
*
|
|
170
|
+
* @memberOf module:Logging
|
|
171
|
+
*/
|
|
172
|
+
function padEnd(str, length, char = " ") {
|
|
173
|
+
if (char.length !== 1)
|
|
174
|
+
throw new Error("Invalid character length for padding. must be one!");
|
|
175
|
+
return str.padEnd(length, char);
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* @description Replaces placeholders in a string with provided values.
|
|
179
|
+
* @summary Interpolates a string by replacing placeholders of the form ${variableName}
|
|
180
|
+
* with corresponding values from the provided object. If a placeholder doesn't have
|
|
181
|
+
* a corresponding value, it is left unchanged in the string.
|
|
182
|
+
*
|
|
183
|
+
* @param {string} input - The input string containing placeholders to be replaced.
|
|
184
|
+
* @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
|
|
185
|
+
* @param prefix
|
|
186
|
+
* @param suffix
|
|
187
|
+
* @param flags
|
|
188
|
+
* @return {string} The interpolated string with placeholders replaced by their corresponding values.
|
|
189
|
+
*
|
|
190
|
+
* @function patchPlaceholders
|
|
191
|
+
*
|
|
192
|
+
* @mermaid
|
|
193
|
+
* sequenceDiagram
|
|
194
|
+
* participant Caller
|
|
195
|
+
* participant patchString
|
|
196
|
+
* participant String.replace
|
|
197
|
+
* Caller->>patchString: Call with input and values
|
|
198
|
+
* patchString->>String.replace: Call with regex and replacement function
|
|
199
|
+
* String.replace->>patchString: Return replaced string
|
|
200
|
+
* patchString-->>Caller: Return patched string
|
|
201
|
+
*
|
|
202
|
+
* @memberOf module:Logging
|
|
203
|
+
*/
|
|
204
|
+
function patchPlaceholders(input, values, prefix = DefaultPlaceholderWrappers[0], suffix = DefaultPlaceholderWrappers[1], flags = "g") {
|
|
205
|
+
const placeholders = Object.entries(values).reduce((acc, [key, val]) => {
|
|
206
|
+
acc[`${prefix}${key}${suffix}`] = val;
|
|
207
|
+
return acc;
|
|
208
|
+
}, {});
|
|
209
|
+
return patchString(input, placeholders, flags);
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* @description Replaces occurrences of keys with their corresponding values in a string.
|
|
213
|
+
* @summary Iterates through a set of key-value pairs and replaces all occurrences of each key
|
|
214
|
+
* in the input string with its corresponding value. Supports regular expression flags for customized replacement.
|
|
215
|
+
*
|
|
216
|
+
* @param {string} input - The input string in which replacements will be made.
|
|
217
|
+
* @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
|
|
218
|
+
* @param {string} [flags="g"] - Regular expression flags to control the replacement behavior.
|
|
219
|
+
* @return {string} The string with all specified replacements applied.
|
|
220
|
+
*
|
|
221
|
+
* @function patchString
|
|
222
|
+
*
|
|
223
|
+
* @memberOf module:Logging
|
|
224
|
+
*/
|
|
225
|
+
function patchString(input, values, flags = "g") {
|
|
226
|
+
Object.entries(values).forEach(([key, val]) => {
|
|
227
|
+
const regexp = new RegExp(escapeRegExp(key), flags);
|
|
228
|
+
input = input.replace(regexp, val);
|
|
229
|
+
});
|
|
230
|
+
return input;
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* @description Converts a string to camelCase.
|
|
234
|
+
* @summary Transforms the input string into camelCase format, where words are joined without spaces
|
|
235
|
+
* and each word after the first starts with a capital letter.
|
|
236
|
+
*
|
|
237
|
+
* @param {string} text - The input string to be converted.
|
|
238
|
+
* @return {string} The input string converted to camelCase.
|
|
239
|
+
*
|
|
240
|
+
* @function toCamelCase
|
|
241
|
+
*
|
|
242
|
+
* @memberOf module:Logging
|
|
243
|
+
*/
|
|
244
|
+
function toCamelCase(text) {
|
|
245
|
+
return text
|
|
246
|
+
.replace(/(?:^\w|[A-Z]|\b\w)/g, (word, index) => index === 0 ? word.toLowerCase() : word.toUpperCase())
|
|
247
|
+
.replace(/\s+/g, "");
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* @description Converts a string to ENVIRONMENT_VARIABLE format.
|
|
251
|
+
* @summary Transforms the input string into uppercase with words separated by underscores,
|
|
252
|
+
* typically used for environment variable names.
|
|
253
|
+
*
|
|
254
|
+
* @param {string} text - The input string to be converted.
|
|
255
|
+
* @return {string} The input string converted to ENVIRONMENT_VARIABLE format.
|
|
256
|
+
*
|
|
257
|
+
* @function toENVFormat
|
|
258
|
+
*
|
|
259
|
+
* @memberOf module:Logging
|
|
260
|
+
*/
|
|
261
|
+
function toENVFormat(text) {
|
|
262
|
+
return toSnakeCase(text).toUpperCase();
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* @description Converts a string to snake_case.
|
|
266
|
+
* @summary Transforms the input string into lowercase with words separated by underscores.
|
|
267
|
+
*
|
|
268
|
+
* @param {string} text - The input string to be converted.
|
|
269
|
+
* @return {string} The input string converted to snake_case.
|
|
270
|
+
*
|
|
271
|
+
* @function toSnakeCase
|
|
272
|
+
*
|
|
273
|
+
* @memberOf module:Logging
|
|
274
|
+
*/
|
|
275
|
+
function toSnakeCase(text) {
|
|
276
|
+
return text
|
|
277
|
+
.replace(/([a-z])([A-Z])/g, "$1_$2")
|
|
278
|
+
.replace(/[\s-]+/g, "_")
|
|
279
|
+
.toLowerCase();
|
|
280
|
+
}
|
|
281
|
+
/**
|
|
282
|
+
* @description Converts a string to kebab-case.
|
|
283
|
+
* @summary Transforms the input string into lowercase with words separated by hyphens.
|
|
284
|
+
*
|
|
285
|
+
* @param {string} text - The input string to be converted.
|
|
286
|
+
* @return {string} The input string converted to kebab-case.
|
|
287
|
+
*
|
|
288
|
+
* @function toKebabCase
|
|
289
|
+
*
|
|
290
|
+
* @memberOf module:Logging
|
|
291
|
+
*/
|
|
292
|
+
function toKebabCase(text) {
|
|
293
|
+
return text
|
|
294
|
+
.replace(/([a-z])([A-Z])/g, "$1-$2")
|
|
295
|
+
.replace(/[\s_]+/g, "-")
|
|
296
|
+
.toLowerCase();
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* @description Converts a string to PascalCase.
|
|
300
|
+
* @summary Transforms the input string into PascalCase format, where words are joined without spaces
|
|
301
|
+
* and each word starts with a capital letter.
|
|
302
|
+
*
|
|
303
|
+
* @param {string} text - The input string to be converted.
|
|
304
|
+
* @return {string} The input string converted to PascalCase.
|
|
305
|
+
*
|
|
306
|
+
* @function toPascalCase
|
|
307
|
+
*
|
|
308
|
+
* @memberOf module:Logging
|
|
309
|
+
*/
|
|
310
|
+
function toPascalCase(text) {
|
|
311
|
+
return text
|
|
312
|
+
.replace(/(?:^\w|[A-Z]|\b\w)/g, (word) => word.toUpperCase())
|
|
313
|
+
.replace(/\s+/g, "");
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* @description Escapes special characters in a string for use in a regular expression.
|
|
317
|
+
* @summary Adds backslashes before characters that have special meaning in regular expressions,
|
|
318
|
+
* allowing the string to be used as a literal match in a RegExp.
|
|
319
|
+
*
|
|
320
|
+
* @param {string} string - The string to escape for regular expression use.
|
|
321
|
+
* @return {string} The escaped string safe for use in regular expressions.
|
|
322
|
+
*
|
|
323
|
+
* @function escapeRegExp
|
|
324
|
+
*
|
|
325
|
+
* @memberOf module:Logging
|
|
326
|
+
*/
|
|
327
|
+
function escapeRegExp(string) {
|
|
328
|
+
return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
|
|
329
|
+
}
|
|
146
330
|
/**
|
|
147
331
|
* @summary Util function to provide string format functionality similar to C#'s string.format
|
|
148
332
|
*
|
|
@@ -150,11 +334,10 @@ const DefaultLoggingConfig = {
|
|
|
150
334
|
* @param {Array<string | number> | Record<string, any>} [args] replacements made by order of appearance (replacement0 wil replace {0} and so on)
|
|
151
335
|
* @return {string} formatted string
|
|
152
336
|
*
|
|
153
|
-
* @function
|
|
154
|
-
* @memberOf module:
|
|
155
|
-
* @category Model
|
|
337
|
+
* @function sf
|
|
338
|
+
* @memberOf module:Logging
|
|
156
339
|
*/
|
|
157
|
-
function
|
|
340
|
+
function sf(string, ...args) {
|
|
158
341
|
if (args.length > 1) {
|
|
159
342
|
if (!args.every((arg) => typeof arg === "string" || typeof arg === "number"))
|
|
160
343
|
throw new Error(`Only string and number arguments are supported for multiple replacements.`);
|
|
@@ -173,6 +356,224 @@ function stringFormat(string, ...args) {
|
|
|
173
356
|
: "undefined";
|
|
174
357
|
});
|
|
175
358
|
}
|
|
359
|
+
/**
|
|
360
|
+
* @summary Util function to provide string format functionality similar to C#'s string.format
|
|
361
|
+
*
|
|
362
|
+
* @see sf
|
|
363
|
+
*
|
|
364
|
+
* @deprecated
|
|
365
|
+
* @function stringFormat
|
|
366
|
+
* @memberOf module:Logging
|
|
367
|
+
*/
|
|
368
|
+
const stringFormat = sf;
|
|
369
|
+
|
|
370
|
+
/**
|
|
371
|
+
* @description Determines if the current environment is a browser by checking the prototype chain of the global object.
|
|
372
|
+
* @summary Checks if the code is running in a browser environment.
|
|
373
|
+
* @return {boolean} True if the environment is a browser, false otherwise.
|
|
374
|
+
* @function isBrowser
|
|
375
|
+
* @memberOf module:Logging
|
|
376
|
+
*/
|
|
377
|
+
function isBrowser() {
|
|
378
|
+
return (Object.getPrototypeOf(Object.getPrototypeOf(globalThis)) !==
|
|
379
|
+
Object.prototype);
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
/**
|
|
383
|
+
* @class Environment
|
|
384
|
+
* @extends {ObjectAccumulator<T>}
|
|
385
|
+
* @template T
|
|
386
|
+
* @description A class representing an environment with accumulation capabilities.
|
|
387
|
+
* @summary Manages environment-related data and provides methods for accumulation and key retrieval.
|
|
388
|
+
* @param {T} [initialData] - The initial data to populate the environment with.
|
|
389
|
+
*/
|
|
390
|
+
class Environment extends ObjectAccumulator {
|
|
391
|
+
/**
|
|
392
|
+
* @static
|
|
393
|
+
* @protected
|
|
394
|
+
* @description A factory function for creating Environment instances.
|
|
395
|
+
* @summary Defines how new instances of the Environment class should be created.
|
|
396
|
+
* @return {Environment<any>} A new instance of the Environment class.
|
|
397
|
+
*/
|
|
398
|
+
static { this.factory = () => new Environment(); }
|
|
399
|
+
constructor() {
|
|
400
|
+
super();
|
|
401
|
+
}
|
|
402
|
+
/**
|
|
403
|
+
* @description Retrieves a value from the environment
|
|
404
|
+
* @summary Gets a value from the environment variables, handling browser and Node.js environments differently
|
|
405
|
+
* @param {string} k - The key to retrieve from the environment
|
|
406
|
+
* @return {unknown} The value from the environment, or undefined if not found
|
|
407
|
+
*/
|
|
408
|
+
fromEnv(k) {
|
|
409
|
+
let env;
|
|
410
|
+
if (isBrowser()) {
|
|
411
|
+
env = globalThis[BrowserEnvKey];
|
|
412
|
+
}
|
|
413
|
+
else {
|
|
414
|
+
env = globalThis.process.env;
|
|
415
|
+
k = toENVFormat(k);
|
|
416
|
+
}
|
|
417
|
+
return env[k];
|
|
418
|
+
}
|
|
419
|
+
/**
|
|
420
|
+
* @description Expands an object into the environment
|
|
421
|
+
* @summary Defines properties on the environment object that can be accessed as getters and setters
|
|
422
|
+
* @template V - Type of the object being expanded
|
|
423
|
+
* @param {V} value - The object to expand into the environment
|
|
424
|
+
* @return {void}
|
|
425
|
+
*/
|
|
426
|
+
expand(value) {
|
|
427
|
+
Object.entries(value).forEach(([k, v]) => {
|
|
428
|
+
Object.defineProperty(this, k, {
|
|
429
|
+
get: () => {
|
|
430
|
+
const fromEnv = this.fromEnv(k);
|
|
431
|
+
if (typeof fromEnv !== "undefined")
|
|
432
|
+
return fromEnv;
|
|
433
|
+
if (v && typeof v === "object") {
|
|
434
|
+
return Environment.buildEnvProxy(v, [k]);
|
|
435
|
+
}
|
|
436
|
+
// If the model provides an empty string, expose a proxy that composes ENV keys
|
|
437
|
+
if (v === "") {
|
|
438
|
+
return Environment.buildEnvProxy(undefined, [k]);
|
|
439
|
+
}
|
|
440
|
+
return v;
|
|
441
|
+
},
|
|
442
|
+
set: (val) => {
|
|
443
|
+
v = val;
|
|
444
|
+
},
|
|
445
|
+
configurable: true,
|
|
446
|
+
enumerable: true,
|
|
447
|
+
});
|
|
448
|
+
});
|
|
449
|
+
}
|
|
450
|
+
/**
|
|
451
|
+
* @protected
|
|
452
|
+
* @static
|
|
453
|
+
* @description Retrieves or creates the singleton instance of the Environment class.
|
|
454
|
+
* @summary Ensures only one instance of the Environment class exists.
|
|
455
|
+
* @template E
|
|
456
|
+
* @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.
|
|
457
|
+
* @return {E} The singleton instance of the Environment class.
|
|
458
|
+
*/
|
|
459
|
+
static instance(...args) {
|
|
460
|
+
if (!Environment._instance) {
|
|
461
|
+
const base = Environment.factory(...args);
|
|
462
|
+
const proxied = new Proxy(base, {
|
|
463
|
+
get(target, prop, receiver) {
|
|
464
|
+
const value = Reflect.get(target, prop, receiver);
|
|
465
|
+
if (typeof value !== "undefined")
|
|
466
|
+
return value;
|
|
467
|
+
if (typeof prop === "string") {
|
|
468
|
+
// Avoid interfering with logging config lookups for optional fields like 'app'
|
|
469
|
+
if (prop === "app")
|
|
470
|
+
return undefined;
|
|
471
|
+
return Environment.buildEnvProxy(undefined, [prop]);
|
|
472
|
+
}
|
|
473
|
+
return value;
|
|
474
|
+
},
|
|
475
|
+
});
|
|
476
|
+
Environment._instance = proxied;
|
|
477
|
+
}
|
|
478
|
+
return Environment._instance;
|
|
479
|
+
}
|
|
480
|
+
/**
|
|
481
|
+
* @static
|
|
482
|
+
* @description Accumulates the given value into the environment.
|
|
483
|
+
* @summary Adds new properties to the environment from the provided object.
|
|
484
|
+
* @template V
|
|
485
|
+
* @param {V} value - The object to accumulate into the environment.
|
|
486
|
+
* @return {V} The updated environment instance.
|
|
487
|
+
*/
|
|
488
|
+
static accumulate(value) {
|
|
489
|
+
const instance = Environment.instance();
|
|
490
|
+
Object.keys(instance).forEach((key) => {
|
|
491
|
+
const desc = Object.getOwnPropertyDescriptor(instance, key);
|
|
492
|
+
if (desc && desc.configurable && desc.enumerable) {
|
|
493
|
+
Object.defineProperty(instance, key, {
|
|
494
|
+
...desc,
|
|
495
|
+
enumerable: false,
|
|
496
|
+
});
|
|
497
|
+
}
|
|
498
|
+
});
|
|
499
|
+
return instance.accumulate(value);
|
|
500
|
+
}
|
|
501
|
+
static get(key) {
|
|
502
|
+
return Environment._instance.get(key);
|
|
503
|
+
}
|
|
504
|
+
static buildEnvProxy(current, path) {
|
|
505
|
+
const buildKey = (p) => p.map((seg) => toENVFormat(seg)).join(ENV_PATH_DELIMITER);
|
|
506
|
+
// Helper to read from the active environment given a composed key
|
|
507
|
+
const readEnv = (key) => {
|
|
508
|
+
if (isBrowser()) {
|
|
509
|
+
const env = globalThis[BrowserEnvKey];
|
|
510
|
+
return env ? env[key] : undefined;
|
|
511
|
+
}
|
|
512
|
+
return globalThis?.process?.env?.[key];
|
|
513
|
+
};
|
|
514
|
+
const handler = {
|
|
515
|
+
get(_target, prop) {
|
|
516
|
+
if (prop === Symbol.toPrimitive) {
|
|
517
|
+
return () => buildKey(path);
|
|
518
|
+
}
|
|
519
|
+
if (prop === "toString") {
|
|
520
|
+
return () => buildKey(path);
|
|
521
|
+
}
|
|
522
|
+
if (prop === "valueOf") {
|
|
523
|
+
return () => buildKey(path);
|
|
524
|
+
}
|
|
525
|
+
if (typeof prop === "symbol")
|
|
526
|
+
return undefined;
|
|
527
|
+
const nextModel = current && Object.prototype.hasOwnProperty.call(current, prop)
|
|
528
|
+
? current[prop]
|
|
529
|
+
: undefined;
|
|
530
|
+
const nextPath = [...path, prop];
|
|
531
|
+
const composedKey = buildKey(nextPath);
|
|
532
|
+
// If an ENV value exists for this path, return it directly
|
|
533
|
+
const envValue = readEnv(composedKey);
|
|
534
|
+
if (typeof envValue !== "undefined")
|
|
535
|
+
return envValue;
|
|
536
|
+
// Otherwise, if the model has an object at this path, keep drilling with a proxy
|
|
537
|
+
const isNextObject = nextModel && typeof nextModel === "object";
|
|
538
|
+
if (isNextObject)
|
|
539
|
+
return Environment.buildEnvProxy(nextModel, nextPath);
|
|
540
|
+
// Always return a proxy for further path composition when no ENV value;
|
|
541
|
+
// do not surface primitive model defaults here (this API is for key composition).
|
|
542
|
+
return Environment.buildEnvProxy(undefined, nextPath);
|
|
543
|
+
},
|
|
544
|
+
ownKeys() {
|
|
545
|
+
return current ? Reflect.ownKeys(current) : [];
|
|
546
|
+
},
|
|
547
|
+
getOwnPropertyDescriptor(_t, p) {
|
|
548
|
+
if (!current)
|
|
549
|
+
return undefined;
|
|
550
|
+
if (Object.prototype.hasOwnProperty.call(current, p)) {
|
|
551
|
+
return { enumerable: true, configurable: true };
|
|
552
|
+
}
|
|
553
|
+
return undefined;
|
|
554
|
+
},
|
|
555
|
+
};
|
|
556
|
+
const target = {};
|
|
557
|
+
return new Proxy(target, handler);
|
|
558
|
+
}
|
|
559
|
+
/**
|
|
560
|
+
* @static
|
|
561
|
+
* @description Retrieves the keys of the environment, optionally converting them to ENV format.
|
|
562
|
+
* @summary Gets all keys in the environment, with an option to format them for environment variables.
|
|
563
|
+
* @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.
|
|
564
|
+
* @return {string[]} An array of keys from the environment.
|
|
565
|
+
*/
|
|
566
|
+
static keys(toEnv = true) {
|
|
567
|
+
return Environment.instance()
|
|
568
|
+
.keys()
|
|
569
|
+
.map((k) => (toEnv ? toENVFormat(k) : k));
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
const LoggedEnvironment = Environment.accumulate(Object.assign({}, DefaultLoggingConfig, {
|
|
573
|
+
env: (isBrowser() && globalThis[BrowserEnvKey]
|
|
574
|
+
? globalThis[BrowserEnvKey]["NODE_ENV"]
|
|
575
|
+
: globalThis.process.env["NODE_ENV"]) || "development",
|
|
576
|
+
}));
|
|
176
577
|
|
|
177
578
|
/**
|
|
178
579
|
* @description A minimal logger implementation.
|
|
@@ -254,12 +655,22 @@ class MiniLogger {
|
|
|
254
655
|
* @summary Generates a log string with timestamp, colored log level, context, and message
|
|
255
656
|
* @param {LogLevel} level - The log level for this message
|
|
256
657
|
* @param {StringLike | Error} message - The message to log or an Error object
|
|
257
|
-
* @param {string} [
|
|
658
|
+
* @param {string} [error] - Optional error to extract stack trace to include in the log
|
|
258
659
|
* @return {string} A formatted log string with all components
|
|
259
660
|
*/
|
|
260
|
-
createLog(level, message,
|
|
661
|
+
createLog(level, message, error) {
|
|
261
662
|
const log = {};
|
|
262
663
|
const style = this.config("style");
|
|
664
|
+
const separator = this.config("separator");
|
|
665
|
+
const app = this.config("app");
|
|
666
|
+
if (app)
|
|
667
|
+
log.app = style
|
|
668
|
+
? Logging.theme(app, "app", level)
|
|
669
|
+
: app;
|
|
670
|
+
if (separator)
|
|
671
|
+
log.separator = style
|
|
672
|
+
? Logging.theme(separator, "separator", level)
|
|
673
|
+
: separator;
|
|
263
674
|
if (this.config("timestamp")) {
|
|
264
675
|
const date = new Date().toISOString();
|
|
265
676
|
const timestamp = style ? Logging.theme(date, "timestamp", level) : date;
|
|
@@ -291,11 +702,11 @@ class MiniLogger {
|
|
|
291
702
|
? message
|
|
292
703
|
: message.message;
|
|
293
704
|
log.message = msg;
|
|
294
|
-
if (
|
|
295
|
-
stack = style
|
|
296
|
-
? Logging.theme((stack || message.stack), "stack", level)
|
|
297
|
-
: stack;
|
|
298
|
-
log.stack =
|
|
705
|
+
if (error || message instanceof Error) {
|
|
706
|
+
const stack = style
|
|
707
|
+
? Logging.theme((error?.stack || message.stack), "stack", level)
|
|
708
|
+
: error?.stack || "";
|
|
709
|
+
log.stack = ` | ${(error || message).message} - Stack trace:\n${stack}`;
|
|
299
710
|
}
|
|
300
711
|
switch (this.config("format")) {
|
|
301
712
|
case "json":
|
|
@@ -306,7 +717,7 @@ class MiniLogger {
|
|
|
306
717
|
.map((s) => {
|
|
307
718
|
if (!s.match(/\{.*?}/g))
|
|
308
719
|
return s;
|
|
309
|
-
const formattedS =
|
|
720
|
+
const formattedS = sf(s, log);
|
|
310
721
|
if (formattedS !== s)
|
|
311
722
|
return formattedS;
|
|
312
723
|
return undefined;
|
|
@@ -323,12 +734,12 @@ class MiniLogger {
|
|
|
323
734
|
* then uses the appropriate console method to output the formatted log
|
|
324
735
|
* @param {LogLevel} level - The log level of the message
|
|
325
736
|
* @param {StringLike | Error} msg - The message to be logged or an Error object
|
|
326
|
-
* @param {string} [
|
|
737
|
+
* @param {string} [error] - Optional stack trace to include in the log
|
|
327
738
|
* @return {void}
|
|
328
739
|
*/
|
|
329
|
-
log(level, msg,
|
|
330
|
-
|
|
331
|
-
|
|
740
|
+
log(level, msg, error) {
|
|
741
|
+
const confLvl = this.config("level");
|
|
742
|
+
if (NumericLogLevels[confLvl] < NumericLogLevels[level])
|
|
332
743
|
return;
|
|
333
744
|
let method;
|
|
334
745
|
switch (level) {
|
|
@@ -345,7 +756,7 @@ class MiniLogger {
|
|
|
345
756
|
default:
|
|
346
757
|
throw new Error("Invalid log level");
|
|
347
758
|
}
|
|
348
|
-
method(this.createLog(level, msg,
|
|
759
|
+
method(this.createLog(level, msg, error));
|
|
349
760
|
}
|
|
350
761
|
/**
|
|
351
762
|
* @description Logs a message at the silly level
|
|
@@ -391,10 +802,11 @@ class MiniLogger {
|
|
|
391
802
|
* @description Logs a message at the error level
|
|
392
803
|
* @summary Logs a message at the error level for errors and exceptions
|
|
393
804
|
* @param {StringLike | Error} msg - The message to be logged or an Error object
|
|
805
|
+
* @param e
|
|
394
806
|
* @return {void}
|
|
395
807
|
*/
|
|
396
|
-
error(msg) {
|
|
397
|
-
this.log(LogLevel.error, msg);
|
|
808
|
+
error(msg, e) {
|
|
809
|
+
this.log(LogLevel.error, msg, e);
|
|
398
810
|
}
|
|
399
811
|
/**
|
|
400
812
|
* @description Updates the logger configuration
|
|
@@ -479,11 +891,7 @@ class Logging {
|
|
|
479
891
|
static { this._factory = (object, config) => {
|
|
480
892
|
return new MiniLogger(object, config);
|
|
481
893
|
}; }
|
|
482
|
-
|
|
483
|
-
* @description Configuration for the logging system
|
|
484
|
-
* @summary Stores the global logging configuration including verbosity, log level, styling, and formatting settings
|
|
485
|
-
*/
|
|
486
|
-
static { this._config = DefaultLoggingConfig; }
|
|
894
|
+
static { this._config = LoggedEnvironment; }
|
|
487
895
|
constructor() { }
|
|
488
896
|
/**
|
|
489
897
|
* @description Sets the factory function for creating logger instances
|
|
@@ -501,7 +909,9 @@ class Logging {
|
|
|
501
909
|
* @return {void}
|
|
502
910
|
*/
|
|
503
911
|
static setConfig(config) {
|
|
504
|
-
Object.
|
|
912
|
+
Object.entries(config).forEach(([k, v]) => {
|
|
913
|
+
this._config[k] = v;
|
|
914
|
+
});
|
|
505
915
|
}
|
|
506
916
|
/**
|
|
507
917
|
* @description Gets a copy of the current global logging configuration
|
|
@@ -509,7 +919,7 @@ class Logging {
|
|
|
509
919
|
* @return {LoggingConfig} A copy of the current configuration
|
|
510
920
|
*/
|
|
511
921
|
static getConfig() {
|
|
512
|
-
return
|
|
922
|
+
return this._config;
|
|
513
923
|
}
|
|
514
924
|
/**
|
|
515
925
|
* @description Retrieves or creates the global logger instance.
|
|
@@ -563,9 +973,10 @@ class Logging {
|
|
|
563
973
|
* @summary Delegates the error logging to the global logger instance.
|
|
564
974
|
*
|
|
565
975
|
* @param msg - The message to be logged.
|
|
976
|
+
* @param e
|
|
566
977
|
*/
|
|
567
|
-
static error(msg) {
|
|
568
|
-
return this.get().error(msg);
|
|
978
|
+
static error(msg, e) {
|
|
979
|
+
return this.get().error(msg, e);
|
|
569
980
|
}
|
|
570
981
|
/**
|
|
571
982
|
* @description Creates a logger for a specific object or context
|
|
@@ -702,6 +1113,57 @@ class Logging {
|
|
|
702
1113
|
}
|
|
703
1114
|
}
|
|
704
1115
|
|
|
1116
|
+
/**
|
|
1117
|
+
* @description Base class that provides a ready-to-use logger instance
|
|
1118
|
+
* @summary LoggedClass is a convenience abstract class that injects a type-safe logger
|
|
1119
|
+
* into derived classes through a protected getter. Subclasses can directly access
|
|
1120
|
+
* this.log to emit messages without manually creating a logger. This promotes
|
|
1121
|
+
* consistent, context-aware logging across the codebase.
|
|
1122
|
+
* @param {void} [constructor] - No constructor arguments; subclasses may define their own
|
|
1123
|
+
* @class LoggedClass
|
|
1124
|
+
* @example
|
|
1125
|
+
* class UserService extends LoggedClass {
|
|
1126
|
+
* create(user: User) {
|
|
1127
|
+
* this.log.info(`Creating user ${user.id}`);
|
|
1128
|
+
* }
|
|
1129
|
+
* }
|
|
1130
|
+
*
|
|
1131
|
+
* const svc = new UserService();
|
|
1132
|
+
* svc.create({ id: "42" });
|
|
1133
|
+
* @mermaid
|
|
1134
|
+
* sequenceDiagram
|
|
1135
|
+
* participant Client
|
|
1136
|
+
* participant Instance as Subclass Instance
|
|
1137
|
+
* participant Getter as LoggedClass.log
|
|
1138
|
+
* participant Logging as Logging
|
|
1139
|
+
* participant Logger as Logger
|
|
1140
|
+
*
|
|
1141
|
+
* Client->>Instance: call someMethod()
|
|
1142
|
+
* Instance->>Getter: access this.log
|
|
1143
|
+
* Getter->>Logging: Logging.for(this)
|
|
1144
|
+
* Logging-->>Getter: return Logger
|
|
1145
|
+
* Getter-->>Instance: return Logger
|
|
1146
|
+
* Instance->>Logger: info/debug/error(...)
|
|
1147
|
+
*/
|
|
1148
|
+
class LoggedClass {
|
|
1149
|
+
/**
|
|
1150
|
+
* @description Lazily provides a context-aware logger for the current instance
|
|
1151
|
+
* @summary Uses Logging.for(this) to create a logger whose context is the
|
|
1152
|
+
* subclass name, allowing uniform and structured logs from any inheriting class.
|
|
1153
|
+
* @return {Logger} A logger bound to the subclass context
|
|
1154
|
+
*/
|
|
1155
|
+
get log() {
|
|
1156
|
+
return Logging.for(this);
|
|
1157
|
+
}
|
|
1158
|
+
constructor() { }
|
|
1159
|
+
}
|
|
1160
|
+
|
|
1161
|
+
class LogFilter extends LoggedClass {
|
|
1162
|
+
get log() {
|
|
1163
|
+
return super.log.for(this, { filters: [] });
|
|
1164
|
+
}
|
|
1165
|
+
}
|
|
1166
|
+
|
|
705
1167
|
/**
|
|
706
1168
|
* @description Method decorator for logging function calls
|
|
707
1169
|
* @summary Creates a decorator that logs method calls with specified level, benchmarking, and verbosity
|
|
@@ -737,35 +1199,33 @@ function log(level = LogLevel.info, benchmark = false, verbosity = 0) {
|
|
|
737
1199
|
return function (target, propertyKey, descriptor) {
|
|
738
1200
|
if (!descriptor)
|
|
739
1201
|
throw new Error(`Logging decoration only applies to methods`);
|
|
740
|
-
const
|
|
741
|
-
const method =
|
|
1202
|
+
const logger = Logging.for(target).for(target[propertyKey]);
|
|
1203
|
+
const method = logger[level].bind(logger);
|
|
742
1204
|
const originalMethod = descriptor.value;
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
1205
|
+
descriptor.value = new Proxy(originalMethod, {
|
|
1206
|
+
apply(fn, thisArg, args) {
|
|
1207
|
+
method(`called with ${args}`, verbosity);
|
|
1208
|
+
const start = Date.now();
|
|
1209
|
+
try {
|
|
1210
|
+
const result = Reflect.apply(fn, thisArg, args);
|
|
1211
|
+
if (result instanceof Promise) {
|
|
1212
|
+
return result.then((r) => {
|
|
1213
|
+
if (benchmark)
|
|
1214
|
+
method(`completed in ${Date.now() - start}ms`, verbosity);
|
|
1215
|
+
return r;
|
|
1216
|
+
});
|
|
754
1217
|
}
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
Object.assign(func, "name", {
|
|
766
|
-
value: descriptor.value.name,
|
|
1218
|
+
if (benchmark)
|
|
1219
|
+
method(`completed in ${Date.now() - start}ms`, verbosity);
|
|
1220
|
+
return result;
|
|
1221
|
+
}
|
|
1222
|
+
catch (err) {
|
|
1223
|
+
if (benchmark)
|
|
1224
|
+
method(`failed in ${Date.now() - start}ms`, verbosity);
|
|
1225
|
+
throw err;
|
|
1226
|
+
}
|
|
1227
|
+
},
|
|
767
1228
|
});
|
|
768
|
-
descriptor.value = func;
|
|
769
1229
|
};
|
|
770
1230
|
}
|
|
771
1231
|
/**
|
|
@@ -817,51 +1277,56 @@ function verbose(verbosity = 0, benchmark) {
|
|
|
817
1277
|
}
|
|
818
1278
|
return log(LogLevel.verbose, benchmark, verbosity);
|
|
819
1279
|
}
|
|
820
|
-
|
|
821
1280
|
/**
|
|
822
|
-
* @description
|
|
823
|
-
* @summary
|
|
824
|
-
*
|
|
825
|
-
*
|
|
826
|
-
*
|
|
827
|
-
* @
|
|
828
|
-
* @class LoggedClass
|
|
829
|
-
* @example
|
|
830
|
-
* class UserService extends LoggedClass {
|
|
831
|
-
* create(user: User) {
|
|
832
|
-
* this.log.info(`Creating user ${user.id}`);
|
|
833
|
-
* }
|
|
834
|
-
* }
|
|
835
|
-
*
|
|
836
|
-
* const svc = new UserService();
|
|
837
|
-
* svc.create({ id: "42" });
|
|
838
|
-
* @mermaid
|
|
839
|
-
* sequenceDiagram
|
|
840
|
-
* participant Client
|
|
841
|
-
* participant Instance as Subclass Instance
|
|
842
|
-
* participant Getter as LoggedClass.log
|
|
843
|
-
* participant Logging as Logging
|
|
844
|
-
* participant Logger as Logger
|
|
845
|
-
*
|
|
846
|
-
* Client->>Instance: call someMethod()
|
|
847
|
-
* Instance->>Getter: access this.log
|
|
848
|
-
* Getter->>Logging: Logging.for(this)
|
|
849
|
-
* Logging-->>Getter: return Logger
|
|
850
|
-
* Getter-->>Instance: return Logger
|
|
851
|
-
* Instance->>Logger: info/debug/error(...)
|
|
1281
|
+
* @description Creates a decorator that makes a method non-configurable
|
|
1282
|
+
* @summary This decorator prevents a method from being overridden by making it non-configurable.
|
|
1283
|
+
* It throws an error if used on anything other than a method.
|
|
1284
|
+
* @return {Function} A decorator function that can be applied to methods
|
|
1285
|
+
* @function final
|
|
1286
|
+
* @category Method Decorators
|
|
852
1287
|
*/
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
1288
|
+
function final() {
|
|
1289
|
+
return (target, propertyKey, descriptor) => {
|
|
1290
|
+
if (!descriptor)
|
|
1291
|
+
throw new Error("final decorator can only be used on methods");
|
|
1292
|
+
if (descriptor?.configurable) {
|
|
1293
|
+
descriptor.configurable = false;
|
|
1294
|
+
}
|
|
1295
|
+
return descriptor;
|
|
1296
|
+
};
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
class PatternFilter extends LogFilter {
|
|
1300
|
+
constructor(regexp, replacement) {
|
|
1301
|
+
super();
|
|
1302
|
+
this.regexp = regexp;
|
|
1303
|
+
this.replacement = replacement;
|
|
1304
|
+
}
|
|
1305
|
+
match(message) {
|
|
1306
|
+
const match = this.regexp.exec(message);
|
|
1307
|
+
this.regexp.lastIndex = 0;
|
|
1308
|
+
return match;
|
|
1309
|
+
}
|
|
1310
|
+
filter(config, message, context) {
|
|
1311
|
+
const log = this.log.for(this.filter);
|
|
1312
|
+
const match = this.match(message);
|
|
1313
|
+
if (!match)
|
|
1314
|
+
return message;
|
|
1315
|
+
try {
|
|
1316
|
+
return message.replace(this.regexp, this.replacement);
|
|
1317
|
+
}
|
|
1318
|
+
catch (e) {
|
|
1319
|
+
log.error(`PatternFilter replacement error: ${e}`);
|
|
1320
|
+
}
|
|
1321
|
+
return "";
|
|
862
1322
|
}
|
|
863
|
-
constructor() { }
|
|
864
1323
|
}
|
|
1324
|
+
__decorate([
|
|
1325
|
+
final(),
|
|
1326
|
+
__metadata("design:type", Function),
|
|
1327
|
+
__metadata("design:paramtypes", [String]),
|
|
1328
|
+
__metadata("design:returntype", void 0)
|
|
1329
|
+
], PatternFilter.prototype, "match", null);
|
|
865
1330
|
|
|
866
1331
|
/**
|
|
867
1332
|
* @description A logging module for TypeScript applications
|
|
@@ -879,7 +1344,7 @@ class LoggedClass {
|
|
|
879
1344
|
* @const VERSION
|
|
880
1345
|
* @memberOf module:Logging
|
|
881
1346
|
*/
|
|
882
|
-
const VERSION = "0.3.
|
|
1347
|
+
const VERSION = "0.3.9";
|
|
883
1348
|
|
|
884
|
-
export { DefaultLoggingConfig, DefaultTheme, LogLevel, LoggedClass, Logging, LoggingMode, MiniLogger, NumericLogLevels, VERSION, debug, info, log, silly, stringFormat, verbose };
|
|
885
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"logging.esm.cjs","sources":["../src/constants.ts","../src/utils.ts","../src/logging.ts","../src/decorators.ts","../src/LoggedClass.ts","../src/index.ts"],"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      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  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  format: \"raw\",\n  pattern: \"{level} [{timestamp}] {context} - {message} {stack}\",\n  theme: DefaultTheme,\n};\n","/**\n * @summary Util function to provide string format functionality similar to C#'s string.format\n *\n * @param {string} string\n * @param {Array<string | number> | Record<string, any>} [args] replacements made by order of appearance (replacement0 wil replace {0} and so on)\n * @return {string} formatted string\n *\n * @function stringFormat\n * @memberOf module:logging\n * @category Model\n */\nexport function stringFormat(\n  string: string,\n  ...args: (string | number | Record<string, any>)[]\n) {\n  if (args.length > 1) {\n    if (\n      !args.every((arg) => typeof arg === \"string\" || typeof arg === \"number\")\n    )\n      throw new Error(\n        `Only string and number arguments are supported for multiple replacements.`\n      );\n  }\n\n  if (args.length === 1 && typeof args[0] === \"object\") {\n    const obj = args[0] as Record<string, any>;\n    return Object.entries(obj).reduce((acc, [key, val]) => {\n      return acc.replace(new RegExp(`\\\\{${key}\\\\}`, \"g\"), function () {\n        return val;\n      });\n    }, string);\n  }\n\n  return string.replace(/{(\\d+)}/g, function (match, number) {\n    return typeof args[number] !== \"undefined\"\n      ? args[number].toString()\n      : \"undefined\";\n  });\n}\n","import {\n  LoggerFactory,\n  LoggingConfig,\n  LoggingContext,\n  StringLike,\n  Theme,\n  ThemeOption,\n  ThemeOptionByLogLevel,\n  Logger,\n} from \"./types\";\nimport { ColorizeOptions, style, StyledString } from \"styled-string-builder\";\nimport {\n  DefaultLoggingConfig,\n  DefaultTheme,\n  LogLevel,\n  NumericLogLevels,\n} from \"./constants\";\nimport { stringFormat } from \"./utils\";\n\n/**\n * @description A minimal logger implementation.\n * @summary MiniLogger is a lightweight logging class that implements the Logger interface.\n * It provides basic logging functionality with support for different log levels, verbosity,\n * context-aware logging, and customizable formatting.\n * @param {string} context - The context (typically class name) this logger is associated with\n * @param {Partial<LoggingConfig>} conf - Optional configuration to override global settings\n * @class MiniLogger\n * @example\n * // Create a new logger for a class\n * const logger = new MiniLogger('MyClass');\n *\n * // Log messages at different levels\n * logger.info('This is an info message');\n * logger.debug('This is a debug message');\n * logger.error('Something went wrong');\n *\n * // Create a child logger for a specific method\n * const methodLogger = logger.for('myMethod');\n * methodLogger.verbose('Detailed information', 2);\n *\n * // Log with custom configuration\n * logger.for('specialMethod', { style: true }).info('Styled message');\n */\nexport class MiniLogger implements Logger {\n  constructor(\n    protected context: string,\n    protected conf?: Partial<LoggingConfig>\n  ) {}\n\n  protected config(\n    key: keyof LoggingConfig\n  ): LoggingConfig[keyof LoggingConfig] {\n    if (this.conf && key in this.conf) return this.conf[key];\n    return Logging.getConfig()[key];\n  }\n\n  for(method: string | ((...args: any[]) => any)): Logger;\n  for(config: Partial<LoggingConfig>): Logger;\n  for(\n    method: string | ((...args: any[]) => any) | Partial<LoggingConfig>,\n    config: Partial<LoggingConfig>,\n    ...args: any[]\n  ): Logger;\n  /**\n   * @description Creates a child logger for a specific method or context\n   * @summary Returns a new logger instance with the current context extended by the specified method name\n   * @param {string | Function} method - The method name or function to create a logger for\n   * @param {Partial<LoggingConfig>} config - Optional configuration to override settings\n   * @param {...any[]} args - Additional arguments to pass to the logger factory\n   * @return {Logger} A new logger instance for the specified method\n   */\n  for(\n    method?: string | ((...args: any[]) => any) | Partial<LoggingConfig>,\n    config?: Partial<LoggingConfig>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Logger {\n    if (!config && typeof method === \"object\") {\n      config = method;\n      method = undefined;\n    } else {\n      method = method\n        ? typeof method === \"string\"\n          ? method\n          : (method as any).name\n        : undefined;\n    }\n\n    return new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        const result = Reflect.get(target, p, receiver);\n        if (p === \"config\") {\n          return new Proxy(this.config, {\n            get: (target: typeof this.config, p: string | symbol) => {\n              if (config && p in config)\n                return config[p as keyof LoggingConfig];\n              return Reflect.get(target, p, receiver);\n            },\n          });\n        }\n        if (p === \"context\" && method) {\n          return [result, method].join(\".\");\n        }\n        return result;\n      },\n    });\n  }\n\n  /**\n   * @description Creates a formatted log string\n   * @summary Generates a log string with timestamp, colored log level, context, and message\n   * @param {LogLevel} level - The log level for this message\n   * @param {StringLike | Error} message - The message to log or an Error object\n   * @param {string} [stack] - Optional stack trace to include in the log\n   * @return {string} A formatted log string with all components\n   */\n  protected createLog(\n    level: LogLevel,\n    message: StringLike | Error,\n    stack?: string\n  ): string {\n    const log: Record<\n      \"timestamp\" | \"level\" | \"context\" | \"correlationId\" | \"message\" | \"stack\",\n      string\n    > = {} as any;\n    const style = this.config(\"style\");\n    if (this.config(\"timestamp\")) {\n      const date = new Date().toISOString();\n      const timestamp = style ? Logging.theme(date, \"timestamp\", level) : date;\n      log.timestamp = timestamp;\n    }\n\n    if (this.config(\"logLevel\")) {\n      const lvl: string = style\n        ? Logging.theme(level, \"logLevel\", level)\n        : level;\n      log.level = lvl.toUpperCase();\n    }\n\n    if (this.config(\"context\")) {\n      const context: string = style\n        ? Logging.theme(this.context, \"class\", level)\n        : this.context;\n      log.context = context;\n    }\n\n    if (this.config(\"correlationId\")) {\n      {\n        const id: string = style\n          ? Logging.theme(this.config(\"correlationId\")!.toString(), \"id\", level)\n          : this.config(\"correlationId\")!.toString();\n        log.correlationId = id;\n      }\n    }\n\n    const msg: string = style\n      ? Logging.theme(\n          typeof message === \"string\" ? message : (message as Error).message,\n          \"message\",\n          level\n        )\n      : typeof message === \"string\"\n        ? message\n        : (message as Error).message;\n    log.message = msg;\n    if (stack || message instanceof Error) {\n      stack = style\n        ? Logging.theme(\n            (stack || (message as Error).stack) as string,\n            \"stack\",\n            level\n          )\n        : stack;\n      log.stack = `\\nStack trace:\\n${stack}`;\n    }\n\n    switch (this.config(\"format\")) {\n      case \"json\":\n        return JSON.stringify(log);\n      case \"raw\":\n        return (this.config(\"pattern\") as string)\n          .split(\" \")\n          .map((s) => {\n            if (!s.match(/\\{.*?}/g)) return s;\n            const formattedS = stringFormat(s, log);\n            if (formattedS !== s) return formattedS;\n            return undefined;\n          })\n          .filter((s) => s)\n          .join(\" \");\n      default:\n        throw new Error(`Unsupported logging format: ${this.config(\"format\")}`);\n    }\n  }\n\n  /**\n   * @description Logs a message with the specified log level\n   * @summary Checks if the message should be logged based on the current log level,\n   * then uses the appropriate console method to output the formatted log\n   * @param {LogLevel} level - The log level of the message\n   * @param {StringLike | Error} msg - The message to be logged or an Error object\n   * @param {string} [stack] - Optional stack trace to include in the log\n   * @return {void}\n   */\n  protected log(\n    level: LogLevel,\n    msg: StringLike | Error,\n    stack?: string\n  ): void {\n    if (\n      NumericLogLevels[this.config(\"level\") as LogLevel] <\n      NumericLogLevels[level]\n    )\n      return;\n    let method;\n    switch (level) {\n      case LogLevel.info:\n        method = console.log;\n        break;\n      case LogLevel.verbose:\n      case LogLevel.debug:\n        method = console.debug;\n        break;\n      case LogLevel.error:\n        method = console.error;\n        break;\n      default:\n        throw new Error(\"Invalid log level\");\n    }\n    method(this.createLog(level, msg, stack));\n  }\n\n  /**\n   * @description Logs a message at the silly level\n   * @summary Logs a message at the silly level if the current verbosity setting allows it\n   * @param {StringLike} msg - The message to be logged\n   * @param {number} [verbosity=0] - The verbosity level of the message\n   * @return {void}\n   */\n  silly(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs a message at the verbose level\n   * @summary Logs a message at the verbose level if the current verbosity setting allows it\n   * @param {StringLike} msg - The message to be logged\n   * @param {number} [verbosity=0] - The verbosity level of the message\n   * @return {void}\n   */\n  verbose(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs a message at the info level\n   * @summary Logs a message at the info level for general application information\n   * @param {StringLike} msg - The message to be logged\n   * @return {void}\n   */\n  info(msg: StringLike): void {\n    this.log(LogLevel.info, msg);\n  }\n\n  /**\n   * @description Logs a message at the debug level\n   * @summary Logs a message at the debug level for detailed troubleshooting information\n   * @param {StringLike} msg - The message to be logged\n   * @return {void}\n   */\n  debug(msg: StringLike): void {\n    this.log(LogLevel.debug, msg);\n  }\n\n  /**\n   * @description Logs a message at the error level\n   * @summary Logs a message at the error level for errors and exceptions\n   * @param {StringLike | Error} msg - The message to be logged or an Error object\n   * @return {void}\n   */\n  error(msg: StringLike | Error): void {\n    this.log(LogLevel.error, msg);\n  }\n\n  /**\n   * @description Updates the logger configuration\n   * @summary Merges the provided configuration with the existing configuration\n   * @param {Partial<LoggingConfig>} config - The configuration options to apply\n   * @return {void}\n   */\n  setConfig(config: Partial<LoggingConfig>): void {\n    this.conf = { ...(this.conf || {}), ...config };\n  }\n}\n\n/**\n * @description A static class for managing logging operations\n * @summary The Logging class provides a centralized logging mechanism with support for\n * different log levels, verbosity, and styling. It uses a singleton pattern to maintain a global\n * logger instance and allows creating specific loggers for different classes and methods.\n * @class Logging\n * @example\n * // Set global configuration\n * Logging.setConfig({ level: LogLevel.debug, style: true });\n *\n * // Get a logger for a specific class\n * const logger = Logging.for('MyClass');\n *\n * // Log messages at different levels\n * logger.info('Application started');\n * logger.debug('Processing data...');\n *\n * // Log with context\n * const methodLogger = Logging.for('MyClass.myMethod');\n * methodLogger.verbose('Detailed operation information', 1);\n *\n * // Log errors\n * try {\n *   // some operation\n * } catch (error) {\n *   logger.error(error);\n * }\n * @mermaid\n * classDiagram\n *   class Logger {\n *     <<interface>>\n *     +for(method, config, ...args)\n *     +silly(msg, verbosity)\n *     +verbose(msg, verbosity)\n *     +info(msg)\n *     +debug(msg)\n *     +error(msg)\n *     +setConfig(config)\n *   }\n *\n *   class Logging {\n *     -global: Logger\n *     -_factory: LoggerFactory\n *     -_config: LoggingConfig\n *     +setFactory(factory)\n *     +setConfig(config)\n *     +getConfig()\n *     +get()\n *     +verbose(msg, verbosity)\n *     +info(msg)\n *     +debug(msg)\n *     +silly(msg)\n *     +error(msg)\n *     +for(object, config, ...args)\n *     +because(reason, id)\n *     +theme(text, type, loggerLevel, template)\n *   }\n *\n *   class MiniLogger {\n *     +constructor(context, conf?)\n *   }\n *\n *   Logging ..> Logger : creates\n *   Logging ..> MiniLogger : creates by default\n */\nexport class Logging {\n  /**\n   * @description The global logger instance\n   * @summary A singleton instance of Logger used for global logging\n   */\n  private static global?: Logger;\n\n  /**\n   * @description Factory function for creating logger instances\n   * @summary A function that creates new Logger instances. By default, it creates a MiniLogger.\n   */\n  private static _factory: LoggerFactory = (\n    object: string,\n    config?: Partial<LoggingConfig>\n  ) => {\n    return new MiniLogger(object, config);\n  };\n  /**\n   * @description Configuration for the logging system\n   * @summary Stores the global logging configuration including verbosity, log level, styling, and formatting settings\n   */\n  private static _config: LoggingConfig = DefaultLoggingConfig;\n\n  private constructor() {}\n\n  /**\n   * @description Sets the factory function for creating logger instances\n   * @summary Allows customizing how logger instances are created\n   * @param {LoggerFactory} factory - The factory function to use for creating loggers\n   * @return {void}\n   */\n  static setFactory(factory: LoggerFactory) {\n    Logging._factory = factory;\n  }\n\n  /**\n   * @description Updates the global logging configuration\n   * @summary Allows updating the global logging configuration with new settings\n   * @param {Partial<LoggingConfig>} config - The configuration options to apply\n   * @return {void}\n   */\n  static setConfig(config: Partial<LoggingConfig>) {\n    Object.assign(this._config, config);\n  }\n\n  /**\n   * @description Gets a copy of the current global logging configuration\n   * @summary Returns a copy of the current global logging configuration\n   * @return {LoggingConfig} A copy of the current configuration\n   */\n  static getConfig(): LoggingConfig {\n    return Object.assign({}, this._config);\n  }\n\n  /**\n   * @description Retrieves or creates the global logger instance.\n   * @summary Returns the existing global logger or creates a new one if it doesn't exist.\n   *\n   * @return The global VerbosityLogger instance.\n   */\n  static get(): Logger {\n    this.global = this.global ? this.global : this._factory(\"Logging\");\n    return this.global;\n  }\n\n  /**\n   * @description Logs a verbose message.\n   * @summary Delegates the verbose logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   * @param verbosity - The verbosity level of the message (default: 0).\n   */\n  static verbose(msg: StringLike, verbosity: number = 0): void {\n    return this.get().verbose(msg, verbosity);\n  }\n\n  /**\n   * @description Logs an info message.\n   * @summary Delegates the info logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static info(msg: StringLike): void {\n    return this.get().info(msg);\n  }\n\n  /**\n   * @description Logs a debug message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static debug(msg: StringLike): void {\n    return this.get().debug(msg);\n  }\n\n  /**\n   * @description Logs a silly message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static silly(msg: StringLike): void {\n    return this.get().silly(msg);\n  }\n\n  /**\n   * @description Logs an error message.\n   * @summary Delegates the error logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static error(msg: StringLike): void {\n    return this.get().error(msg);\n  }\n\n  /**\n   * @description Creates a logger for a specific object or context\n   * @summary Creates a new logger instance for the given object or context using the factory function\n   * @param {LoggingContext} object - The object, class, or context to create a logger for\n   * @param {Partial<LoggingConfig>} [config] - Optional configuration to override global settings\n   * @param {...any} args - Additional arguments to pass to the logger factory\n   * @return {Logger} A new logger instance for the specified object or context\n   */\n  static for(\n    object: LoggingContext,\n    config?: Partial<LoggingConfig>,\n    ...args: any[]\n  ): Logger {\n    object =\n      typeof object === \"string\"\n        ? object\n        : object.constructor\n          ? object.constructor.name\n          : object.name;\n    return this._factory(object, config, ...args);\n  }\n\n  /**\n   * @description Creates a logger for a specific reason or correlation context\n   * @summary Utility to quickly create a logger labeled with a free-form reason and optional identifier\n   * so that ad-hoc operations can be traced without tying the logger to a class or method name.\n   * @param {string} reason - A textual reason or context label for this logger instance\n   * @param {string} [id] - Optional identifier to help correlate related log entries\n   * @return {Logger} A new logger instance labeled with the provided reason and id\n   */\n  static because(reason: string, id?: string): Logger {\n    return this._factory(reason, this._config, id);\n  }\n\n  /**\n   * @description Applies theme styling to text\n   * @summary Applies styling (colors, formatting) to text based on the theme configuration\n   * @param {string} text - The text to style\n   * @param {string} type - The type of element to style (e.g., \"class\", \"message\", \"logLevel\")\n   * @param {LogLevel} loggerLevel - The log level to use for styling\n   * @param {Theme} [template=DefaultTheme] - The theme to use for styling\n   * @return {string} The styled text\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant Theme as Logging.theme\n   *   participant Apply as apply function\n   *   participant Style as styled-string-builder\n   *\n   *   Caller->>Theme: theme(text, type, loggerLevel)\n   *   Theme->>Theme: Check if styling is enabled\n   *   alt styling disabled\n   *     Theme-->>Caller: return original text\n   *   else styling enabled\n   *     Theme->>Theme: Get theme for type\n   *     alt theme not found\n   *       Theme-->>Caller: return original text\n   *     else theme found\n   *       Theme->>Theme: Determine actual theme based on log level\n   *       Theme->>Apply: Apply each style property\n   *       Apply->>Style: Apply colors and formatting\n   *       Style-->>Apply: Return styled text\n   *       Apply-->>Theme: Return styled text\n   *       Theme-->>Caller: Return final styled text\n   *     end\n   *   end\n   */\n  static theme(\n    text: string,\n    type: keyof Theme | keyof LogLevel,\n    loggerLevel: LogLevel,\n    template: Theme = DefaultTheme\n  ) {\n    if (!this._config.style) return text;\n    const logger = Logging.get().for(this.theme);\n\n    function apply(\n      txt: string,\n      option: keyof ThemeOption,\n      value: number | [number] | [number, number, number] | number[] | string[]\n    ): string {\n      try {\n        const t: string | StyledString = txt;\n        let c = style(t);\n\n        function applyColor(\n          val: number | [number] | [number, number, number],\n          isBg = false\n        ): StyledString {\n          let f:\n            | typeof c.background\n            | typeof c.foreground\n            | typeof c.rgb\n            | typeof c.color256 = isBg ? c.background : c.foreground;\n          if (!Array.isArray(val)) {\n            return (f as typeof c.background | typeof c.foreground).call(\n              c,\n              value as number\n            );\n          }\n          switch (val.length) {\n            case 1:\n              f = isBg ? c.bgColor256 : c.color256;\n              return (f as typeof c.bgColor256 | typeof c.color256)(val[0]);\n            case 3:\n              f = isBg ? c.bgRgb : c.rgb;\n              return c.rgb(val[0], val[1], val[2]);\n            default:\n              logger.error(`Not a valid color option: ${option}`);\n              return style(t as string);\n          }\n        }\n\n        function applyStyle(v: number | string): void {\n          if (typeof v === \"number\") {\n            c = c.style(v);\n          } else {\n            c = c[v as keyof ColorizeOptions] as StyledString;\n          }\n        }\n\n        switch (option) {\n          case \"bg\":\n          case \"fg\":\n            return applyColor(value as number).text;\n          case \"style\":\n            if (Array.isArray(value)) {\n              value.forEach(applyStyle);\n            } else {\n              applyStyle(value as number | string);\n            }\n            return c.text;\n          default:\n            logger.error(`Not a valid theme option: ${option}`);\n            return t;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        logger.error(`Error applying style: ${option} with value ${value}`);\n        return txt;\n      }\n    }\n\n    const individualTheme = template[type as keyof Theme];\n    if (!individualTheme || !Object.keys(individualTheme).length) {\n      return text;\n    }\n\n    let actualTheme: ThemeOption = individualTheme as ThemeOption;\n\n    const logLevels = Object.assign({}, LogLevel);\n    if (Object.keys(individualTheme)[0] in logLevels)\n      actualTheme =\n        (individualTheme as ThemeOptionByLogLevel)[loggerLevel] || {};\n\n    return Object.keys(actualTheme).reduce((acc: string, key: string) => {\n      const val = (actualTheme as ThemeOption)[key as keyof ThemeOption];\n      if (val)\n        return apply(\n          acc,\n          key as keyof ThemeOption,\n          val as\n            | number\n            | [number]\n            | [number, number, number]\n            | number[]\n            | string[]\n        );\n      return acc;\n    }, text);\n  }\n}\n","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?: any,\n    descriptor?: PropertyDescriptor\n  ) {\n    if (!descriptor)\n      throw new Error(`Logging decoration only applies to methods`);\n    const log = Logging.for(target).for(target[propertyKey]);\n    const method = log[level].bind(log);\n    const originalMethod = descriptor.value;\n\n    const func = function (this: typeof target, ...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    }.bind(target) as any;\n\n    Object.assign(func, \"name\", {\n      value: descriptor.value.name,\n    });\n\n    descriptor.value = func;\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(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => 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(\n  benchmark: boolean\n): (target: any, propertyKey?: any, descriptor?: any) => 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 * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(\n  verbosity: number | boolean\n): (target: any, propertyKey?: any, descriptor?: any) => void;\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","import { Logging } from \"./logging\";\nimport { Logger } from \"./types\";\n\n/**\n * @description Base class that provides a ready-to-use logger instance\n * @summary LoggedClass is a convenience abstract class that injects a type-safe logger\n * into derived classes through a protected getter. Subclasses can directly access\n * this.log to emit messages without manually creating a logger. This promotes\n * consistent, context-aware logging across the codebase.\n * @param {void} [constructor] - No constructor arguments; subclasses may define their own\n * @class LoggedClass\n * @example\n * class UserService extends LoggedClass {\n *   create(user: User) {\n *     this.log.info(`Creating user ${user.id}`);\n *   }\n * }\n *\n * const svc = new UserService();\n * svc.create({ id: \"42\" });\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Instance as Subclass Instance\n *   participant Getter as LoggedClass.log\n *   participant Logging as Logging\n *   participant Logger as Logger\n *\n *   Client->>Instance: call someMethod()\n *   Instance->>Getter: access this.log\n *   Getter->>Logging: Logging.for(this)\n *   Logging-->>Getter: return Logger\n *   Getter-->>Instance: return Logger\n *   Instance->>Logger: info/debug/error(...)\n */\nexport abstract class LoggedClass {\n  /**\n   * @description Lazily provides a context-aware logger for the current instance\n   * @summary Uses Logging.for(this) to create a logger whose context is the\n   * subclass name, allowing uniform and structured logs from any inheriting class.\n   * @return {Logger} A logger bound to the subclass context\n   */\n  protected get log(): Logger {\n    return Logging.for(this as any);\n  }\n\n  protected constructor() {}\n}\n","export * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./LoggedClass\";\nexport * from \"./logging\";\nexport * from \"./types\";\nexport * from \"./utils\";\n\n/**\n * @description A logging module for TypeScript applications\n * @summary Provides a comprehensive, flexible logging solution. This module exposes:\n * - Core classes like {@link Logging} and {@link MiniLogger}\n * - Decorators such as {@link log} for instrumenting methods\n * - Configuration and constants like {@link LogLevel} and {@link DefaultLoggingConfig}\n * - Type definitions including {@link Logger} and {@link LoggingConfig}\n * These exports enable consistent, context-aware, and optionally themed logging across projects.\n * @module Logging\n */\n\n/**\n * @description Current package version string\n * @summary Stores the current package version, used for version tracking and compatibility checks\n * @const VERSION\n * @memberOf module:Logging\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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"}
|
|
1349
|
+
export { BrowserEnvKey, DefaultLoggingConfig, DefaultPlaceholderWrappers, DefaultTheme, ENV_PATH_DELIMITER, Environment, LogFilter, LogLevel, LoggedClass, LoggedEnvironment, Logging, LoggingMode, MiniLogger, NumericLogLevels, PatternFilter, VERSION, debug, escapeRegExp, final, info, isBrowser, log, padEnd, patchPlaceholders, patchString, sf, silly, stringFormat, toCamelCase, toENVFormat, toKebabCase, toPascalCase, toSnakeCase, verbose };
|
|
1350
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"logging.esm.cjs","sources":["../src/constants.ts","../src/text.ts","../src/web.ts","../src/environment.ts","../src/logging.ts","../src/LoggedClass.ts","../src/filters/LogFilter.ts","../src/decorators.ts","../src/filters/PatternFilter.ts","../src/index.ts"],"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","import { DefaultPlaceholderWrappers } from \"./constants\";\n\n/**\n * @description Pads the end of a string with a specified character.\n * @summary Extends the input string to a specified length by adding a padding character to the end.\n * If the input string is already longer than the specified length, it is returned unchanged.\n *\n * @param {string} str - The input string to be padded.\n * @param {number} length - The desired total length of the resulting string.\n * @param {string} [char=\" \"] - The character to use for padding. Defaults to a space.\n * @return {string} The padded string.\n * @throws {Error} If the padding character is not exactly one character long.\n *\n * @function padEnd\n *\n * @memberOf module:Logging\n */\nexport function padEnd(\n  str: string,\n  length: number,\n  char: string = \" \"\n): string {\n  if (char.length !== 1)\n    throw new Error(\"Invalid character length for padding. must be one!\");\n  return str.padEnd(length, char);\n}\n\n/**\n * @description Replaces placeholders in a string with provided values.\n * @summary Interpolates a string by replacing placeholders of the form ${variableName}\n * with corresponding values from the provided object. If a placeholder doesn't have\n * a corresponding value, it is left unchanged in the string.\n *\n * @param {string} input - The input string containing placeholders to be replaced.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @param prefix\n * @param suffix\n * @param flags\n * @return {string} The interpolated string with placeholders replaced by their corresponding values.\n *\n * @function patchPlaceholders\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchString\n *   participant String.replace\n *   Caller->>patchString: Call with input and values\n *   patchString->>String.replace: Call with regex and replacement function\n *   String.replace->>patchString: Return replaced string\n *   patchString-->>Caller: Return patched string\n *\n * @memberOf module:Logging\n */\nexport function patchPlaceholders(\n  input: string,\n  values: Record<string, number | string>,\n  prefix: string = DefaultPlaceholderWrappers[0],\n  suffix: string = DefaultPlaceholderWrappers[1],\n  flags: string = \"g\"\n): string {\n  const placeholders = Object.entries(values).reduce(\n    (acc: Record<string, any>, [key, val]) => {\n      acc[`${prefix}${key}${suffix}`] = val;\n      return acc;\n    },\n    {}\n  );\n  return patchString(input, placeholders, flags);\n}\n\n/**\n * @description Replaces occurrences of keys with their corresponding values in a string.\n * @summary Iterates through a set of key-value pairs and replaces all occurrences of each key\n * in the input string with its corresponding value. Supports regular expression flags for customized replacement.\n *\n * @param {string} input - The input string in which replacements will be made.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @param {string} [flags=\"g\"] - Regular expression flags to control the replacement behavior.\n * @return {string} The string with all specified replacements applied.\n *\n * @function patchString\n *\n * @memberOf module:Logging\n */\nexport function patchString(\n  input: string,\n  values: Record<string, number | string>,\n  flags: string = \"g\"\n): string {\n  Object.entries(values).forEach(([key, val]) => {\n    const regexp = new RegExp(escapeRegExp(key), flags);\n    input = input.replace(regexp, val as string);\n  });\n  return input;\n}\n\n/**\n * @description Converts a string to camelCase.\n * @summary Transforms the input string into camelCase format, where words are joined without spaces\n * and each word after the first starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to camelCase.\n *\n * @function toCamelCase\n *\n * @memberOf module:Logging\n */\nexport function toCamelCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word, index) =>\n      index === 0 ? word.toLowerCase() : word.toUpperCase()\n    )\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Converts a string to ENVIRONMENT_VARIABLE format.\n * @summary Transforms the input string into uppercase with words separated by underscores,\n * typically used for environment variable names.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.\n *\n * @function toENVFormat\n *\n * @memberOf module:Logging\n */\nexport function toENVFormat(text: string): string {\n  return toSnakeCase(text).toUpperCase();\n}\n\n/**\n * @description Converts a string to snake_case.\n * @summary Transforms the input string into lowercase with words separated by underscores.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to snake_case.\n *\n * @function toSnakeCase\n *\n * @memberOf module:Logging\n */\nexport function toSnakeCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1_$2\")\n    .replace(/[\\s-]+/g, \"_\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to kebab-case.\n * @summary Transforms the input string into lowercase with words separated by hyphens.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to kebab-case.\n *\n * @function toKebabCase\n *\n * @memberOf module:Logging\n */\nexport function toKebabCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n    .replace(/[\\s_]+/g, \"-\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to PascalCase.\n * @summary Transforms the input string into PascalCase format, where words are joined without spaces\n * and each word starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to PascalCase.\n *\n * @function toPascalCase\n *\n * @memberOf module:Logging\n */\nexport function toPascalCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word) => word.toUpperCase())\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Escapes special characters in a string for use in a regular expression.\n * @summary Adds backslashes before characters that have special meaning in regular expressions,\n * allowing the string to be used as a literal match in a RegExp.\n *\n * @param {string} string - The string to escape for regular expression use.\n * @return {string} The escaped string safe for use in regular expressions.\n *\n * @function escapeRegExp\n *\n * @memberOf module:Logging\n */\nexport function escapeRegExp(string: string) {\n  return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"); // $& means the whole matched string\n}\n\n/**\n * @summary Util function to provide string format functionality similar to C#'s string.format\n *\n * @param {string} string\n * @param {Array<string | number> | Record<string, any>} [args] replacements made by order of appearance (replacement0 wil replace {0} and so on)\n * @return {string} formatted string\n *\n * @function sf\n * @memberOf module:Logging\n */\nexport function sf(\n  string: string,\n  ...args: (string | number | Record<string, any>)[]\n) {\n  if (args.length > 1) {\n    if (\n      !args.every((arg) => typeof arg === \"string\" || typeof arg === \"number\")\n    )\n      throw new Error(\n        `Only string and number arguments are supported for multiple replacements.`\n      );\n  }\n\n  if (args.length === 1 && typeof args[0] === \"object\") {\n    const obj = args[0] as Record<string, any>;\n    return Object.entries(obj).reduce((acc, [key, val]) => {\n      return acc.replace(new RegExp(`\\\\{${key}\\\\}`, \"g\"), function () {\n        return val;\n      });\n    }, string);\n  }\n\n  return string.replace(/{(\\d+)}/g, function (match, number) {\n    return typeof args[number] !== \"undefined\"\n      ? args[number].toString()\n      : \"undefined\";\n  });\n}\n\n/**\n * @summary Util function to provide string format functionality similar to C#'s string.format\n *\n * @see sf\n *\n * @deprecated\n * @function stringFormat\n * @memberOf module:Logging\n */\nexport const stringFormat = sf;\n","/**\n * @description Determines if the current environment is a browser by checking the prototype chain of the global object.\n * @summary Checks if the code is running in a browser environment.\n * @return {boolean} True if the environment is a browser, false otherwise.\n * @function isBrowser\n * @memberOf module:Logging\n */\nexport function isBrowser(): boolean {\n  return (\n    Object.getPrototypeOf(Object.getPrototypeOf(globalThis)) !==\n    Object.prototype\n  );\n}\n","import { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { toENVFormat } from \"./text\";\nimport { isBrowser } from \"./web\";\nimport {\n  BrowserEnvKey,\n  DefaultLoggingConfig,\n  ENV_PATH_DELIMITER,\n} from \"./constants\";\n\n/**\n * @description Factory type for creating Environment instances.\n * @summary Defines a function type that creates and returns Environment instances.\n *\n * @template T - The type of object the Environment will accumulate.\n * @template E - The specific Environment type to be created, extending Environment<T>.\n * @typedef {function(...unknown[]): E} EnvironmentFactory\n * @memberOf module:Logging\n */\nexport type EnvironmentFactory<T extends object, E extends Environment<T>> = (\n  ...args: unknown[]\n) => E;\n\n/**\n * @class Environment\n * @extends {ObjectAccumulator<T>}\n * @template T\n * @description A class representing an environment with accumulation capabilities.\n * @summary Manages environment-related data and provides methods for accumulation and key retrieval.\n * @param {T} [initialData] - The initial data to populate the environment with.\n */\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieves a value from the environment\n   * @summary Gets a value from the environment variables, handling browser and Node.js environments differently\n   * @param {string} k - The key to retrieve from the environment\n   * @return {unknown} The value from the environment, or undefined if not found\n   */\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env = (\n        globalThis as typeof globalThis & {\n          [BrowserEnvKey]: Record<string, any>;\n        }\n      )[BrowserEnvKey];\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return env[k];\n  }\n\n  /**\n   * @description Expands an object into the environment\n   * @summary Defines properties on the environment object that can be accessed as getters and setters\n   * @template V - Type of the object being expanded\n   * @param {V} value - The object to expand into the environment\n   * @return {void}\n   */\n  protected override expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          if (typeof fromEnv !== \"undefined\") return fromEnv;\n          if (v && typeof v === \"object\") {\n            return Environment.buildEnvProxy(v as any, [k]);\n          }\n          // If the model provides an empty string, expose a proxy that composes ENV keys\n          if (v === \"\") {\n            return Environment.buildEnvProxy(undefined, [k]);\n          }\n          return v;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one instance of the Environment class exists.\n   * @template E\n   * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.\n   * @return {E} The singleton instance of the Environment class.\n   */\n  protected static instance<E extends Environment<any>>(...args: unknown[]): E {\n    if (!Environment._instance) {\n      const base = Environment.factory(...args) as E;\n      const proxied = new Proxy(base as any, {\n        get(target, prop, receiver) {\n          const value = Reflect.get(target, prop, receiver);\n          if (typeof value !== \"undefined\") return value;\n          if (typeof prop === \"string\") {\n            // Avoid interfering with logging config lookups for optional fields like 'app'\n            if (prop === \"app\") return undefined;\n            return Environment.buildEnvProxy(undefined, [prop]);\n          }\n          return value;\n        },\n      });\n      Environment._instance = proxied as any;\n    }\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties to the environment from the provided object.\n   * @template V\n   * @param {V} value - The object to accumulate into the environment.\n   * @return {V} The updated environment instance.\n   */\n  static accumulate<V extends object>(\n    value: V\n  ): typeof Environment._instance &\n    V &\n    ObjectAccumulator<typeof Environment._instance & V> {\n    const instance = Environment.instance();\n    Object.keys(instance as any).forEach((key) => {\n      const desc = Object.getOwnPropertyDescriptor(instance as any, key);\n      if (desc && desc.configurable && desc.enumerable) {\n        Object.defineProperty(instance as any, key, {\n          ...desc,\n          enumerable: false,\n        });\n      }\n    });\n    return instance.accumulate(value);\n  }\n\n  static get(key: string) {\n    return Environment._instance.get(key);\n  }\n\n  private static buildEnvProxy(current: any, path: string[]): any {\n    const buildKey = (p: string[]) =>\n      p.map((seg) => toENVFormat(seg)).join(ENV_PATH_DELIMITER);\n\n    // Helper to read from the active environment given a composed key\n    const readEnv = (key: string): unknown => {\n      if (isBrowser()) {\n        const env = (\n          globalThis as typeof globalThis & {\n            [BrowserEnvKey]?: Record<string, unknown>;\n          }\n        )[BrowserEnvKey];\n        return env ? env[key] : undefined;\n      }\n      return (globalThis as any)?.process?.env?.[key];\n    };\n\n    const handler: ProxyHandler<any> = {\n      get(_target, prop: string | symbol) {\n        if (prop === Symbol.toPrimitive) {\n          return () => buildKey(path);\n        }\n        if (prop === \"toString\") {\n          return () => buildKey(path);\n        }\n        if (prop === \"valueOf\") {\n          return () => buildKey(path);\n        }\n        if (typeof prop === \"symbol\") return undefined;\n\n        const nextModel =\n          current && Object.prototype.hasOwnProperty.call(current, prop)\n            ? (current as any)[prop]\n            : undefined;\n        const nextPath = [...path, prop];\n        const composedKey = buildKey(nextPath);\n\n        // If an ENV value exists for this path, return it directly\n        const envValue = readEnv(composedKey);\n        if (typeof envValue !== \"undefined\") return envValue;\n\n        // Otherwise, if the model has an object at this path, keep drilling with a proxy\n        const isNextObject = nextModel && typeof nextModel === \"object\";\n        if (isNextObject) return Environment.buildEnvProxy(nextModel, nextPath);\n\n        // Always return a proxy for further path composition when no ENV value;\n        // do not surface primitive model defaults here (this API is for key composition).\n        return Environment.buildEnvProxy(undefined, nextPath);\n      },\n      ownKeys() {\n        return current ? Reflect.ownKeys(current) : [];\n      },\n      getOwnPropertyDescriptor(_t, p) {\n        if (!current) return undefined as any;\n        if (Object.prototype.hasOwnProperty.call(current, p)) {\n          return { enumerable: true, configurable: true } as PropertyDescriptor;\n        }\n        return undefined as any;\n      },\n    };\n\n    const target = {} as any;\n    return new Proxy(target, handler);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n}\n\nexport const LoggedEnvironment = Environment.accumulate(\n  Object.assign({}, DefaultLoggingConfig, {\n    env:\n      (isBrowser() && (globalThis as any)[BrowserEnvKey]\n        ? (globalThis as any)[BrowserEnvKey][\"NODE_ENV\"]\n        : (globalThis as any).process.env[\"NODE_ENV\"]) || \"development\",\n  })\n);\n","import {\n  LoggerFactory,\n  LoggingConfig,\n  LoggingContext,\n  StringLike,\n  Theme,\n  ThemeOption,\n  ThemeOptionByLogLevel,\n  Logger,\n} from \"./types\";\nimport { ColorizeOptions, style, StyledString } from \"styled-string-builder\";\nimport { DefaultTheme, LogLevel, NumericLogLevels } from \"./constants\";\nimport { sf } from \"./text\";\nimport { LoggedEnvironment } from \"./environment\";\n\n/**\n * @description A minimal logger implementation.\n * @summary MiniLogger is a lightweight logging class that implements the Logger interface.\n * It provides basic logging functionality with support for different log levels, verbosity,\n * context-aware logging, and customizable formatting.\n * @param {string} context - The context (typically class name) this logger is associated with\n * @param {Partial<LoggingConfig>} conf - Optional configuration to override global settings\n * @class MiniLogger\n * @example\n * // Create a new logger for a class\n * const logger = new MiniLogger('MyClass');\n *\n * // Log messages at different levels\n * logger.info('This is an info message');\n * logger.debug('This is a debug message');\n * logger.error('Something went wrong');\n *\n * // Create a child logger for a specific method\n * const methodLogger = logger.for('myMethod');\n * methodLogger.verbose('Detailed information', 2);\n *\n * // Log with custom configuration\n * logger.for('specialMethod', { style: true }).info('Styled message');\n */\nexport class MiniLogger implements Logger {\n  constructor(\n    protected context: string,\n    protected conf?: Partial<LoggingConfig>\n  ) {}\n\n  protected config(\n    key: keyof LoggingConfig\n  ): LoggingConfig[keyof LoggingConfig] {\n    if (this.conf && key in this.conf) return this.conf[key];\n    return Logging.getConfig()[key];\n  }\n\n  for(method: string | ((...args: any[]) => any)): Logger;\n  for(config: Partial<LoggingConfig>): Logger;\n  for(\n    method: string | ((...args: any[]) => any) | Partial<LoggingConfig>,\n    config: Partial<LoggingConfig>,\n    ...args: any[]\n  ): Logger;\n  /**\n   * @description Creates a child logger for a specific method or context\n   * @summary Returns a new logger instance with the current context extended by the specified method name\n   * @param {string | Function} method - The method name or function to create a logger for\n   * @param {Partial<LoggingConfig>} config - Optional configuration to override settings\n   * @param {...any[]} args - Additional arguments to pass to the logger factory\n   * @return {Logger} A new logger instance for the specified method\n   */\n  for(\n    method?: string | ((...args: any[]) => any) | Partial<LoggingConfig>,\n    config?: Partial<LoggingConfig>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Logger {\n    if (!config && typeof method === \"object\") {\n      config = method;\n      method = undefined;\n    } else {\n      method = method\n        ? typeof method === \"string\"\n          ? method\n          : (method as any).name\n        : undefined;\n    }\n\n    return new Proxy(this, {\n      get: (target: typeof this, p: string | symbol, receiver: any) => {\n        const result = Reflect.get(target, p, receiver);\n        if (p === \"config\") {\n          return new Proxy(this.config, {\n            get: (target: typeof this.config, p: string | symbol) => {\n              if (config && p in config)\n                return config[p as keyof LoggingConfig];\n              return Reflect.get(target, p, receiver);\n            },\n          });\n        }\n        if (p === \"context\" && method) {\n          return [result, method].join(\".\");\n        }\n        return result;\n      },\n    });\n  }\n\n  /**\n   * @description Creates a formatted log string\n   * @summary Generates a log string with timestamp, colored log level, context, and message\n   * @param {LogLevel} level - The log level for this message\n   * @param {StringLike | Error} message - The message to log or an Error object\n   * @param {string} [error] - Optional error to extract stack trace to include in the log\n   * @return {string} A formatted log string with all components\n   */\n  protected createLog(\n    level: LogLevel,\n    message: StringLike | Error,\n    error?: Error\n  ): string {\n    const log: Record<\n      | \"timestamp\"\n      | \"level\"\n      | \"context\"\n      | \"correlationId\"\n      | \"message\"\n      | \"separator\"\n      | \"stack\"\n      | \"app\",\n      string\n    > = {} as any;\n    const style = this.config(\"style\");\n    const separator = this.config(\"separator\");\n    const app = this.config(\"app\");\n    if (app)\n      log.app = style\n        ? Logging.theme(app as string, \"app\", level)\n        : (app as string);\n\n    if (separator)\n      log.separator = style\n        ? Logging.theme(separator as string, \"separator\", level)\n        : (separator as string);\n\n    if (this.config(\"timestamp\")) {\n      const date = new Date().toISOString();\n      const timestamp = style ? Logging.theme(date, \"timestamp\", level) : date;\n      log.timestamp = timestamp;\n    }\n\n    if (this.config(\"logLevel\")) {\n      const lvl: string = style\n        ? Logging.theme(level, \"logLevel\", level)\n        : level;\n      log.level = lvl.toUpperCase();\n    }\n\n    if (this.config(\"context\")) {\n      const context: string = style\n        ? Logging.theme(this.context, \"class\", level)\n        : this.context;\n      log.context = context;\n    }\n\n    if (this.config(\"correlationId\")) {\n      {\n        const id: string = style\n          ? Logging.theme(this.config(\"correlationId\")!.toString(), \"id\", level)\n          : this.config(\"correlationId\")!.toString();\n        log.correlationId = id;\n      }\n    }\n\n    const msg: string = style\n      ? Logging.theme(\n          typeof message === \"string\" ? message : (message as Error).message,\n          \"message\",\n          level\n        )\n      : typeof message === \"string\"\n        ? message\n        : (message as Error).message;\n    log.message = msg;\n    if (error || message instanceof Error) {\n      const stack = style\n        ? Logging.theme(\n            (error?.stack || (message as Error).stack) as string,\n            \"stack\",\n            level\n          )\n        : error?.stack || \"\";\n      log.stack = ` | ${(error || (message as Error)).message} - Stack trace:\\n${stack}`;\n    }\n\n    switch (this.config(\"format\")) {\n      case \"json\":\n        return JSON.stringify(log);\n      case \"raw\":\n        return (this.config(\"pattern\") as string)\n          .split(\" \")\n          .map((s) => {\n            if (!s.match(/\\{.*?}/g)) return s;\n            const formattedS = sf(s, log);\n            if (formattedS !== s) return formattedS;\n            return undefined;\n          })\n          .filter((s) => s)\n          .join(\" \");\n      default:\n        throw new Error(`Unsupported logging format: ${this.config(\"format\")}`);\n    }\n  }\n\n  /**\n   * @description Logs a message with the specified log level\n   * @summary Checks if the message should be logged based on the current log level,\n   * then uses the appropriate console method to output the formatted log\n   * @param {LogLevel} level - The log level of the message\n   * @param {StringLike | Error} msg - The message to be logged or an Error object\n   * @param {string} [error] - Optional stack trace to include in the log\n   * @return {void}\n   */\n  protected log(level: LogLevel, msg: StringLike | Error, error?: Error): void {\n    const confLvl = this.config(\"level\") as LogLevel;\n    if (NumericLogLevels[confLvl] < NumericLogLevels[level]) return;\n    let method;\n    switch (level) {\n      case LogLevel.info:\n        method = console.log;\n        break;\n      case LogLevel.verbose:\n      case LogLevel.debug:\n        method = console.debug;\n        break;\n      case LogLevel.error:\n        method = console.error;\n        break;\n      default:\n        throw new Error(\"Invalid log level\");\n    }\n    method(this.createLog(level, msg, error));\n  }\n\n  /**\n   * @description Logs a message at the silly level\n   * @summary Logs a message at the silly level if the current verbosity setting allows it\n   * @param {StringLike} msg - The message to be logged\n   * @param {number} [verbosity=0] - The verbosity level of the message\n   * @return {void}\n   */\n  silly(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs a message at the verbose level\n   * @summary Logs a message at the verbose level if the current verbosity setting allows it\n   * @param {StringLike} msg - The message to be logged\n   * @param {number} [verbosity=0] - The verbosity level of the message\n   * @return {void}\n   */\n  verbose(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs a message at the info level\n   * @summary Logs a message at the info level for general application information\n   * @param {StringLike} msg - The message to be logged\n   * @return {void}\n   */\n  info(msg: StringLike): void {\n    this.log(LogLevel.info, msg);\n  }\n\n  /**\n   * @description Logs a message at the debug level\n   * @summary Logs a message at the debug level for detailed troubleshooting information\n   * @param {StringLike} msg - The message to be logged\n   * @return {void}\n   */\n  debug(msg: StringLike): void {\n    this.log(LogLevel.debug, msg);\n  }\n\n  /**\n   * @description Logs a message at the error level\n   * @summary Logs a message at the error level for errors and exceptions\n   * @param {StringLike | Error} msg - The message to be logged or an Error object\n   * @param e\n   * @return {void}\n   */\n  error(msg: StringLike | Error, e?: Error): void {\n    this.log(LogLevel.error, msg, e);\n  }\n\n  /**\n   * @description Updates the logger configuration\n   * @summary Merges the provided configuration with the existing configuration\n   * @param {Partial<LoggingConfig>} config - The configuration options to apply\n   * @return {void}\n   */\n  setConfig(config: Partial<LoggingConfig>): void {\n    this.conf = { ...(this.conf || {}), ...config };\n  }\n}\n\n/**\n * @description A static class for managing logging operations\n * @summary The Logging class provides a centralized logging mechanism with support for\n * different log levels, verbosity, and styling. It uses a singleton pattern to maintain a global\n * logger instance and allows creating specific loggers for different classes and methods.\n * @class Logging\n * @example\n * // Set global configuration\n * Logging.setConfig({ level: LogLevel.debug, style: true });\n *\n * // Get a logger for a specific class\n * const logger = Logging.for('MyClass');\n *\n * // Log messages at different levels\n * logger.info('Application started');\n * logger.debug('Processing data...');\n *\n * // Log with context\n * const methodLogger = Logging.for('MyClass.myMethod');\n * methodLogger.verbose('Detailed operation information', 1);\n *\n * // Log errors\n * try {\n *   // some operation\n * } catch (error) {\n *   logger.error(error);\n * }\n * @mermaid\n * classDiagram\n *   class Logger {\n *     <<interface>>\n *     +for(method, config, ...args)\n *     +silly(msg, verbosity)\n *     +verbose(msg, verbosity)\n *     +info(msg)\n *     +debug(msg)\n *     +error(msg)\n *     +setConfig(config)\n *   }\n *\n *   class Logging {\n *     -global: Logger\n *     -_factory: LoggerFactory\n *     -_config: LoggingConfig\n *     +setFactory(factory)\n *     +setConfig(config)\n *     +getConfig()\n *     +get()\n *     +verbose(msg, verbosity)\n *     +info(msg)\n *     +debug(msg)\n *     +silly(msg)\n *     +error(msg)\n *     +for(object, config, ...args)\n *     +because(reason, id)\n *     +theme(text, type, loggerLevel, template)\n *   }\n *\n *   class MiniLogger {\n *     +constructor(context, conf?)\n *   }\n *\n *   Logging ..> Logger : creates\n *   Logging ..> MiniLogger : creates by default\n */\nexport class Logging {\n  /**\n   * @description The global logger instance\n   * @summary A singleton instance of Logger used for global logging\n   */\n  private static global?: Logger;\n\n  /**\n   * @description Factory function for creating logger instances\n   * @summary A function that creates new Logger instances. By default, it creates a MiniLogger.\n   */\n  private static _factory: LoggerFactory = (\n    object: string,\n    config?: Partial<LoggingConfig>\n  ) => {\n    return new MiniLogger(object, config);\n  };\n\n  private static _config: typeof LoggedEnvironment = LoggedEnvironment;\n\n  private constructor() {}\n\n  /**\n   * @description Sets the factory function for creating logger instances\n   * @summary Allows customizing how logger instances are created\n   * @param {LoggerFactory} factory - The factory function to use for creating loggers\n   * @return {void}\n   */\n  static setFactory(factory: LoggerFactory) {\n    Logging._factory = factory;\n  }\n\n  /**\n   * @description Updates the global logging configuration\n   * @summary Allows updating the global logging configuration with new settings\n   * @param {Partial<LoggingConfig>} config - The configuration options to apply\n   * @return {void}\n   */\n  static setConfig(config: Partial<LoggingConfig>): void {\n    Object.entries(config).forEach(([k, v]) => {\n      (this._config as any)[k] = v as any;\n    });\n  }\n\n  /**\n   * @description Gets a copy of the current global logging configuration\n   * @summary Returns a copy of the current global logging configuration\n   * @return {LoggingConfig} A copy of the current configuration\n   */\n  static getConfig(): typeof LoggedEnvironment {\n    return this._config;\n  }\n\n  /**\n   * @description Retrieves or creates the global logger instance.\n   * @summary Returns the existing global logger or creates a new one if it doesn't exist.\n   *\n   * @return The global VerbosityLogger instance.\n   */\n  static get(): Logger {\n    this.global = this.global ? this.global : this._factory(\"Logging\");\n    return this.global;\n  }\n\n  /**\n   * @description Logs a verbose message.\n   * @summary Delegates the verbose logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   * @param verbosity - The verbosity level of the message (default: 0).\n   */\n  static verbose(msg: StringLike, verbosity: number = 0): void {\n    return this.get().verbose(msg, verbosity);\n  }\n\n  /**\n   * @description Logs an info message.\n   * @summary Delegates the info logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static info(msg: StringLike): void {\n    return this.get().info(msg);\n  }\n\n  /**\n   * @description Logs a debug message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static debug(msg: StringLike): void {\n    return this.get().debug(msg);\n  }\n\n  /**\n   * @description Logs a silly message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static silly(msg: StringLike): void {\n    return this.get().silly(msg);\n  }\n\n  /**\n   * @description Logs an error message.\n   * @summary Delegates the error logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   * @param e\n   */\n  static error(msg: StringLike, e?: Error): void {\n    return this.get().error(msg, e);\n  }\n\n  /**\n   * @description Creates a logger for a specific object or context\n   * @summary Creates a new logger instance for the given object or context using the factory function\n   * @param {LoggingContext} object - The object, class, or context to create a logger for\n   * @param {Partial<LoggingConfig>} [config] - Optional configuration to override global settings\n   * @param {...any} args - Additional arguments to pass to the logger factory\n   * @return {Logger} A new logger instance for the specified object or context\n   */\n  static for(\n    object: LoggingContext,\n    config?: Partial<LoggingConfig>,\n    ...args: any[]\n  ): Logger {\n    object =\n      typeof object === \"string\"\n        ? object\n        : object.constructor\n          ? object.constructor.name\n          : object.name;\n    return this._factory(object, config, ...args);\n  }\n\n  /**\n   * @description Creates a logger for a specific reason or correlation context\n   * @summary Utility to quickly create a logger labeled with a free-form reason and optional identifier\n   * so that ad-hoc operations can be traced without tying the logger to a class or method name.\n   * @param {string} reason - A textual reason or context label for this logger instance\n   * @param {string} [id] - Optional identifier to help correlate related log entries\n   * @return {Logger} A new logger instance labeled with the provided reason and id\n   */\n  static because(reason: string, id?: string): Logger {\n    return this._factory(reason, this._config, id);\n  }\n\n  /**\n   * @description Applies theme styling to text\n   * @summary Applies styling (colors, formatting) to text based on the theme configuration\n   * @param {string} text - The text to style\n   * @param {string} type - The type of element to style (e.g., \"class\", \"message\", \"logLevel\")\n   * @param {LogLevel} loggerLevel - The log level to use for styling\n   * @param {Theme} [template=DefaultTheme] - The theme to use for styling\n   * @return {string} The styled text\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant Theme as Logging.theme\n   *   participant Apply as apply function\n   *   participant Style as styled-string-builder\n   *\n   *   Caller->>Theme: theme(text, type, loggerLevel)\n   *   Theme->>Theme: Check if styling is enabled\n   *   alt styling disabled\n   *     Theme-->>Caller: return original text\n   *   else styling enabled\n   *     Theme->>Theme: Get theme for type\n   *     alt theme not found\n   *       Theme-->>Caller: return original text\n   *     else theme found\n   *       Theme->>Theme: Determine actual theme based on log level\n   *       Theme->>Apply: Apply each style property\n   *       Apply->>Style: Apply colors and formatting\n   *       Style-->>Apply: Return styled text\n   *       Apply-->>Theme: Return styled text\n   *       Theme-->>Caller: Return final styled text\n   *     end\n   *   end\n   */\n  static theme(\n    text: string,\n    type: keyof Theme | keyof LogLevel,\n    loggerLevel: LogLevel,\n    template: Theme = DefaultTheme\n  ) {\n    if (!this._config.style) return text;\n    const logger = Logging.get().for(this.theme);\n\n    function apply(\n      txt: string,\n      option: keyof ThemeOption,\n      value: number | [number] | [number, number, number] | number[] | string[]\n    ): string {\n      try {\n        const t: string | StyledString = txt;\n        let c = style(t);\n\n        function applyColor(\n          val: number | [number] | [number, number, number],\n          isBg = false\n        ): StyledString {\n          let f:\n            | typeof c.background\n            | typeof c.foreground\n            | typeof c.rgb\n            | typeof c.color256 = isBg ? c.background : c.foreground;\n          if (!Array.isArray(val)) {\n            return (f as typeof c.background | typeof c.foreground).call(\n              c,\n              value as number\n            );\n          }\n          switch (val.length) {\n            case 1:\n              f = isBg ? c.bgColor256 : c.color256;\n              return (f as typeof c.bgColor256 | typeof c.color256)(val[0]);\n            case 3:\n              f = isBg ? c.bgRgb : c.rgb;\n              return c.rgb(val[0], val[1], val[2]);\n            default:\n              logger.error(`Not a valid color option: ${option}`);\n              return style(t as string);\n          }\n        }\n\n        function applyStyle(v: number | string): void {\n          if (typeof v === \"number\") {\n            c = c.style(v);\n          } else {\n            c = c[v as keyof ColorizeOptions] as StyledString;\n          }\n        }\n\n        switch (option) {\n          case \"bg\":\n          case \"fg\":\n            return applyColor(value as number).text;\n          case \"style\":\n            if (Array.isArray(value)) {\n              value.forEach(applyStyle);\n            } else {\n              applyStyle(value as number | string);\n            }\n            return c.text;\n          default:\n            logger.error(`Not a valid theme option: ${option}`);\n            return t;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        logger.error(`Error applying style: ${option} with value ${value}`);\n        return txt;\n      }\n    }\n\n    const individualTheme = template[type as keyof Theme];\n    if (!individualTheme || !Object.keys(individualTheme).length) {\n      return text;\n    }\n\n    let actualTheme: ThemeOption = individualTheme as ThemeOption;\n\n    const logLevels = Object.assign({}, LogLevel);\n    if (Object.keys(individualTheme)[0] in logLevels)\n      actualTheme =\n        (individualTheme as ThemeOptionByLogLevel)[loggerLevel] || {};\n\n    return Object.keys(actualTheme).reduce((acc: string, key: string) => {\n      const val = (actualTheme as ThemeOption)[key as keyof ThemeOption];\n      if (val)\n        return apply(\n          acc,\n          key as keyof ThemeOption,\n          val as\n            | number\n            | [number]\n            | [number, number, number]\n            | number[]\n            | string[]\n        );\n      return acc;\n    }, text);\n  }\n}\n","import { Logging } from \"./logging\";\nimport { Logger } from \"./types\";\n\n/**\n * @description Base class that provides a ready-to-use logger instance\n * @summary LoggedClass is a convenience abstract class that injects a type-safe logger\n * into derived classes through a protected getter. Subclasses can directly access\n * this.log to emit messages without manually creating a logger. This promotes\n * consistent, context-aware logging across the codebase.\n * @param {void} [constructor] - No constructor arguments; subclasses may define their own\n * @class LoggedClass\n * @example\n * class UserService extends LoggedClass {\n *   create(user: User) {\n *     this.log.info(`Creating user ${user.id}`);\n *   }\n * }\n *\n * const svc = new UserService();\n * svc.create({ id: \"42\" });\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Instance as Subclass Instance\n *   participant Getter as LoggedClass.log\n *   participant Logging as Logging\n *   participant Logger as Logger\n *\n *   Client->>Instance: call someMethod()\n *   Instance->>Getter: access this.log\n *   Getter->>Logging: Logging.for(this)\n *   Logging-->>Getter: return Logger\n *   Getter-->>Instance: return Logger\n *   Instance->>Logger: info/debug/error(...)\n */\nexport abstract class LoggedClass {\n  /**\n   * @description Lazily provides a context-aware logger for the current instance\n   * @summary Uses Logging.for(this) to create a logger whose context is the\n   * subclass name, allowing uniform and structured logs from any inheriting class.\n   * @return {Logger} A logger bound to the subclass context\n   */\n  protected get log(): Logger {\n    return Logging.for(this as any);\n  }\n\n  protected constructor() {}\n}\n","import { Logger, LoggingConfig, LoggingFilter } from \"../types\";\nimport { LoggedClass } from \"../LoggedClass\";\n\nexport abstract class LogFilter extends LoggedClass implements LoggingFilter {\n  override get log(): Logger {\n    return super.log.for(this as any, { filters: [] });\n  }\n\n  abstract filter(\n    config: LoggingConfig,\n    message: string,\n    context: string[]\n  ): string;\n}\n","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?: any,\n    descriptor?: PropertyDescriptor\n  ) {\n    if (!descriptor)\n      throw new Error(`Logging decoration only applies to methods`);\n    const logger = Logging.for(target).for(target[propertyKey]);\n    const method = logger[level].bind(logger) as any;\n    const originalMethod = descriptor.value;\n\n    descriptor.value = new Proxy(originalMethod, {\n      apply(fn, thisArg, args: any[]) {\n        method(`called with ${args}`, verbosity);\n        const start = Date.now();\n        try {\n          const result = Reflect.apply(fn, thisArg, args);\n          if (result instanceof Promise) {\n            return result.then((r: any) => {\n              if (benchmark)\n                method(`completed in ${Date.now() - start}ms`, verbosity);\n              return r;\n            });\n          }\n          if (benchmark)\n            method(`completed in ${Date.now() - start}ms`, verbosity);\n          return result;\n        } catch (err) {\n          if (benchmark) method(`failed in ${Date.now() - start}ms`, verbosity);\n          throw err;\n        }\n      },\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(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => 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(\n  benchmark: boolean\n): (target: any, propertyKey?: any, descriptor?: any) => 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 * @return {Function} A method decorator that wraps the original method with verbose logging\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(\n  verbosity: number | boolean\n): (target: any, propertyKey?: any, descriptor?: any) => void;\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\n/**\n * @description Creates a decorator that makes a method non-configurable\n * @summary This decorator prevents a method from being overridden by making it non-configurable.\n * It throws an error if used on anything other than a method.\n * @return {Function} A decorator function that can be applied to methods\n * @function final\n * @category Method Decorators\n */\nexport function final() {\n  return (\n    target: object,\n    propertyKey?: any,\n    descriptor?: PropertyDescriptor\n  ) => {\n    if (!descriptor)\n      throw new Error(\"final decorator can only be used on methods\");\n    if (descriptor?.configurable) {\n      descriptor.configurable = false;\n    }\n    return descriptor;\n  };\n}\n","import { LogFilter } from \"./LogFilter\";\nimport { LoggingConfig } from \"../types\";\nimport { final } from \"../decorators\";\n\nexport type ReplacementFunction = (substring: string, ...args: any[]) => string;\n\nexport class PatternFilter extends LogFilter {\n  constructor(\n    protected readonly regexp: RegExp,\n    protected readonly replacement: string | ReplacementFunction\n  ) {\n    super();\n  }\n\n  @final()\n  protected match(message: string) {\n    const match = this.regexp.exec(message);\n    this.regexp.lastIndex = 0;\n    return match;\n  }\n\n  filter(config: LoggingConfig, message: string, context: string[]): string {\n    const log = this.log.for(this.filter);\n    const match = this.match(message);\n    if (!match) return message;\n    try {\n      return message.replace(this.regexp, this.replacement as any);\n    } catch (e: unknown) {\n      log.error(`PatternFilter replacement error: ${e}`);\n    }\n    return \"\";\n  }\n}\n","export * from \"./filters\";\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./environment\";\nexport * from \"./LoggedClass\";\nexport * from \"./logging\";\nexport * from \"./text\";\nexport * from \"./types\";\nexport * from \"./web\";\n\n/**\n * @description A logging module for TypeScript applications\n * @summary Provides a comprehensive, flexible logging solution. This module exposes:\n * - Core classes like {@link Logging} and {@link MiniLogger}\n * - Decorators such as {@link log} for instrumenting methods\n * - Configuration and constants like {@link LogLevel} and {@link DefaultLoggingConfig}\n * - Type definitions including {@link Logger} and {@link LoggingConfig}\n * These exports enable consistent, context-aware, and optionally themed logging across projects.\n * @module Logging\n */\n\n/**\n * @description Current package version string\n * @summary Stores the current package version, used for version tracking and compatibility checks\n * @const VERSION\n * @memberOf module:Logging\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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"}
|