@arikajs/logging 0.0.3 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -9,11 +9,13 @@ It allows applications to write logs to multiple destinations (console, files, e
9
9
  ## ✨ Features
10
10
 
11
11
  - **Multiple log channels**: Separate outputs for different needs
12
- - **Driver-based architecture**: Pluggable backends (console, file, etc.)
13
- - **Log levels**: Compatible with standard levels (debug, info, warning, error, etc.)
12
+ - **Driver-based architecture**: Pluggable backends (console, file, slack, etc.)
13
+ - **Log levels**: RFC 5424 compliant (emergency, alert, critical, error, warning, notice, info, debug)
14
+ - **Shared Context**: Set global metadata across all log entries
15
+ - **JSON Formatting**: Native support for structured logs
14
16
  - **Stackable channels**: Combine multiple channels
15
- - **File & console drivers (v1)**: Essential logging outputs
16
- - **Contextual logging**: Pass metadata with log messages
17
+ - **File & console drivers**: Essential logging outputs
18
+ - **Slack integration**: Native webhook support for critical alerts
17
19
  - **TypeScript-first**: Strongly typed interface
18
20
 
19
21
  ---
@@ -39,10 +41,59 @@ Log.info('Application started');
39
41
  Log.error('Something went wrong', { userId: 1 });
40
42
  ```
41
43
 
42
- ### 📂 Log Channels
44
+ Log.channel('daily').warning('Low disk space');
45
+ ```
46
+
47
+ ### 🎨 Formatting System
48
+
49
+ Arika Logging supports a pluggable formatting system. You can choose from built-in formatters or create your own.
50
+
51
+ **Available Formatters:**
52
+ - `json`: Structured JSON output (merges context into root)
53
+ - `pretty`: Colored text output for development
54
+ - `line` (or `text`): Standard plain text output
43
55
 
44
56
  ```ts
45
- Log.channel('daily').warning('Low disk space');
57
+ export default {
58
+ channels: {
59
+ // Production: Structured JSON for ELK/Datadog
60
+ app: {
61
+ driver: 'file',
62
+ path: './logs/app.json',
63
+ formatter: 'json',
64
+ },
65
+
66
+ // Development: Colored console output
67
+ console: {
68
+ driver: 'console',
69
+ formatter: 'pretty',
70
+ }
71
+ }
72
+ }
73
+ ```
74
+
75
+ **JSON Output Example:**
76
+ ```json
77
+ {
78
+ "timestamp": "2026-02-21T10:30:00Z",
79
+ "level": "info",
80
+ "message": "User logged in",
81
+ "userId": 1,
82
+ "ip": "127.0.0.1"
83
+ }
84
+ ```
85
+
86
+ ---
87
+
88
+ ### 🧠 Shared Context
89
+
90
+ You can append context that will be included in every subsequent log entry for that logger.
91
+
92
+ ```ts
93
+ Log.withContext({ traceId: 'req_123' });
94
+
95
+ Log.info('Processing order'); // Included traceId: req_123
96
+ Log.error('Order failed'); // Included traceId: req_123
46
97
  ```
47
98
 
48
99
  ---
@@ -75,6 +126,13 @@ export default {
75
126
  console: {
76
127
  driver: 'console',
77
128
  level: process.env.LOG_LEVEL || 'debug',
129
+ formatter: 'json', // Use 'json' for structured logs
130
+ },
131
+
132
+ slack: {
133
+ driver: 'slack',
134
+ url: process.env.LOG_SLACK_WEBHOOK_URL,
135
+ level: 'critical',
78
136
  },
79
137
  },
80
138
  };
