@xylabs/logger 4.4.36 → 4.5.0

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.
@@ -1,3 +1,5 @@
1
+ import type { EnumValue } from '@xylabs/enum';
2
+ import { Enum } from '@xylabs/enum';
1
3
  export type LogFunction = (...data: unknown[]) => void;
2
4
  /**
3
5
  * Interface to handle overlap between Winston &
@@ -10,13 +12,14 @@ export interface Logger {
10
12
  log: LogFunction;
11
13
  warn: LogFunction;
12
14
  }
13
- export declare enum LogLevel {
14
- error = 1,
15
- warn = 2,
16
- info = 3,
17
- log = 4,
18
- debug = 5
19
- }
15
+ export declare const LogLevel: Enum<{
16
+ error: 1;
17
+ warn: 2;
18
+ info: 3;
19
+ log: 4;
20
+ debug: 5;
21
+ }>;
22
+ export type LogLevel = EnumValue<typeof LogLevel>;
20
23
  export declare const NoOpLogFunction: (..._data: unknown[]) => undefined;
21
24
  export declare class ConsoleLogger implements Logger {
22
25
  readonly level: LogLevel;
@@ -1 +1 @@
1
- {"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../../src/Logger.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAA;AAEtD;;;GAGG;AACH,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,WAAW,CAAA;IAClB,KAAK,EAAE,WAAW,CAAA;IAClB,IAAI,EAAE,WAAW,CAAA;IACjB,GAAG,EAAE,WAAW,CAAA;IAChB,IAAI,EAAE,WAAW,CAAA;CAClB;AAED,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,GAAG,IAAI;IACP,KAAK,IAAI;CACV;AAED,eAAO,MAAM,eAAe,aAAc,OAAO,EAAE,cAAY,CAAA;AAE/D,qBAAa,aAAc,YAAW,MAAM;IAC9B,QAAQ,CAAC,KAAK,EAAE,QAAQ;gBAAf,KAAK,GAAE,QAAwB;IAEpD,IAAI,KAAK,sDAER;IAED,IAAI,KAAK,sDAER;IAED,IAAI,IAAI,sDAEP;IAED,IAAI,GAAG,sDAEN;IAED,IAAI,IAAI,sDAEP;CACF"}
1
+ {"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../../src/Logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AACnC,MAAM,MAAM,WAAW,GAAG,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAA;AAEtD;;;GAGG;AACH,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,WAAW,CAAA;IAClB,KAAK,EAAE,WAAW,CAAA;IAClB,IAAI,EAAE,WAAW,CAAA;IACjB,GAAG,EAAE,WAAW,CAAA;IAChB,IAAI,EAAE,WAAW,CAAA;CAClB;AAED,eAAO,MAAM,QAAQ;;;;;;EAMnB,CAAA;AAEF,MAAM,MAAM,QAAQ,GAAG,SAAS,CAAC,OAAO,QAAQ,CAAC,CAAA;AAEjD,eAAO,MAAM,eAAe,aAAc,OAAO,EAAE,cAAY,CAAA;AAE/D,qBAAa,aAAc,YAAW,MAAM;IAC9B,QAAQ,CAAC,KAAK,EAAE,QAAQ;gBAAf,KAAK,GAAE,QAAwB;IAEpD,IAAI,KAAK,sDAER;IAED,IAAI,KAAK,sDAER;IAED,IAAI,IAAI,sDAEP;IAED,IAAI,GAAG,sDAEN;IAED,IAAI,IAAI,sDAEP;CACF"}
@@ -52,33 +52,33 @@ var IdLogger = class {
52
52
  };
53
53
 
54
54
  // src/Logger.ts
55
- var LogLevel = /* @__PURE__ */ ((LogLevel2) => {
56
- LogLevel2[LogLevel2["error"] = 1] = "error";
57
- LogLevel2[LogLevel2["warn"] = 2] = "warn";
58
- LogLevel2[LogLevel2["info"] = 3] = "info";
59
- LogLevel2[LogLevel2["log"] = 4] = "log";
60
- LogLevel2[LogLevel2["debug"] = 5] = "debug";
61
- return LogLevel2;
62
- })(LogLevel || {});
55
+ import { Enum } from "@xylabs/enum";
56
+ var LogLevel = Enum({
57
+ error: 1,
58
+ warn: 2,
59
+ info: 3,
60
+ log: 4,
61
+ debug: 5
62
+ });
63
63
  var NoOpLogFunction = (..._data) => void 0;
