@arikajs/logging 0.0.4 → 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 +84 -22
- package/dist/Contracts/Formatter.d.ts +4 -0
- package/dist/Contracts/Formatter.d.ts.map +1 -0
- package/dist/Contracts/Formatter.js +3 -0
- package/dist/Contracts/Formatter.js.map +1 -0
- package/dist/Drivers/ConsoleDriver.d.ts +1 -0
- package/dist/Drivers/ConsoleDriver.d.ts.map +1 -1
- package/dist/Drivers/ConsoleDriver.js +10 -5
- package/dist/Drivers/ConsoleDriver.js.map +1 -1
- package/dist/Drivers/FileDriver.d.ts +1 -0
- package/dist/Drivers/FileDriver.d.ts.map +1 -1
- package/dist/Drivers/FileDriver.js +3 -3
- package/dist/Drivers/FileDriver.js.map +1 -1
- package/dist/Drivers/SlackDriver.d.ts +17 -0
- package/dist/Drivers/SlackDriver.d.ts.map +1 -0
- package/dist/Drivers/SlackDriver.js +85 -0
- package/dist/Drivers/SlackDriver.js.map +1 -0
- package/dist/Formatters/JsonFormatter.d.ts +5 -0
- package/dist/Formatters/JsonFormatter.d.ts.map +1 -0
- package/dist/Formatters/JsonFormatter.js +18 -0
- package/dist/Formatters/JsonFormatter.js.map +1 -0
- package/dist/Formatters/LineFormatter.d.ts +7 -0
- package/dist/Formatters/LineFormatter.d.ts.map +1 -0
- package/dist/Formatters/LineFormatter.js +17 -0
- package/dist/Formatters/LineFormatter.js.map +1 -0
- package/dist/LogManager.d.ts +3 -0
- package/dist/LogManager.d.ts.map +1 -1
- package/dist/LogManager.js +30 -2
- package/dist/LogManager.js.map +1 -1
- package/dist/Logger.d.ts +3 -0
- package/dist/Logger.d.ts.map +1 -1
- package/dist/Logger.js +20 -9
- package/dist/Logger.js.map +1 -1
- package/package.json +8 -6
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**:
|
|
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
|
|
16
|
-
- **
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
|
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
|
-
##
|
|
165
|
+
## 🏗 Architecture
|
|
107
166
|
|
|
108
|
-
```
|
|
167
|
+
```text
|
|
109
168
|
logging/
|
|
110
169
|
├── src/
|
|
111
|
-
│ ├──
|
|
112
|
-
│ ├──
|
|
113
|
-
│ ├── Drivers/
|
|
114
|
-
│ │ ├── ConsoleDriver.ts
|
|
115
|
-
│ │ └── FileDriver.ts
|
|
116
|
-
│ ├── Contracts/
|
|
170
|
+
│ ├── Contracts
|
|
171
|
+
│ │ ├── Formatter.ts
|
|
117
172
|
│ │ └── Logger.ts
|
|
118
|
-
│
|
|
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
|
-
|
|
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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"Formatter.js","sourceRoot":"","sources":["../../src/Contracts/Formatter.ts"],"names":[],"mappings":""}
|
|
@@ -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;
|
|
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
|
|
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":";;;AAEA,MAAa,aAAa;
|
|
1
|
+
{"version":3,"file":"ConsoleDriver.js","sourceRoot":"","sources":["../../src/Drivers/ConsoleDriver.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FileDriver.d.ts","sourceRoot":"","sources":["../../src/Drivers/FileDriver.ts"],"names":[],"mappings":"
|
|
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
|
|
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":";;;;;;AAEA,4CAAoB;AACpB,gDAAwB;AAExB,MAAa,UAAU;
|
|
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":";;;;;;AAEA,kDAA0B;AAE1B,MAAa,WAAW;IAYpB,YAAoB,MAAW;QAAX,WAAM,GAAN,MAAM,CAAK;QAXvB,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;QAGE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;QACvE,CAAC;IACL,CAAC;IAED,GAAG,CAAC,KAAa,EAAE,OAAe,EAAE,OAAa;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,UAAU,CAAC;QACpD,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YAChD,OAAO;QACX,CAAC;QAED,MAAM,OAAO,GAAG;YACZ,IAAI,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE,MAAM,OAAO,EAAE;YAC7C,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;gBACnB;oBACI,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;oBACrC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;wBACrC,KAAK,EAAE,GAAG;wBACV,KAAK,EAAE,OAAO,OAAO,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;wBAC7F,KAAK,EAAE,IAAI;qBACd,CAAC,CAAC;iBACN;aACJ,CAAC,CAAC,CAAC,EAAE;SACT,CAAC;QAEF,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAErC,MAAM,GAAG,GAAG,eAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACvC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACL,cAAc,EAAE,kBAAkB;gBAClC,gBAAgB,EAAE,IAAI,CAAC,MAAM;aAChC;SACJ,CAAC,CAAC;QAEH,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YACtB,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,KAAK,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAChB,GAAG,CAAC,GAAG,EAAE,CAAC;IACd,CAAC;IAEO,kBAAkB,CAAC,KAAa;QACpC,QAAQ,KAAK,EAAE,CAAC;YACZ,KAAK,WAAW,CAAC;YACjB,KAAK,OAAO,CAAC;YACb,KAAK,UAAU;gBACX,OAAO,SAAS,CAAC;YACrB,KAAK,OAAO;gBACR,OAAO,SAAS,CAAC;YACrB,KAAK,SAAS;gBACV,OAAO,SAAS,CAAC;YACrB,KAAK,MAAM;gBACP,OAAO,SAAS,CAAC;YACrB,KAAK,OAAO;gBACR,OAAO,SAAS,CAAC;YACrB;gBACI,OAAO,SAAS,CAAC;QACzB,CAAC;IACL,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;AAnFD,kCAmFC"}
|
|
@@ -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"}
|
package/dist/LogManager.d.ts
CHANGED
|
@@ -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;
|
package/dist/LogManager.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LogManager.d.ts","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":"
|
|
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"}
|
package/dist/LogManager.js
CHANGED
|
@@ -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 {
|
package/dist/LogManager.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LogManager.js","sourceRoot":"","sources":["../src/LogManager.ts"],"names":[],"mappings":";;;
|
|
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;
|
package/dist/Logger.d.ts.map
CHANGED
|
@@ -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;
|
|
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
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
package/dist/Logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":";;;AAGA,MAAa,MAAM;
|
|
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
|
+
"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": "
|
|
14
|
-
"test:watch": "
|
|
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
|
|
34
|
+
"url": "git+https://github.com/ArikaJs/arikajs.git",
|
|
35
|
+
"directory": "packages/logging"
|
|
34
36
|
},
|
|
35
37
|
"bugs": {
|
|
36
|
-
"url": "https://github.com/arikajs/
|
|
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",
|