@@ -86,11 +144,12 @@ export default {
86
144
 
87
145
  | Driver | Status | Description |
88
146
  | :--- | :--- | :--- |
89
- | **Console** | ✅ Supported | Standard output logging |
90
- | **File** | ✅ Supported | Single file logging |
147
+ | **Console** | ✅ Supported | Standard output logging (Supports JSON) |
148
+ | **File** | ✅ Supported | Single file logging (Supports JSON) |
91
149
  | **Daily** | ✅ Supported | Date-based rotating log files |
92
150
  | **Stack** | ✅ Supported | Multi-channel composite logging |
93
- | External services | Planned | Slack, Papertrail, etc. |
151
+ | **Slack** | Supported | Critical alerts via Webhooks |
152
+ | Papertrail | ⏳ Planned | External service driver |
94
153
 
95
154
  ---
96
155
 
@@ -103,28 +162,31 @@ export default {
103
162
 
104
163
  ---
105
164
 
106
- ## 🧠 Architecture (High Level)
165
+ ## 🏗 Architecture
107
166
 
108
- ```
167
+ ```text
109
168
  logging/
110
169
  ├── src/
111
- │ ├── LogManager.ts
112
- │ ├── Logger.ts
113
- │ ├── Drivers/
114
- │ │ ├── ConsoleDriver.ts
115
- │ │ └── FileDriver.ts
116
- │ ├── Contracts/
170
+ │ ├── Contracts
171
+ ├── Formatter.ts
117
172
  │ │ └── Logger.ts
118
- └── index.ts
173
+ ├── Drivers
174
+ │ │ ├── ConsoleDriver.ts
175
+ │ │ ├── DailyDriver.ts
176
+ │ │ ├── FileDriver.ts
177
+ │ │ └── SlackDriver.ts
178
+ │ ├── Formatters
179
+ │ │ ├── JsonFormatter.ts
180
+ │ │ └── LineFormatter.ts
181
+ │ ├── index.ts
182
+ │ ├── Logger.ts
183
+ │ └── LogManager.ts
119
184
  ├── tests/
120
185
  ├── package.json
121
186
  ├── tsconfig.json
122
- ├── README.md
123
- └── LICENSE
187
+ └── README.md
124
188
  ```
125
189
 
126
- ---
127
-
128
190
  ## 📄 License
129
191
 
130
192
  `@arikajs/logging` is open-source software licensed under the **MIT License**.
@@ -0,0 +1,4 @@
1
+ export interface Formatter {
2
+ format(level: string, message: string, context?: any): string;
3
+ }
4
+ //# sourceMappingURL=Formatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Formatter.d.ts","sourceRoot":"","sources":["../../src/Contracts/Formatter.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,SAAS;IACtB,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC;CACjE"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=Formatter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Formatter.js","sourceRoot":"","sources":["../../src/Contracts/Formatter.ts"],"names":[],"mappings":""}
@@ -3,6 +3,7 @@ export declare class ConsoleDriver implements Logger {
3
3
  private config;
4
4
  private colors;
5
5
  private levels;
6
+ private formatter;
6
7
  constructor(config?: any);
7
8
  log(level: string, message: string, context?: any): void;
8
9
  emergency(message: string, context?: any): void;
@@ -1 +1 @@
1
- {"version":3,"file":"ConsoleDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/ConsoleDriver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,qBAAa,aAAc,YAAW,MAAM;IAuB5B,OAAO,CAAC,MAAM;IAtB1B,OAAO,CAAC,MAAM,CASZ;IAEF,OAAO,CAAC,MAAM,CASZ;gBAEkB,MAAM,GAAE,GAAQ;IAEpC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAmCxD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC9C"}
1
+ {"version":3,"file":"ConsoleDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/ConsoleDriver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAI7C,qBAAa,aAAc,YAAW,MAAM;IAyB5B,OAAO,CAAC,MAAM;IAxB1B,OAAO,CAAC,MAAM,CASZ;IAEF,OAAO,CAAC,MAAM,CASZ;IAEF,OAAO,CAAC,SAAS,CAAY;gBAET,MAAM,GAAE,GAAQ;IAUpC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IA8BxD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC9C"}
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ConsoleDriver = void 0;
4
+ const LineFormatter_1 = require("../Formatters/LineFormatter");
4
5
  class ConsoleDriver {
5
6
  constructor(config = {}) {
6
7
  this.config = config;
@@ -24,17 +25,21 @@ class ConsoleDriver {
24
25
  info: 6,
25
26
  debug: 7,
26
27
  };
28
+ // If config.formatter was 'pretty', LogManager might have returned a default LineFormatter.
29
+ // We want to ensure ConsoleDriver uses colors for 'pretty' or default.
30
+ if (!config.formatter || (typeof config._rawFormatter === 'string' && config._rawFormatter === 'pretty')) {
31
+ this.formatter = new LineFormatter_1.LineFormatter(this.colors);
32
+ }
33
+ else {
34
+ this.formatter = config.formatter;
35
+ }
27
36
  }
28
37
  log(level, message, context) {
29
38
  const configLevel = this.config.level || 'debug';
30
39
  if (this.levels[level] > this.levels[configLevel]) {
31
40
  return;
32
41
  }
33
- const timestamp = new Date().toISOString().replace('T', ' ').split('.')[0];
34
- const color = this.colors[level] || '';
35
- const reset = '\x1b[0m';
36
- const contextStr = context ? ' ' + JSON.stringify(context) : '';
37
- const output = `[${timestamp}] ${color}${level.toUpperCase()}${reset}: ${message}${contextStr}`;
42
+ const output = this.formatter.format(level, message, context);
38
43
  switch (level) {
39
44
  case 'emergency':
40
45
  case 'alert':
@@ -1 +1 @@
1
- {"version":3,"file":"ConsoleDriver.js","sourceRoot":"","sources":["../../src/Drivers/ConsoleDriver.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ConsoleDriver.js","sourceRoot":"","sources":["../../src/Drivers/ConsoleDriver.ts"],"names":[],"mappings":"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"}
@@ -3,6 +3,7 @@ export declare class FileDriver implements Logger {
3
3
  private config;
4
4
  private filePath;
5
5
  private levels;
6
+ private formatter;
6
7
  constructor(config: any);
7
8
  private ensureFileExists;
8
9
  log(level: string, message: string, context?: any): void;
@@ -1 +1 @@
1
- {"version":3,"file":"FileDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/FileDriver.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAI7C,qBAAa,UAAW,YAAW,MAAM;IAczB,OAAO,CAAC,MAAM;IAb1B,OAAO,CAAC,QAAQ,CAAS;IAEzB,OAAO,CAAC,MAAM,CASZ;gBAEkB,MAAM,EAAE,GAAG;IAK/B,OAAO,CAAC,gBAAgB;IAOxB,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAaxD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC9C"}
1
+ {"version":3,"file":"FileDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/FileDriver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAM7C,qBAAa,UAAW,YAAW,MAAM;IAgBzB,OAAO,CAAC,MAAM;IAf1B,OAAO,CAAC,QAAQ,CAAS;IAEzB,OAAO,CAAC,MAAM,CASZ;IAEF,OAAO,CAAC,SAAS,CAAY;gBAET,MAAM,EAAE,GAAG;IAM/B,OAAO,CAAC,gBAAgB;IAOxB,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAWxD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC9C"}
@@ -4,6 +4,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.FileDriver = void 0;
7
+ const LineFormatter_1 = require("../Formatters/LineFormatter");
7
8
  const fs_1 = __importDefault(require("fs"));
8
9
  const path_1 = __importDefault(require("path"));
9
10
  class FileDriver {
@@ -21,6 +22,7 @@ class FileDriver {
21
22
  };
22
23
  this.filePath = config.path || 'app.log';
23
24
  this.ensureFileExists();
25
+ this.formatter = config.formatter || new LineFormatter_1.LineFormatter();
24
26
  }
25
27
  ensureFileExists() {
26
28
  const dir = path_1.default.dirname(this.filePath);
@@ -33,9 +35,7 @@ class FileDriver {
33
35
  if (this.levels[level] > this.levels[configLevel]) {
34
36
  return;
35
37
  }
36
- const timestamp = new Date().toISOString().replace('T', ' ').split('.')[0];
37
- const contextStr = context ? ' ' + JSON.stringify(context) : '';
38
- const line = `[${timestamp}] ${level.toUpperCase()}: ${message}${contextStr}\n`;
38
+ const line = this.formatter.format(level, message, context) + '\n';
39
39
  fs_1.default.appendFileSync(this.filePath, line);
40
40
  }
41
41
  emergency(message, context) { this.log('emergency', message, context); }
@@ -1 +1 @@
1
- {"version":3,"file":"FileDriver.js","sourceRoot":"","sources":["../../src/Drivers/FileDriver.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"FileDriver.js","sourceRoot":"","sources":["../../src/Drivers/FileDriver.ts"],"names":[],"mappings":";;;;;;AAEA,+DAA4D;AAC5D,4CAAoB;AACpB,gDAAwB;AAExB,MAAa,UAAU;IAgBnB,YAAoB,MAAW;QAAX,WAAM,GAAN,MAAM,CAAK;QAbvB,WAAM,GAA2B;YACrC,SAAS,EAAE,CAAC;YACZ,KAAK,EAAE,CAAC;YACR,QAAQ,EAAE,CAAC;YACX,KAAK,EAAE,CAAC;YACR,OAAO,EAAE,CAAC;YACV,MAAM,EAAE,CAAC;YACT,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,CAAC;SACX,CAAC;QAKE,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI,SAAS,CAAC;QACzC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,IAAI,6BAAa,EAAE,CAAC;IAC7D,CAAC;IAEO,gBAAgB;QACpB,MAAM,GAAG,GAAG,cAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACxC,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACtB,YAAE,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3C,CAAC;IACL,CAAC;IAED,GAAG,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC;QACjD,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YAChD,OAAO;QACX,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;QAEnE,YAAE,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,SAAS,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5F,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpF,QAAQ,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC1F,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpF,OAAO,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACxF,MAAM,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACtF,IAAI,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAClF,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;CACvF;AAhDD,gCAgDC"}
@@ -0,0 +1,17 @@
1
+ import { Logger } from '../Contracts/Logger';
2
+ export declare class SlackDriver implements Logger {
3
+ private config;
4
+ private levels;
5
+ constructor(config: any);
6
+ log(level: string, message: string, context?: any): void;
7
+ private getAttachmentColor;
8
+ emergency(message: string, context?: any): void;
9
+ alert(message: string, context?: any): void;
10
+ critical(message: string, context?: any): void;
11
+ error(message: string, context?: any): void;
12
+ warning(message: string, context?: any): void;
13
+ notice(message: string, context?: any): void;
14
+ info(message: string, context?: any): void;
15
+ debug(message: string, context?: any): void;
16
+ }
17
+ //# sourceMappingURL=SlackDriver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SlackDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/SlackDriver.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAG7C,qBAAa,WAAY,YAAW,MAAM;IAY1B,OAAO,CAAC,MAAM;IAX1B,OAAO,CAAC,MAAM,CASZ;gBAEkB,MAAM,EAAE,GAAG;IAM/B,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAsCxD,OAAO,CAAC,kBAAkB;IAmB1B,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC9C"}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SlackDriver = void 0;
7
+ const https_1 = __importDefault(require("https"));
8
+ class SlackDriver {
9
+ constructor(config) {
10
+ this.config = config;
11
+ this.levels = {
12
+ emergency: 0,
13
+ alert: 1,
14
+ critical: 2,
15
+ error: 3,
16
+ warning: 4,
17
+ notice: 5,
18
+ info: 6,
19
+ debug: 7,
20
+ };
21
+ if (!config.url) {
22
+ throw new Error('Slack webhook URL is required for Slack driver.');
23
+ }
24
+ }
25
+ log(level, message, context) {
26
+ const configLevel = this.config.level || 'critical';
27
+ if (this.levels[level] > this.levels[configLevel]) {
28
+ return;
29
+ }
30
+ const payload = {
31
+ text: `*[${level.toUpperCase()}]* ${message}`,
32
+ attachments: context ? [
33
+ {
34
+ color: this.getAttachmentColor(level),
35
+ fields: Object.keys(context).map(key => ({
36
+ title: key,
37
+ value: typeof context[key] === 'object' ? JSON.stringify(context[key]) : String(context[key]),
38
+ short: true
39
+ }))
40
+ }
41
+ ] : []
42
+ };
43
+ const data = JSON.stringify(payload);
44
+ const req = https_1.default.request(this.config.url, {
45
+ method: 'POST',
46
+ headers: {
47
+ 'Content-Type': 'application/json',
48
+ 'Content-Length': data.length,
49
+ },
50
+ });
51
+ req.on('error', (error) => {
52
+ console.error('Failed to send log to Slack:', error);
53
+ });
54
+ req.write(data);
55
+ req.end();
56
+ }
57
+ getAttachmentColor(level) {
58
+ switch (level) {
59
+ case 'emergency':
60
+ case 'alert':
61
+ case 'critical':
62
+ return '#FF0000';
63
+ case 'error':
64
+ return '#E01E5A';
65
+ case 'warning':
66
+ return '#ECB22E';
67
+ case 'info':
68
+ return '#36C5F0';
69
+ case 'debug':
70
+ return '#909090';
71
+ default:
72
+ return '#D0D0D0';
73
+ }
74
+ }
75
+ emergency(message, context) { this.log('emergency', message, context); }
76
+ alert(message, context) { this.log('alert', message, context); }
77
+ critical(message, context) { this.log('critical', message, context); }
78
+ error(message, context) { this.log('error', message, context); }
79
+ warning(message, context) { this.log('warning', message, context); }
80
+ notice(message, context) { this.log('notice', message, context); }
81
+ info(message, context) { this.log('info', message, context); }
82
+ debug(message, context) { this.log('debug', message, context); }
83
+ }
84
+ exports.SlackDriver = SlackDriver;
85
+ //# sourceMappingURL=SlackDriver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SlackDriver.js","sourceRoot":"","sources":["../../src/Drivers/SlackDriver.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { Formatter } from '../Contracts/Formatter';
2
+ export declare class JsonFormatter implements Formatter {
3
+ format(level: string, message: string, context?: any): string;
4
+ }
5
+ //# sourceMappingURL=JsonFormatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonFormatter.d.ts","sourceRoot":"","sources":["../../src/Formatters/JsonFormatter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,qBAAa,aAAc,YAAW,SAAS;IAC3C,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,MAAM;CAahE"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JsonFormatter = void 0;
4
+ class JsonFormatter {
5
+ format(level, message, context) {
6
+ const payload = {
7
+ timestamp: new Date().toISOString(),
8
+ level,
9
+ message,
10
+ };
11
+ if (context) {
12
+ Object.assign(payload, context);
13
+ }
14
+ return JSON.stringify(payload);
15
+ }
16
+ }
17
+ exports.JsonFormatter = JsonFormatter;
18
+ //# sourceMappingURL=JsonFormatter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonFormatter.js","sourceRoot":"","sources":["../../src/Formatters/JsonFormatter.ts"],"names":[],"mappings":";;;AAGA,MAAa,aAAa;IACtB,MAAM,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa;QAChD,MAAM,OAAO,GAAQ;YACjB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,KAAK;YACL,OAAO;SACV,CAAC;QAEF,IAAI,OAAO,EAAE,CAAC;YACV,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;CACJ;AAdD,sCAcC"}
@@ -0,0 +1,7 @@
1
+ import { Formatter } from '../Contracts/Formatter';
2
+ export declare class LineFormatter implements Formatter {
3
+ private colors;
4
+ constructor(colors?: Record<string, string>);
5
+ format(level: string, message: string, context?: any): string;
6
+ }
7
+ //# sourceMappingURL=LineFormatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LineFormatter.d.ts","sourceRoot":"","sources":["../../src/Formatters/LineFormatter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,qBAAa,aAAc,YAAW,SAAS;IAC/B,OAAO,CAAC,MAAM;gBAAN,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM;IAEvD,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,MAAM;CAQhE"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LineFormatter = void 0;
4
+ class LineFormatter {
5
+ constructor(colors = {}) {
6
+ this.colors = colors;
7
+ }
8
+ format(level, message, context) {
9
+ const timestamp = new Date().toISOString().replace('T', ' ').split('.')[0];
10
+ const color = this.colors[level] || '';
11
+ const reset = color ? '\x1b[0m' : '';
12
+ const contextStr = context ? ' ' + JSON.stringify(context) : '';
13
+ return `[${timestamp}] ${color}${level.toUpperCase()}${reset}: ${message}${contextStr}`;
14
+ }
15
+ }
16
+ exports.LineFormatter = LineFormatter;
17
+ //# sourceMappingURL=LineFormatter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LineFormatter.js","sourceRoot":"","sources":["../../src/Formatters/LineFormatter.ts"],"names":[],"mappings":";;;AAGA,MAAa,aAAa;IACtB,YAAoB,SAAiC,EAAE;QAAnC,WAAM,GAAN,MAAM,CAA6B;IAAI,CAAC;IAE5D,MAAM,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa;QAChD,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACvC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QACrC,MAAM,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEhE,OAAO,IAAI,SAAS,KAAK,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,GAAG,KAAK,KAAK,OAAO,GAAG,UAAU,EAAE,CAAC;IAC5F,CAAC;CACJ;AAXD,sCAWC"}
@@ -1,5 +1,6 @@
1
1
  import { Logger } from './Logger';
2
2
  import { Logger as LoggerContract } from './Contracts/Logger';
3
+ import { Formatter } from './Contracts/Formatter';
3
4
  export declare class LogManager {
4
5
  protected config: any;
5
6
  protected channels: Map<string, Logger>;
@@ -7,9 +8,11 @@ export declare class LogManager {
7
8
  constructor(config: any);
8
9
  channel(name?: string): Logger;
9
10
  protected resolve(name: string): Logger;
11
+ protected resolveFormatter(formatter: any): Formatter;
10
12
  protected createDailyDriver(config: any): LoggerContract;
11
13
  protected createConsoleDriver(config: any): LoggerContract;
12
14
  protected createFileDriver(config: any): LoggerContract;
15
+ protected createSlackDriver(config: any): LoggerContract;
13
16
  protected createStackDriver(config: any): LoggerContract;
14
17
  extend(driver: string, callback: (config: any) => LoggerContract): this;
15
18
  emergency(message: string, context?: any): void;
@@ -1 +1 @@
1
- {"version":3,"file":"LogManager.d.ts","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAIlC,OAAO,EAAE,MAAM,IAAI,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAE9D,qBAAa,UAAU;IAIP,SAAS,CAAC,MAAM,EAAE,GAAG;IAHjC,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IACpD,SAAS,CAAC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,cAAc,CAAC,CAAa;gBAE7D,MAAM,EAAE,GAAG;IAE1B,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM;IAUrC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAoBvC,SAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAIxD,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAI1D,SAAS,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAIvD,SAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAkBjD,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,cAAc,GAAG,IAAI;IAMvE,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAClE"}
1
+ {"version":3,"file":"LogManager.d.ts","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAKlC,OAAO,EAAE,MAAM,IAAI,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAG9D,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAElD,qBAAa,UAAU;IAIP,SAAS,CAAC,MAAM,EAAE,GAAG;IAHjC,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IACpD,SAAS,CAAC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,cAAc,CAAC,CAAa;gBAE7D,MAAM,EAAE,GAAG;IAE1B,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM;IAUrC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAsBvC,SAAS,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,GAAG,SAAS;IAwBrD,SAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAIxD,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAI1D,SAAS,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAIvD,SAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAIxD,SAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,GAAG,cAAc;IAkBjD,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,cAAc,GAAG,IAAI;IAMvE,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAClE"}
@@ -5,6 +5,9 @@ const Logger_1 = require("./Logger");
5
5
  const ConsoleDriver_1 = require("./Drivers/ConsoleDriver");
6
6
  const FileDriver_1 = require("./Drivers/FileDriver");
7
7
  const DailyDriver_1 = require("./Drivers/DailyDriver");
8
+ const SlackDriver_1 = require("./Drivers/SlackDriver");
9
+ const JsonFormatter_1 = require("./Formatters/JsonFormatter");
10
+ const LineFormatter_1 = require("./Formatters/LineFormatter");
8
11
  class LogManager {
9
12
  constructor(config) {
10
13
  this.config = config;
@@ -23,15 +26,37 @@ class LogManager {
23
26
  if (!config) {
24
27
  throw new Error(`Log channel [${name}] is not defined.`);
25
28
  }
29
+ const formatter = this.resolveFormatter(config.formatter);
26
30
  if (this.customCreators.has(config.driver)) {
27
- return new Logger_1.Logger(this.customCreators.get(config.driver)(config));
31
+ return new Logger_1.Logger(this.customCreators.get(config.driver)({ ...config, formatter, _rawFormatter: config.formatter }));
28
32
  }
29
33
  const driverMethod = `create${config.driver.charAt(0).toUpperCase() + config.driver.slice(1)}Driver`;
30
34
  if (typeof this[driverMethod] === 'function') {
31
- return new Logger_1.Logger(this[driverMethod](config));
35
+ return new Logger_1.Logger(this[driverMethod]({ ...config, formatter, _rawFormatter: config.formatter }));
32
36
  }
33
37
  throw new Error(`Driver [${config.driver}] is not supported.`);
34
38
  }
39
+ resolveFormatter(formatter) {
40
+ if (typeof formatter === 'string') {
41
+ switch (formatter) {
42
+ case 'json':
43
+ return new JsonFormatter_1.JsonFormatter();
44
+ case 'line':
45
+ case 'text':
46
+ return new LineFormatter_1.LineFormatter();
47
+ case 'pretty':
48
+ // We'll let the driver handle the 'pretty' default if it wants colors
49
+ // or return a standard LineFormatter here.
50
+ return new LineFormatter_1.LineFormatter();
51
+ default:
52
+ throw new Error(`Formatter [${formatter}] not supported.`);
53
+ }
54
+ }
55
+ if (typeof formatter === 'object' && 'format' in formatter) {
56
+ return formatter;
57
+ }
58
+ return new LineFormatter_1.LineFormatter();
59
+ }
35
60
  createDailyDriver(config) {
36
61
  return new DailyDriver_1.DailyDriver(config);
37
62
  }
@@ -41,6 +66,9 @@ class LogManager {
41
66
  createFileDriver(config) {
42
67
  return new FileDriver_1.FileDriver(config);
43
68
  }
69
+ createSlackDriver(config) {
70
+ return new SlackDriver_1.SlackDriver(config);
71
+ }
44
72
  createStackDriver(config) {
45
73
  const channels = config.channels.map((channel) => this.channel(channel));
46
74
  return new class {
@@ -1 +1 @@
1
- {"version":3,"file":"LogManager.js","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"LogManager.js","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":"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"}
package/dist/Logger.d.ts CHANGED
@@ -1,7 +1,10 @@
1
1
  import { Logger as LoggerContract } from './Contracts/Logger';
2
2
  export declare class Logger implements LoggerContract {
3
3
  protected driver: LoggerContract;
4
+ protected sharedContext: any;
4
5
  constructor(driver: LoggerContract);
6
+ withContext(context: any): this;
7
+ protected getMergedContext(context?: any): any;
5
8
  emergency(message: string, context?: any): void;
6
9
  alert(message: string, context?: any): void;
7
10
  critical(message: string, context?: any): void;
@@ -1 +1 @@
1
- {"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,IAAI,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAE9D,qBAAa,MAAO,YAAW,cAAc;IAC7B,SAAS,CAAC,MAAM,EAAE,cAAc;gBAAtB,MAAM,EAAE,cAAc;IAE5C,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC3D"}
1
+ {"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,IAAI,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAE9D,qBAAa,MAAO,YAAW,cAAc;IAG7B,SAAS,CAAC,MAAM,EAAE,cAAc;IAF5C,SAAS,CAAC,aAAa,EAAE,GAAG,CAAM;gBAEZ,MAAM,EAAE,cAAc;IAErC,WAAW,CAAC,OAAO,EAAE,GAAG,GAAG,IAAI;IAKtC,SAAS,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,GAAG,GAAG,GAAG;IAO9C,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC7C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;IAC3C,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,IAAI;CAC3D"}
package/dist/Logger.js CHANGED
@@ -4,16 +4,27 @@ exports.Logger = void 0;
4
4
  class Logger {
5
5
  constructor(driver) {
6
6
  this.driver = driver;
7
+ this.sharedContext = {};
7
8
  }
8
- emergency(message, context) { this.driver.emergency(message, context); }
9
- alert(message, context) { this.driver.alert(message, context); }
10
- critical(message, context) { this.driver.critical(message, context); }
11
- error(message, context) { this.driver.error(message, context); }
12
- warning(message, context) { this.driver.warning(message, context); }
13
- notice(message, context) { this.driver.notice(message, context); }
14
- info(message, context) { this.driver.info(message, context); }
15
- debug(message, context) { this.driver.debug(message, context); }
16
- log(level, message, context) { this.driver.log(level, message, context); }
9
+ withContext(context) {
10
+ this.sharedContext = { ...this.sharedContext, ...context };
11
+ return this;
12
+ }
13
+ getMergedContext(context) {
14
+ if (!context && Object.keys(this.sharedContext).length === 0) {
15
+ return undefined;
16
+ }
17
+ return { ...this.sharedContext, ...context };
18
+ }
19
+ emergency(message, context) { this.driver.emergency(message, this.getMergedContext(context)); }
20
+ alert(message, context) { this.driver.alert(message, this.getMergedContext(context)); }
21
+ critical(message, context) { this.driver.critical(message, this.getMergedContext(context)); }
22
+ error(message, context) { this.driver.error(message, this.getMergedContext(context)); }
23
+ warning(message, context) { this.driver.warning(message, this.getMergedContext(context)); }
24
+ notice(message, context) { this.driver.notice(message, this.getMergedContext(context)); }
25
+ info(message, context) { this.driver.info(message, this.getMergedContext(context)); }
26
+ debug(message, context) { this.driver.debug(message, this.getMergedContext(context)); }
27
+ log(level, message, context) { this.driver.log(level, message, this.getMergedContext(context)); }
17
28
  }
18
29
  exports.Logger = Logger;
19
30
  //# sourceMappingURL=Logger.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":";;;AAGA,MAAa,MAAM;IACf,YAAsB,MAAsB;QAAtB,WAAM,GAAN,MAAM,CAAgB;IAAI,CAAC;IAEjD,SAAS,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5F,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpF,QAAQ,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC1F,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpF,OAAO,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACxF,MAAM,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACtF,IAAI,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAClF,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpF,GAAG,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;CACzG;AAZD,wBAYC"}
1
+ {"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":";;;AAGA,MAAa,MAAM;IAGf,YAAsB,MAAsB;QAAtB,WAAM,GAAN,MAAM,CAAgB;QAFlC,kBAAa,GAAQ,EAAE,CAAC;IAEc,CAAC;IAE1C,WAAW,CAAC,OAAY;QAC3B,IAAI,CAAC,aAAa,GAAG,EAAE,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;QAC3D,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,gBAAgB,CAAC,OAAa;QACpC,IAAI,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3D,OAAO,SAAS,CAAC;QACrB,CAAC;QACD,OAAO,EAAE,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACjD,CAAC;IAED,SAAS,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACnH,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3G,QAAQ,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACjH,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3G,OAAO,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/G,MAAM,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7G,IAAI,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACzG,KAAK,CAAC,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa,IAAU,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;CAChI;AA1BD,wBA0BC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@arikajs/logging",
3
- "version": "0.0.3",
3
+ "version": "0.0.5",
4
4
  "description": "Flexible, channel-based logging system for the ArikaJS framework.",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",
@@ -10,8 +10,9 @@
10
10
  "build:tests": "tsc -p tsconfig.test.json",
11
11
  "clean": "rm -rf dist",
12
12
  "prepare": "echo skip",
13
- "test": "npm run build && npm run build:tests && node scripts/fix-test-imports.js && node --test 'dist/tests/**/*.test.js'",
14
- "test:watch": "npm run build && npm run build:tests && node --test --watch 'dist/tests/**/*.test.js'"
13
+ "test": "npx tsx --test tests/**/*.test.ts",
14
+ "test:watch": "npx tsx --test --watch tests/**/*.test.ts",
15
+ "dev": "tsc -p tsconfig.json --watch"
15
16
  },
16
17
  "files": [
17
18
  "dist"
@@ -30,12 +31,13 @@
30
31
  },
31
32
  "repository": {
32
33
  "type": "git",
33
- "url": "git+https://github.com/arikajs/logging.git"
34
+ "url": "git+https://github.com/ArikaJs/arikajs.git",
35
+ "directory": "packages/logging"
34
36
  },
35
37
  "bugs": {
36
- "url": "https://github.com/arikajs/logging/issues"
38
+ "url": "https://github.com/ArikaJs/arikajs/issues"
37
39
  },
38
- "homepage": "https://github.com/arikajs/logging#readme",
40
+ "homepage": "https://github.com/ArikaJs/arikajs/tree/main/packages/logging#readme",
39
41
  "dependencies": {},
40
42
  "devDependencies": {
41
43
  "@types/node": "^20.11.24",