64
64
  var ConsoleLogger = class {
65
- constructor(level = 2 /* warn */) {
65
+ constructor(level = LogLevel.warn) {
66
66
  this.level = level;
67
67
  }
68
68
  get debug() {
69
- return this.level >= 5 /* debug */ ? console.debug : NoOpLogFunction;
69
+ return this.level >= LogLevel.debug ? console.debug : NoOpLogFunction;
70
70
  }
71
71
  get error() {
72
- return this.level >= 1 /* error */ ? console.error : NoOpLogFunction;
72
+ return this.level >= LogLevel.error ? console.error : NoOpLogFunction;
73
73
  }
74
74
  get info() {
75
- return this.level >= 3 /* info */ ? console.info : NoOpLogFunction;
75
+ return this.level >= LogLevel.info ? console.info : NoOpLogFunction;
76
76
  }
77
77
  get log() {
78
- return this.level >= 4 /* log */ ? console.log : NoOpLogFunction;
78
+ return this.level >= LogLevel.log ? console.log : NoOpLogFunction;
79
79
  }
80
80
  get warn() {
81
- return this.level >= 2 /* warn */ ? console.warn : NoOpLogFunction;
81
+ return this.level >= LogLevel.warn ? console.warn : NoOpLogFunction;
82
82
  }
83
83
  };
84
84
  export {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/getFunctionName.ts","../../src/IdLogger.ts","../../src/Logger.ts"],"sourcesContent":["import { handleError } from '@xylabs/error'\n\nexport const getFunctionName = (depth = 2) => {\n try {\n throw new Error('Getting function name')\n } catch (ex) {\n return handleError(ex, (error) => {\n let newIndex: number | undefined\n const stackParts = error.stack?.split('\\n')[depth]?.split(' ')\n const funcName\n = stackParts?.find((item, index) => {\n if (item.length > 0 && item !== 'at') {\n // check if constructor\n if (item === 'new') {\n newIndex = index\n }\n return item\n }\n }) ?? '<unknown>'\n return newIndex ? `${funcName} ${stackParts?.[newIndex + 1]}` : funcName\n })\n }\n}\n","import type { Logger } from './Logger.ts'\n\nexport class IdLogger implements Logger {\n private _id?: () => string\n private _logger: Logger\n\n constructor(logger: Logger, id?: () => string) {\n this._logger = logger\n this._id = id\n }\n\n set id(id: string) {\n this._id = () => id\n }\n\n debug(...data: unknown[]) {\n this._logger?.debug(this.prefix(), ...data)\n }\n\n error(...data: unknown[]) {\n this._logger?.error(this.prefix(), ...data)\n }\n\n info(...data: unknown[]) {\n this._logger?.info(this.prefix(), ...data)\n }\n\n log(...data: unknown[]) {\n this._logger?.log(this.prefix(), ...data)\n }\n\n warn(...data: unknown[]) {\n this._logger?.warn(this.prefix(), ...data)\n }\n\n private prefix() {\n return `[${this._id?.()}]`\n }\n}\n","export type LogFunction = (...data: unknown[]) => void\n\n/**\n * Interface to handle overlap between Winston &\n * `console` with as much congruency as possible.\n */\nexport interface Logger {\n debug: LogFunction\n error: LogFunction\n info: LogFunction\n log: LogFunction\n warn: LogFunction\n}\n\nexport enum LogLevel {\n error = 1,\n warn = 2,\n info = 3,\n log = 4,\n debug = 5,\n}\n\nexport const NoOpLogFunction = (..._data: unknown[]) => void {}\n\nexport class ConsoleLogger implements Logger {\n constructor(readonly level: LogLevel = LogLevel.warn) {}\n\n get debug() {\n return this.level >= LogLevel.debug ? console.debug : NoOpLogFunction\n }\n\n get error() {\n return this.level >= LogLevel.error ? console.error : NoOpLogFunction\n }\n\n get info() {\n return this.level >= LogLevel.info ? console.info : NoOpLogFunction\n }\n\n get log() {\n return this.level >= LogLevel.log ? console.log : NoOpLogFunction\n }\n\n get warn() {\n return this.level >= LogLevel.warn ? console.warn : NoOpLogFunction\n }\n}\n"],"mappings":";AAAA,SAAS,mBAAmB;AAErB,IAAM,kBAAkB,CAAC,QAAQ,MAAM;AAC5C,MAAI;AACF,UAAM,IAAI,MAAM,uBAAuB;AAAA,EACzC,SAAS,IAAI;AACX,WAAO,YAAY,IAAI,CAAC,UAAU;AAChC,UAAI;AACJ,YAAM,aAAa,MAAM,OAAO,MAAM,IAAI,EAAE,KAAK,GAAG,MAAM,GAAG;AAC7D,YAAM,WACF,YAAY,KAAK,CAAC,MAAM,UAAU;AAClC,YAAI,KAAK,SAAS,KAAK,SAAS,MAAM;AAEpC,cAAI,SAAS,OAAO;AAClB,uBAAW;AAAA,UACb;AACA,iBAAO;AAAA,QACT;AAAA,MACF,CAAC,KAAK;AACR,aAAO,WAAW,GAAG,QAAQ,IAAI,aAAa,WAAW,CAAC,CAAC,KAAK;AAAA,IAClE,CAAC;AAAA,EACH;AACF;;;ACpBO,IAAM,WAAN,MAAiC;AAAA,EAC9B;AAAA,EACA;AAAA,EAER,YAAY,QAAgB,IAAmB;AAC7C,SAAK,UAAU;AACf,SAAK,MAAM;AAAA,EACb;AAAA,EAEA,IAAI,GAAG,IAAY;AACjB,SAAK,MAAM,MAAM;AAAA,EACnB;AAAA,EAEA,SAAS,MAAiB;AACxB,SAAK,SAAS,MAAM,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC5C;AAAA,EAEA,SAAS,MAAiB;AACxB,SAAK,SAAS,MAAM,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC5C;AAAA,EAEA,QAAQ,MAAiB;AACvB,SAAK,SAAS,KAAK,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC3C;AAAA,EAEA,OAAO,MAAiB;AACtB,SAAK,SAAS,IAAI,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC1C;AAAA,EAEA,QAAQ,MAAiB;AACvB,SAAK,SAAS,KAAK,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC3C;AAAA,EAEQ,SAAS;AACf,WAAO,IAAI,KAAK,MAAM,CAAC;AAAA,EACzB;AACF;;;ACxBO,IAAK,WAAL,kBAAKA,cAAL;AACL,EAAAA,oBAAA,WAAQ,KAAR;AACA,EAAAA,oBAAA,UAAO,KAAP;AACA,EAAAA,oBAAA,UAAO,KAAP;AACA,EAAAA,oBAAA,SAAM,KAAN;AACA,EAAAA,oBAAA,WAAQ,KAAR;AALU,SAAAA;AAAA,GAAA;AAQL,IAAM,kBAAkB,IAAI,UAAqB;AAEjD,IAAM,gBAAN,MAAsC;AAAA,EAC3C,YAAqB,QAAkB,cAAe;AAAjC;AAAA,EAAkC;AAAA,EAEvD,IAAI,QAAQ;AACV,WAAO,KAAK,SAAS,gBAAiB,QAAQ,QAAQ;AAAA,EACxD;AAAA,EAEA,IAAI,QAAQ;AACV,WAAO,KAAK,SAAS,gBAAiB,QAAQ,QAAQ;AAAA,EACxD;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,SAAS,eAAgB,QAAQ,OAAO;AAAA,EACtD;AAAA,EAEA,IAAI,MAAM;AACR,WAAO,KAAK,SAAS,cAAe,QAAQ,MAAM;AAAA,EACpD;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,SAAS,eAAgB,QAAQ,OAAO;AAAA,EACtD;AACF;","names":["LogLevel"]}
1
+ {"version":3,"sources":["../../src/getFunctionName.ts","../../src/IdLogger.ts","../../src/Logger.ts"],"sourcesContent":["import { handleError } from '@xylabs/error'\n\nexport const getFunctionName = (depth = 2) => {\n try {\n throw new Error('Getting function name')\n } catch (ex) {\n return handleError(ex, (error) => {\n let newIndex: number | undefined\n const stackParts = error.stack?.split('\\n')[depth]?.split(' ')\n const funcName\n = stackParts?.find((item, index) => {\n if (item.length > 0 && item !== 'at') {\n // check if constructor\n if (item === 'new') {\n newIndex = index\n }\n return item\n }\n }) ?? '<unknown>'\n return newIndex ? `${funcName} ${stackParts?.[newIndex + 1]}` : funcName\n })\n }\n}\n","import type { Logger } from './Logger.ts'\n\nexport class IdLogger implements Logger {\n private _id?: () => string\n private _logger: Logger\n\n constructor(logger: Logger, id?: () => string) {\n this._logger = logger\n this._id = id\n }\n\n set id(id: string) {\n this._id = () => id\n }\n\n debug(...data: unknown[]) {\n this._logger?.debug(this.prefix(), ...data)\n }\n\n error(...data: unknown[]) {\n this._logger?.error(this.prefix(), ...data)\n }\n\n info(...data: unknown[]) {\n this._logger?.info(this.prefix(), ...data)\n }\n\n log(...data: unknown[]) {\n this._logger?.log(this.prefix(), ...data)\n }\n\n warn(...data: unknown[]) {\n this._logger?.warn(this.prefix(), ...data)\n }\n\n private prefix() {\n return `[${this._id?.()}]`\n }\n}\n","import type { EnumValue } from '@xylabs/enum'\nimport { Enum } from '@xylabs/enum'\nexport type LogFunction = (...data: unknown[]) => void\n\n/**\n * Interface to handle overlap between Winston &\n * `console` with as much congruency as possible.\n */\nexport interface Logger {\n debug: LogFunction\n error: LogFunction\n info: LogFunction\n log: LogFunction\n warn: LogFunction\n}\n\nexport const LogLevel = Enum({\n error: 1,\n warn: 2,\n info: 3,\n log: 4,\n debug: 5,\n})\n\nexport type LogLevel = EnumValue<typeof LogLevel>\n\nexport const NoOpLogFunction = (..._data: unknown[]) => void {}\n\nexport class ConsoleLogger implements Logger {\n constructor(readonly level: LogLevel = LogLevel.warn) {}\n\n get debug() {\n return this.level >= LogLevel.debug ? console.debug : NoOpLogFunction\n }\n\n get error() {\n return this.level >= LogLevel.error ? console.error : NoOpLogFunction\n }\n\n get info() {\n return this.level >= LogLevel.info ? console.info : NoOpLogFunction\n }\n\n get log() {\n return this.level >= LogLevel.log ? console.log : NoOpLogFunction\n }\n\n get warn() {\n return this.level >= LogLevel.warn ? console.warn : NoOpLogFunction\n }\n}\n"],"mappings":";AAAA,SAAS,mBAAmB;AAErB,IAAM,kBAAkB,CAAC,QAAQ,MAAM;AAC5C,MAAI;AACF,UAAM,IAAI,MAAM,uBAAuB;AAAA,EACzC,SAAS,IAAI;AACX,WAAO,YAAY,IAAI,CAAC,UAAU;AAChC,UAAI;AACJ,YAAM,aAAa,MAAM,OAAO,MAAM,IAAI,EAAE,KAAK,GAAG,MAAM,GAAG;AAC7D,YAAM,WACF,YAAY,KAAK,CAAC,MAAM,UAAU;AAClC,YAAI,KAAK,SAAS,KAAK,SAAS,MAAM;AAEpC,cAAI,SAAS,OAAO;AAClB,uBAAW;AAAA,UACb;AACA,iBAAO;AAAA,QACT;AAAA,MACF,CAAC,KAAK;AACR,aAAO,WAAW,GAAG,QAAQ,IAAI,aAAa,WAAW,CAAC,CAAC,KAAK;AAAA,IAClE,CAAC;AAAA,EACH;AACF;;;ACpBO,IAAM,WAAN,MAAiC;AAAA,EAC9B;AAAA,EACA;AAAA,EAER,YAAY,QAAgB,IAAmB;AAC7C,SAAK,UAAU;AACf,SAAK,MAAM;AAAA,EACb;AAAA,EAEA,IAAI,GAAG,IAAY;AACjB,SAAK,MAAM,MAAM;AAAA,EACnB;AAAA,EAEA,SAAS,MAAiB;AACxB,SAAK,SAAS,MAAM,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC5C;AAAA,EAEA,SAAS,MAAiB;AACxB,SAAK,SAAS,MAAM,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC5C;AAAA,EAEA,QAAQ,MAAiB;AACvB,SAAK,SAAS,KAAK,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC3C;AAAA,EAEA,OAAO,MAAiB;AACtB,SAAK,SAAS,IAAI,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC1C;AAAA,EAEA,QAAQ,MAAiB;AACvB,SAAK,SAAS,KAAK,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC3C;AAAA,EAEQ,SAAS;AACf,WAAO,IAAI,KAAK,MAAM,CAAC;AAAA,EACzB;AACF;;;ACrCA,SAAS,YAAY;AAed,IAAM,WAAW,KAAK;AAAA,EAC3B,OAAO;AAAA,EACP,MAAM;AAAA,EACN,MAAM;AAAA,EACN,KAAK;AAAA,EACL,OAAO;AACT,CAAC;AAIM,IAAM,kBAAkB,IAAI,UAAqB;AAEjD,IAAM,gBAAN,MAAsC;AAAA,EAC3C,YAAqB,QAAkB,SAAS,MAAM;AAAjC;AAAA,EAAkC;AAAA,EAEvD,IAAI,QAAQ;AACV,WAAO,KAAK,SAAS,SAAS,QAAQ,QAAQ,QAAQ;AAAA,EACxD;AAAA,EAEA,IAAI,QAAQ;AACV,WAAO,KAAK,SAAS,SAAS,QAAQ,QAAQ,QAAQ;AAAA,EACxD;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,SAAS,SAAS,OAAO,QAAQ,OAAO;AAAA,EACtD;AAAA,EAEA,IAAI,MAAM;AACR,WAAO,KAAK,SAAS,SAAS,MAAM,QAAQ,MAAM;AAAA,EACpD;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,SAAS,SAAS,OAAO,QAAQ,OAAO;AAAA,EACtD;AACF;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xylabs/logger",
3
- "version": "4.4.36",
3
+ "version": "4.5.0",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "keywords": [
6
6
  "log",
@@ -38,14 +38,15 @@
38
38
  "module": "dist/neutral/index.mjs",
39
39
  "types": "dist/neutral/index.d.ts",
40
40
  "dependencies": {
41
- "@xylabs/error": "^4.4.36"
41
+ "@xylabs/enum": "^4.5.0",
42
+ "@xylabs/error": "^4.5.0"
42
43
  },
43
44
  "devDependencies": {
44
- "@types/node": "^22.10.4",
45
+ "@types/node": "^22.10.7",
45
46
  "@xylabs/ts-scripts-yarn3": "^4.2.6",
46
47
  "@xylabs/tsconfig": "^4.2.6",
47
- "typescript": "^5.7.2",
48
- "vitest": "^2.1.8"
48
+ "typescript": "^5.7.3",
49
+ "vitest": "^3.0.3"
49
50
  },
50
51
  "engines": {
51
52
  "node": ">=18"
package/src/Logger.ts CHANGED
@@ -1,3 +1,5 @@
1
+ import type { EnumValue } from '@xylabs/enum'
2
+ import { Enum } from '@xylabs/enum'
1
3
  export type LogFunction = (...data: unknown[]) => void
2
4
 
3
5
  /**
@@ -12,13 +14,15 @@ export interface Logger {
12
14
  warn: LogFunction
13
15
  }
14
16
 
15
- export enum LogLevel {
16
- error = 1,
17
- warn = 2,
18
- info = 3,
19
- log = 4,
20
- debug = 5,
21
- }
17
+ export const LogLevel = Enum({
18
+ error: 1,
19
+ warn: 2,
20
+ info: 3,
21
+ log: 4,
22
+ debug: 5,
23
+ })
24
+
25
+ export type LogLevel = EnumValue<typeof LogLevel>
22
26
 
23
27
  export const NoOpLogFunction = (..._data: unknown[]) => void {}
24
28