@abbacchio/transport 0.1.2 → 0.1.4
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 +154 -0
- package/dist/client.d.ts +35 -1
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +62 -3
- package/dist/client.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/transports/bunyan.d.ts +28 -0
- package/dist/transports/bunyan.d.ts.map +1 -1
- package/dist/transports/bunyan.js +42 -0
- package/dist/transports/bunyan.js.map +1 -1
- package/dist/transports/index.d.ts +2 -2
- package/dist/transports/index.d.ts.map +1 -1
- package/dist/transports/index.js +2 -2
- package/dist/transports/index.js.map +1 -1
- package/dist/transports/pino.d.ts +46 -1
- package/dist/transports/pino.d.ts.map +1 -1
- package/dist/transports/pino.js +70 -0
- package/dist/transports/pino.js.map +1 -1
- package/dist/transports/winston.d.ts +28 -0
- package/dist/transports/winston.d.ts.map +1 -1
- package/dist/transports/winston.js +42 -0
- package/dist/transports/winston.js.map +1 -1
- package/package.json +20 -6
- package/pino-transport.cjs +30 -0
- package/src/client.ts +72 -3
- package/src/index.ts +2 -2
- package/src/transports/bunyan.ts +49 -0
- package/src/transports/index.ts +3 -3
- package/src/transports/pino.ts +99 -0
- package/src/transports/winston.ts +49 -0
- package/dist/transports/console.d.ts +0 -21
- package/dist/transports/console.d.ts.map +0 -1
- package/dist/transports/console.js +0 -119
- package/dist/transports/console.js.map +0 -1
- package/src/transports/console.ts +0 -147
package/README.md
ADDED
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
# @abbacchio/transport
|
|
2
|
+
|
|
3
|
+
Node.js log transports for sending logs to [Abbacchio](https://github.com/pekonchan/pino-live) - a real-time log viewer dashboard.
|
|
4
|
+
|
|
5
|
+
Supports **Pino**, **Winston**, **Bunyan**, and **Console**.
|
|
6
|
+
|
|
7
|
+
## Installation
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
npm install @abbacchio/transport
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Usage
|
|
14
|
+
|
|
15
|
+
### Pino
|
|
16
|
+
|
|
17
|
+
```typescript
|
|
18
|
+
import pino from "pino";
|
|
19
|
+
|
|
20
|
+
const logger = pino({
|
|
21
|
+
transport: {
|
|
22
|
+
targets: [
|
|
23
|
+
{ target: "pino-pretty" },
|
|
24
|
+
{
|
|
25
|
+
target: "@abbacchio/transport/transports/pino",
|
|
26
|
+
options: {
|
|
27
|
+
url: "http://localhost:4000/api/logs",
|
|
28
|
+
channel: "my-app",
|
|
29
|
+
namespace: "auth-service",
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
},
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
logger.info({ user: "john" }, "User logged in");
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### Winston
|
|
40
|
+
|
|
41
|
+
```typescript
|
|
42
|
+
import winston from "winston";
|
|
43
|
+
import { winstonTransport } from "@abbacchio/transport/transports/winston";
|
|
44
|
+
|
|
45
|
+
const logger = winston.createLogger({
|
|
46
|
+
transports: [
|
|
47
|
+
new winston.transports.Console(),
|
|
48
|
+
winstonTransport({
|
|
49
|
+
url: "http://localhost:4000/api/logs",
|
|
50
|
+
channel: "my-app",
|
|
51
|
+
}),
|
|
52
|
+
],
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
logger.info("User logged in", { user: "john" });
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### Bunyan
|
|
59
|
+
|
|
60
|
+
```typescript
|
|
61
|
+
import bunyan from "bunyan";
|
|
62
|
+
import { bunyanStream } from "@abbacchio/transport/transports/bunyan";
|
|
63
|
+
|
|
64
|
+
const logger = bunyan.createLogger({
|
|
65
|
+
name: "myapp",
|
|
66
|
+
streams: [
|
|
67
|
+
{ stream: process.stdout },
|
|
68
|
+
bunyanStream({
|
|
69
|
+
url: "http://localhost:4000/api/logs",
|
|
70
|
+
channel: "my-app",
|
|
71
|
+
}),
|
|
72
|
+
],
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
logger.info({ user: "john" }, "User logged in");
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
### Dynamic Control (Pino)
|
|
80
|
+
|
|
81
|
+
Use `createPinoStream` for runtime control over channel, namespace, and enabled state:
|
|
82
|
+
|
|
83
|
+
```typescript
|
|
84
|
+
import pino from "pino";
|
|
85
|
+
import { createPinoStream } from "@abbacchio/transport/transports/pino";
|
|
86
|
+
|
|
87
|
+
const stream = createPinoStream({
|
|
88
|
+
url: "http://localhost:4000/api/logs",
|
|
89
|
+
channel: "my-app",
|
|
90
|
+
namespace: "api",
|
|
91
|
+
enabled: process.env.ABBACCHIO_ENABLED === "true",
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
const logger = pino(stream);
|
|
95
|
+
|
|
96
|
+
// Toggle at runtime
|
|
97
|
+
stream.disable(); // stop sending logs
|
|
98
|
+
stream.enable(); // resume sending logs
|
|
99
|
+
|
|
100
|
+
// Change namespace dynamically
|
|
101
|
+
stream.setNamespace("worker");
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
## Options
|
|
105
|
+
|
|
106
|
+
| Option | Type | Default | Description |
|
|
107
|
+
| ----------- | ------- | -------------------------------- | ---------------------------------------------- |
|
|
108
|
+
| `url` | string | `http://localhost:4000/api/logs` | Abbacchio server URL |
|
|
109
|
+
| `channel` | string | `default` | Channel name for multi-app support |
|
|
110
|
+
| `namespace` | string | - | Default namespace (overridden by per-log values)|
|
|
111
|
+
| `enabled` | boolean | `true` | Whether to send logs to the server |
|
|
112
|
+
| `secretKey` | string | - | Encryption key (enables E2E encryption) |
|
|
113
|
+
| `batchSize` | number | `10` | Send batch when this many logs accumulate |
|
|
114
|
+
| `interval` | number | `1000` | Send batch after this many ms |
|
|
115
|
+
| `headers` | object | `{}` | Additional HTTP headers |
|
|
116
|
+
|
|
117
|
+
### Namespace
|
|
118
|
+
|
|
119
|
+
The `namespace` option sets a default namespace for all logs. Per-log `namespace` or `name` fields (e.g. from Pino child loggers) take precedence:
|
|
120
|
+
|
|
121
|
+
```typescript
|
|
122
|
+
const logger = pino({
|
|
123
|
+
transport: {
|
|
124
|
+
target: "@abbacchio/transport/transports/pino",
|
|
125
|
+
options: { namespace: "api" },
|
|
126
|
+
},
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
logger.info("hello"); // namespace = "api"
|
|
130
|
+
logger.child({ name: "db" }).info("query"); // namespace = "db" (overrides)
|
|
131
|
+
```
|
|
132
|
+
|
|
133
|
+
### Enabled Toggle
|
|
134
|
+
|
|
135
|
+
Set `enabled: false` to prevent logs from being sent to the server. Logs are silently dropped (not buffered). All transports expose `enable()`, `disable()`, and `isEnabled()` methods for runtime control.
|
|
136
|
+
|
|
137
|
+
## End-to-End Encryption
|
|
138
|
+
|
|
139
|
+
Add `secretKey` to encrypt logs before sending:
|
|
140
|
+
|
|
141
|
+
```typescript
|
|
142
|
+
{
|
|
143
|
+
target: "@abbacchio/transport/transports/pino",
|
|
144
|
+
options: {
|
|
145
|
+
url: "http://localhost:4000/api/logs",
|
|
146
|
+
channel: "my-app",
|
|
147
|
+
secretKey: process.env.LOG_SECRET_KEY,
|
|
148
|
+
},
|
|
149
|
+
}
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
## License
|
|
153
|
+
|
|
154
|
+
MIT
|
package/dist/client.d.ts
CHANGED
|
@@ -5,12 +5,16 @@ export interface AbbacchioClientOptions {
|
|
|
5
5
|
secretKey?: string;
|
|
6
6
|
/** Channel/app name for multi-app support. Defaults to 'default' */
|
|
7
7
|
channel?: string;
|
|
8
|
+
/** Default namespace for all logs. Per-log namespace/name fields take precedence */
|
|
9
|
+
namespace?: string;
|
|
8
10
|
/** Number of logs to batch before sending. Defaults to 10 */
|
|
9
11
|
batchSize?: number;
|
|
10
12
|
/** Interval in ms between flushes. Defaults to 1000 */
|
|
11
13
|
interval?: number;
|
|
12
14
|
/** Additional headers to send with requests */
|
|
13
15
|
headers?: Record<string, string>;
|
|
16
|
+
/** Whether to send logs to the server. Defaults to true */
|
|
17
|
+
enabled?: boolean;
|
|
14
18
|
}
|
|
15
19
|
/**
|
|
16
20
|
* Shared HTTP client for all Abbacchio transports.
|
|
@@ -20,14 +24,44 @@ export declare class AbbacchioClient {
|
|
|
20
24
|
private url;
|
|
21
25
|
private secretKey?;
|
|
22
26
|
private channel?;
|
|
27
|
+
private namespace?;
|
|
23
28
|
private batchSize;
|
|
24
29
|
private interval;
|
|
25
30
|
private headers;
|
|
31
|
+
private enabled;
|
|
26
32
|
private buffer;
|
|
27
33
|
private timer;
|
|
28
34
|
constructor(options?: AbbacchioClientOptions);
|
|
29
35
|
/**
|
|
30
|
-
*
|
|
36
|
+
* Change the channel dynamically after initialization
|
|
37
|
+
*/
|
|
38
|
+
setChannel(channel: string | undefined): void;
|
|
39
|
+
/**
|
|
40
|
+
* Get the current channel
|
|
41
|
+
*/
|
|
42
|
+
getChannel(): string | undefined;
|
|
43
|
+
/**
|
|
44
|
+
* Change the namespace dynamically after initialization
|
|
45
|
+
*/
|
|
46
|
+
setNamespace(namespace: string | undefined): void;
|
|
47
|
+
/**
|
|
48
|
+
* Get the current namespace
|
|
49
|
+
*/
|
|
50
|
+
getNamespace(): string | undefined;
|
|
51
|
+
/**
|
|
52
|
+
* Enable sending logs to the server
|
|
53
|
+
*/
|
|
54
|
+
enable(): void;
|
|
55
|
+
/**
|
|
56
|
+
* Disable sending logs to the server. Logs will be silently dropped.
|
|
57
|
+
*/
|
|
58
|
+
disable(): void;
|
|
59
|
+
/**
|
|
60
|
+
* Check if the client is currently enabled
|
|
61
|
+
*/
|
|
62
|
+
isEnabled(): boolean;
|
|
63
|
+
/**
|
|
64
|
+
* Process a log entry: inject default namespace, then encrypt if needed
|
|
31
65
|
*/
|
|
32
66
|
private processLog;
|
|
33
67
|
/**
|
package/dist/client.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,sBAAsB;IACrC,0BAA0B;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,oFAAoF;IACpF,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oEAAoE;IACpE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,6DAA6D;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uDAAuD;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,sBAAsB;IACrC,0BAA0B;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,oFAAoF;IACpF,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oEAAoE;IACpE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oFAAoF;IACpF,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6DAA6D;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uDAAuD;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,2DAA2D;IAC3D,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED;;;GAGG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,GAAG,CAAS;IACpB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,OAAO,CAAC,CAAS;IACzB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,OAAO,CAAyB;IACxC,OAAO,CAAC,OAAO,CAAU;IAEzB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,KAAK,CAA8C;gBAE/C,OAAO,GAAE,sBAA2B;IAWhD;;OAEG;IACH,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAI7C;;OAEG;IACH,UAAU,IAAI,MAAM,GAAG,SAAS;IAIhC;;OAEG;IACH,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAIjD;;OAEG;IACH,YAAY,IAAI,MAAM,GAAG,SAAS;IAIlC;;OAEG;IACH,MAAM,IAAI,IAAI;IAId;;OAEG;IACH,OAAO,IAAI,IAAI;IAIf;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,OAAO,CAAC,UAAU;IAgBlB;;OAEG;IACH,GAAG,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAWvB;;OAEG;IACH,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAa/B;;OAEG;IACG,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAM1C;;OAEG;IACH,OAAO,CAAC,YAAY;IAQpB;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5B;;OAEG;YACW,YAAY;IAiB1B;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAO7B;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,OAAO,CAAC,EAAE,sBAAsB,GAAG,eAAe,CAE9E"}
|
package/dist/client.js
CHANGED
|
@@ -7,32 +7,87 @@ export class AbbacchioClient {
|
|
|
7
7
|
url;
|
|
8
8
|
secretKey;
|
|
9
9
|
channel;
|
|
10
|
+
namespace;
|
|
10
11
|
batchSize;
|
|
11
12
|
interval;
|
|
12
13
|
headers;
|
|
14
|
+
enabled;
|
|
13
15
|
buffer = [];
|
|
14
16
|
timer = null;
|
|
15
17
|
constructor(options = {}) {
|
|
16
18
|
this.url = options.url || "http://localhost:4000/api/logs";
|
|
17
19
|
this.secretKey = options.secretKey;
|
|
18
20
|
this.channel = options.channel;
|
|
21
|
+
this.namespace = options.namespace;
|
|
19
22
|
this.batchSize = options.batchSize || 10;
|
|
20
23
|
this.interval = options.interval || 1000;
|
|
21
24
|
this.headers = options.headers || {};
|
|
25
|
+
this.enabled = options.enabled ?? true;
|
|
22
26
|
}
|
|
23
27
|
/**
|
|
24
|
-
*
|
|
28
|
+
* Change the channel dynamically after initialization
|
|
29
|
+
*/
|
|
30
|
+
setChannel(channel) {
|
|
31
|
+
this.channel = channel;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Get the current channel
|
|
35
|
+
*/
|
|
36
|
+
getChannel() {
|
|
37
|
+
return this.channel;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Change the namespace dynamically after initialization
|
|
41
|
+
*/
|
|
42
|
+
setNamespace(namespace) {
|
|
43
|
+
this.namespace = namespace;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Get the current namespace
|
|
47
|
+
*/
|
|
48
|
+
getNamespace() {
|
|
49
|
+
return this.namespace;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Enable sending logs to the server
|
|
53
|
+
*/
|
|
54
|
+
enable() {
|
|
55
|
+
this.enabled = true;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Disable sending logs to the server. Logs will be silently dropped.
|
|
59
|
+
*/
|
|
60
|
+
disable() {
|
|
61
|
+
this.enabled = false;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Check if the client is currently enabled
|
|
65
|
+
*/
|
|
66
|
+
isEnabled() {
|
|
67
|
+
return this.enabled;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Process a log entry: inject default namespace, then encrypt if needed
|
|
25
71
|
*/
|
|
26
72
|
processLog(log) {
|
|
73
|
+
let processed = log;
|
|
74
|
+
if (this.namespace && typeof processed === 'object' && processed !== null) {
|
|
75
|
+
const obj = processed;
|
|
76
|
+
if (!obj.namespace && !obj.name) {
|
|
77
|
+
processed = { ...obj, namespace: this.namespace };
|
|
78
|
+
}
|
|
79
|
+
}
|
|
27
80
|
if (this.secretKey) {
|
|
28
|
-
return { encrypted: encrypt(JSON.stringify(
|
|
81
|
+
return { encrypted: encrypt(JSON.stringify(processed), this.secretKey) };
|
|
29
82
|
}
|
|
30
|
-
return
|
|
83
|
+
return processed;
|
|
31
84
|
}
|
|
32
85
|
/**
|
|
33
86
|
* Add a log to the buffer and trigger send if needed
|
|
34
87
|
*/
|
|
35
88
|
add(log) {
|
|
89
|
+
if (!this.enabled)
|
|
90
|
+
return;
|
|
36
91
|
this.buffer.push(this.processLog(log));
|
|
37
92
|
if (this.buffer.length >= this.batchSize) {
|
|
38
93
|
this.flush();
|
|
@@ -45,6 +100,8 @@ export class AbbacchioClient {
|
|
|
45
100
|
* Add multiple logs at once
|
|
46
101
|
*/
|
|
47
102
|
addBatch(logs) {
|
|
103
|
+
if (!this.enabled)
|
|
104
|
+
return;
|
|
48
105
|
for (const log of logs) {
|
|
49
106
|
this.buffer.push(this.processLog(log));
|
|
50
107
|
}
|
|
@@ -59,6 +116,8 @@ export class AbbacchioClient {
|
|
|
59
116
|
* Send logs immediately without batching
|
|
60
117
|
*/
|
|
61
118
|
async send(logs) {
|
|
119
|
+
if (!this.enabled)
|
|
120
|
+
return;
|
|
62
121
|
const processedLogs = logs.map(log => this.processLog(log));
|
|
63
122
|
await this.sendToServer(processedLogs);
|
|
64
123
|
}
|
package/dist/client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -7,6 +7,6 @@ export { winstonTransport, AbbacchioWinstonTransport } from "./transports/winsto
|
|
|
7
7
|
export type { WinstonTransportOptions } from "./transports/winston.js";
|
|
8
8
|
export { bunyanStream, AbbacchioBunyanStream } from "./transports/bunyan.js";
|
|
9
9
|
export type { BunyanStreamOptions } from "./transports/bunyan.js";
|
|
10
|
-
export {
|
|
11
|
-
export type {
|
|
10
|
+
export { createPinoStream } from "./transports/pino.js";
|
|
11
|
+
export type { AbbacchioPinoStream } from "./transports/pino.js";
|
|
12
12
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC5D,YAAY,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAGrF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChE,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AACtF,YAAY,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAEvE,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,YAAY,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC5D,YAAY,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAGrF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChE,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AACtF,YAAY,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAEvE,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,YAAY,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,YAAY,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -6,5 +6,5 @@ export { generateKey, encrypt, decrypt, encryptLog, decryptLog } from "./encrypt
|
|
|
6
6
|
export { default as pinoTransport } from "./transports/pino.js";
|
|
7
7
|
export { winstonTransport, AbbacchioWinstonTransport } from "./transports/winston.js";
|
|
8
8
|
export { bunyanStream, AbbacchioBunyanStream } from "./transports/bunyan.js";
|
|
9
|
-
export {
|
|
9
|
+
export { createPinoStream } from "./transports/pino.js";
|
|
10
10
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAG5D,uBAAuB;AACvB,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErF,uCAAuC;AACvC,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGhE,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAGtF,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAG7E,OAAO,EAAE,gBAAgB,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAG5D,uBAAuB;AACvB,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErF,uCAAuC;AACvC,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGhE,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAGtF,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAG7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -40,6 +40,34 @@ export declare class AbbacchioBunyanStream extends Writable {
|
|
|
40
40
|
* Transform Bunyan log format to a normalized format
|
|
41
41
|
*/
|
|
42
42
|
private transformLog;
|
|
43
|
+
/**
|
|
44
|
+
* Change the channel dynamically
|
|
45
|
+
*/
|
|
46
|
+
setChannel(channel: string | undefined): void;
|
|
47
|
+
/**
|
|
48
|
+
* Get the current channel
|
|
49
|
+
*/
|
|
50
|
+
getChannel(): string | undefined;
|
|
51
|
+
/**
|
|
52
|
+
* Change the namespace dynamically
|
|
53
|
+
*/
|
|
54
|
+
setNamespace(namespace: string | undefined): void;
|
|
55
|
+
/**
|
|
56
|
+
* Get the current namespace
|
|
57
|
+
*/
|
|
58
|
+
getNamespace(): string | undefined;
|
|
59
|
+
/**
|
|
60
|
+
* Enable sending logs to the server
|
|
61
|
+
*/
|
|
62
|
+
enable(): void;
|
|
63
|
+
/**
|
|
64
|
+
* Disable sending logs to the server
|
|
65
|
+
*/
|
|
66
|
+
disable(): void;
|
|
67
|
+
/**
|
|
68
|
+
* Check if the client is currently enabled
|
|
69
|
+
*/
|
|
70
|
+
isEnabled(): boolean;
|
|
43
71
|
/**
|
|
44
72
|
* Close the stream
|
|
45
73
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bunyan.d.ts","sourceRoot":"","sources":["../../src/transports/bunyan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAmB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAE5E,MAAM,WAAW,mBAAoB,SAAQ,sBAAsB;IACjE,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,qBAAsB,SAAQ,QAAQ;IACjD,OAAO,CAAC,MAAM,CAAkB;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;gBAEnB,IAAI,GAAE,mBAAwB;IAM1C;;OAEG;IACH,MAAM,CACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,SAAS,EAAE,cAAc,EACzB,QAAQ,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,KAAK,IAAI,GACvC,IAAI;IAWP;;OAEG;IACH,OAAO,CAAC,YAAY;IAcpB;;OAEG;IACH,MAAM,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,KAAK,IAAI,GAAG,IAAI;CAGvD;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,CAAC,EAAE,mBAAmB,GAAG;IAAE,MAAM,EAAE,qBAAqB,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAAC,IAAI,EAAE,KAAK,CAAA;CAAE,CAOhI;AAED,eAAe,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"bunyan.d.ts","sourceRoot":"","sources":["../../src/transports/bunyan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAmB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAE5E,MAAM,WAAW,mBAAoB,SAAQ,sBAAsB;IACjE,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,qBAAsB,SAAQ,QAAQ;IACjD,OAAO,CAAC,MAAM,CAAkB;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;gBAEnB,IAAI,GAAE,mBAAwB;IAM1C;;OAEG;IACH,MAAM,CACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,SAAS,EAAE,cAAc,EACzB,QAAQ,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,KAAK,IAAI,GACvC,IAAI;IAWP;;OAEG;IACH,OAAO,CAAC,YAAY;IAcpB;;OAEG;IACH,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAI7C;;OAEG;IACH,UAAU,IAAI,MAAM,GAAG,SAAS;IAIhC;;OAEG;IACH,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAIjD;;OAEG;IACH,YAAY,IAAI,MAAM,GAAG,SAAS;IAIlC;;OAEG;IACH,MAAM,IAAI,IAAI;IAId;;OAEG;IACH,OAAO,IAAI,IAAI;IAIf;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,MAAM,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,KAAK,IAAI,GAAG,IAAI;CAGvD;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,CAAC,EAAE,mBAAmB,GAAG;IAAE,MAAM,EAAE,qBAAqB,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAAC,IAAI,EAAE,KAAK,CAAA;CAAE,CAOhI;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -61,6 +61,48 @@ export class AbbacchioBunyanStream extends Writable {
|
|
|
61
61
|
...rest,
|
|
62
62
|
};
|
|
63
63
|
}
|
|
64
|
+
/**
|
|
65
|
+
* Change the channel dynamically
|
|
66
|
+
*/
|
|
67
|
+
setChannel(channel) {
|
|
68
|
+
this.client.setChannel(channel);
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Get the current channel
|
|
72
|
+
*/
|
|
73
|
+
getChannel() {
|
|
74
|
+
return this.client.getChannel();
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Change the namespace dynamically
|
|
78
|
+
*/
|
|
79
|
+
setNamespace(namespace) {
|
|
80
|
+
this.client.setNamespace(namespace);
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Get the current namespace
|
|
84
|
+
*/
|
|
85
|
+
getNamespace() {
|
|
86
|
+
return this.client.getNamespace();
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Enable sending logs to the server
|
|
90
|
+
*/
|
|
91
|
+
enable() {
|
|
92
|
+
this.client.enable();
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Disable sending logs to the server
|
|
96
|
+
*/
|
|
97
|
+
disable() {
|
|
98
|
+
this.client.disable();
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Check if the client is currently enabled
|
|
102
|
+
*/
|
|
103
|
+
isEnabled() {
|
|
104
|
+
return this.client.isEnabled();
|
|
105
|
+
}
|
|
64
106
|
/**
|
|
65
107
|
* Close the stream
|
|
66
108
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bunyan.js","sourceRoot":"","sources":["../../src/transports/bunyan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,eAAe,EAA+B,MAAM,cAAc,CAAC;AAO5E;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,OAAO,qBAAsB,SAAQ,QAAQ;IACzC,MAAM,CAAkB;IACzB,KAAK,CAAmB;IAE/B,YAAY,OAA4B,EAAE;QACxC,KAAK,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5B,IAAI,CAAC,MAAM,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,MAAM,CACJ,KAA8B,EAC9B,SAAyB,EACzB,QAAwC;QAExC,IAAI,CAAC;YACH,8CAA8C;YAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACrB,QAAQ,EAAE,CAAC;QACb,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CAAC,GAAY,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,MAA+B;QAClD,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QAErE,OAAO;YACL,KAAK,EAAE,KAAe;YACtB,GAAG;YACH,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAc,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC5D,IAAI;YACJ,QAAQ;YACR,GAAG;YACH,GAAG,IAAI;SACR,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,QAAwC;QAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC7D,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,IAA0B;IACrD,MAAM,MAAM,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,CAAC;IAC/C,OAAO;QACL,MAAM;QACN,KAAK,EAAE,IAAI,EAAE,KAAK;QAClB,IAAI,EAAE,KAAK;KACZ,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"bunyan.js","sourceRoot":"","sources":["../../src/transports/bunyan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,eAAe,EAA+B,MAAM,cAAc,CAAC;AAO5E;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,OAAO,qBAAsB,SAAQ,QAAQ;IACzC,MAAM,CAAkB;IACzB,KAAK,CAAmB;IAE/B,YAAY,OAA4B,EAAE;QACxC,KAAK,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5B,IAAI,CAAC,MAAM,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,MAAM,CACJ,KAA8B,EAC9B,SAAyB,EACzB,QAAwC;QAExC,IAAI,CAAC;YACH,8CAA8C;YAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACrB,QAAQ,EAAE,CAAC;QACb,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CAAC,GAAY,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,MAA+B;QAClD,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QAErE,OAAO;YACL,KAAK,EAAE,KAAe;YACtB,GAAG;YACH,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAc,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC5D,IAAI;YACJ,QAAQ;YACR,GAAG;YACH,GAAG,IAAI;SACR,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,OAA2B;QACpC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,UAAU;QACR,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,SAA6B;QACxC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,QAAwC;QAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC7D,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,IAA0B;IACrD,MAAM,MAAM,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,CAAC;IAC/C,OAAO;QACL,MAAM;QACN,KAAK,EAAE,IAAI,EAAE,KAAK;QAClB,IAAI,EAAE,KAAK;KACZ,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -4,6 +4,6 @@ export { winstonTransport, AbbacchioWinstonTransport } from "./winston.js";
|
|
|
4
4
|
export type { WinstonTransportOptions } from "./winston.js";
|
|
5
5
|
export { bunyanStream, AbbacchioBunyanStream } from "./bunyan.js";
|
|
6
6
|
export type { BunyanStreamOptions } from "./bunyan.js";
|
|
7
|
-
export {
|
|
8
|
-
export type {
|
|
7
|
+
export { createPinoStream } from "./pino.js";
|
|
8
|
+
export type { AbbacchioPinoStream } from "./pino.js";
|
|
9
9
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/transports/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC;AACrD,YAAY,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAGtD,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AAC3E,YAAY,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAG5D,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAClE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAGvD,OAAO,EAAE,gBAAgB,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/transports/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC;AACrD,YAAY,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAGtD,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AAC3E,YAAY,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAG5D,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAClE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAGvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,YAAY,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC"}
|
package/dist/transports/index.js
CHANGED
|
@@ -4,6 +4,6 @@ export { default as pinoTransport } from "./pino.js";
|
|
|
4
4
|
export { winstonTransport, AbbacchioWinstonTransport } from "./winston.js";
|
|
5
5
|
// Bunyan stream
|
|
6
6
|
export { bunyanStream, AbbacchioBunyanStream } from "./bunyan.js";
|
|
7
|
-
//
|
|
8
|
-
export {
|
|
7
|
+
// Pino stream with dynamic channel support
|
|
8
|
+
export { createPinoStream } from "./pino.js";
|
|
9
9
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/transports/index.ts"],"names":[],"mappings":"AAAA,iBAAiB;AACjB,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC;AAGrD,oBAAoB;AACpB,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AAG3E,gBAAgB;AAChB,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAGlE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/transports/index.ts"],"names":[],"mappings":"AAAA,iBAAiB;AACjB,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC;AAGrD,oBAAoB;AACpB,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AAG3E,gBAAgB;AAChB,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAGlE,2CAA2C;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -1,7 +1,26 @@
|
|
|
1
1
|
import build from "pino-abstract-transport";
|
|
2
2
|
import { type AbbacchioClientOptions } from "../client.js";
|
|
3
|
+
import { Transform } from "stream";
|
|
3
4
|
export interface PinoTransportOptions extends AbbacchioClientOptions {
|
|
4
5
|
}
|
|
6
|
+
export interface AbbacchioPinoStream extends Transform {
|
|
7
|
+
/** Change the channel dynamically */
|
|
8
|
+
setChannel(channel: string | undefined): void;
|
|
9
|
+
/** Get the current channel */
|
|
10
|
+
getChannel(): string | undefined;
|
|
11
|
+
/** Change the namespace dynamically */
|
|
12
|
+
setNamespace(namespace: string | undefined): void;
|
|
13
|
+
/** Get the current namespace */
|
|
14
|
+
getNamespace(): string | undefined;
|
|
15
|
+
/** Enable sending logs to the server */
|
|
16
|
+
enable(): void;
|
|
17
|
+
/** Disable sending logs to the server */
|
|
18
|
+
disable(): void;
|
|
19
|
+
/** Check if the client is currently enabled */
|
|
20
|
+
isEnabled(): boolean;
|
|
21
|
+
/** Flush pending logs and close the client */
|
|
22
|
+
close(): Promise<void>;
|
|
23
|
+
}
|
|
5
24
|
/**
|
|
6
25
|
* Pino transport for Abbacchio.
|
|
7
26
|
*
|
|
@@ -15,6 +34,7 @@ export interface PinoTransportOptions extends AbbacchioClientOptions {
|
|
|
15
34
|
* options: {
|
|
16
35
|
* url: "http://localhost:4000/api/logs",
|
|
17
36
|
* channel: "my-app",
|
|
37
|
+
* namespace: "auth-service",
|
|
18
38
|
* secretKey: "optional-encryption-key",
|
|
19
39
|
* },
|
|
20
40
|
* },
|
|
@@ -23,9 +43,34 @@ export interface PinoTransportOptions extends AbbacchioClientOptions {
|
|
|
23
43
|
* logger.info("Hello from Pino!");
|
|
24
44
|
* ```
|
|
25
45
|
*/
|
|
26
|
-
export default function pinoTransport(opts?: PinoTransportOptions): Promise<
|
|
46
|
+
export default function pinoTransport(opts?: PinoTransportOptions): Promise<Transform & build.OnUnknown>;
|
|
27
47
|
/**
|
|
28
48
|
* Named export for programmatic usage
|
|
29
49
|
*/
|
|
30
50
|
export { pinoTransport };
|
|
51
|
+
/**
|
|
52
|
+
* Create a Pino destination stream with direct access to the client.
|
|
53
|
+
* Use this when you need to change the channel dynamically.
|
|
54
|
+
*
|
|
55
|
+
* @example
|
|
56
|
+
* ```typescript
|
|
57
|
+
* import pino from "pino";
|
|
58
|
+
* import { createPinoStream } from "@abbacchio/transport/transports/pino";
|
|
59
|
+
*
|
|
60
|
+
* const stream = createPinoStream({
|
|
61
|
+
* url: "http://localhost:4000/api/logs",
|
|
62
|
+
* channel: "initial-channel",
|
|
63
|
+
* });
|
|
64
|
+
*
|
|
65
|
+
* const logger = pino(stream);
|
|
66
|
+
*
|
|
67
|
+
* logger.info("Log to initial channel");
|
|
68
|
+
*
|
|
69
|
+
* // Change channel dynamically
|
|
70
|
+
* stream.setChannel("new-channel");
|
|
71
|
+
*
|
|
72
|
+
* logger.info("Log to new channel");
|
|
73
|
+
* ```
|
|
74
|
+
*/
|
|
75
|
+
export declare function createPinoStream(opts?: PinoTransportOptions): AbbacchioPinoStream;
|
|
31
76
|
//# sourceMappingURL=pino.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pino.d.ts","sourceRoot":"","sources":["../../src/transports/pino.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,yBAAyB,CAAC;AAC5C,OAAO,EAAmB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"pino.d.ts","sourceRoot":"","sources":["../../src/transports/pino.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,yBAAyB,CAAC;AAC5C,OAAO,EAAmB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAEnC,MAAM,WAAW,oBAAqB,SAAQ,sBAAsB;CAAG;AAEvE,MAAM,WAAW,mBAAoB,SAAQ,SAAS;IACpD,qCAAqC;IACrC,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IAC9C,8BAA8B;IAC9B,UAAU,IAAI,MAAM,GAAG,SAAS,CAAC;IACjC,uCAAuC;IACvC,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IAClD,gCAAgC;IAChC,YAAY,IAAI,MAAM,GAAG,SAAS,CAAC;IACnC,wCAAwC;IACxC,MAAM,IAAI,IAAI,CAAC;IACf,yCAAyC;IACzC,OAAO,IAAI,IAAI,CAAC;IAChB,+CAA+C;IAC/C,SAAS,IAAI,OAAO,CAAC;IACrB,8CAA8C;IAC9C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACxB;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAA8B,aAAa,CAAC,IAAI,GAAE,oBAAyB,wCAiB1E;AAED;;GAEG;AACH,OAAO,EAAE,aAAa,EAAE,CAAC;AAEzB;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,GAAE,oBAAyB,GAAG,mBAAmB,CAoDrF"}
|