@visulima/pail 4.0.0-alpha.11 → 4.0.0-alpha.13
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/CHANGELOG.md +33 -0
- package/LICENSE.md +131 -900
- package/dist/error.d.ts +95 -96
- package/dist/error.js +5 -76
- package/dist/index.browser.d.ts +557 -47
- package/dist/index.browser.js +19 -1499
- package/dist/index.server.d.ts +722 -61
- package/dist/index.server.js +31 -2803
- package/dist/middleware/elysia.d.ts +65 -63
- package/dist/middleware/elysia.js +1 -70
- package/dist/middleware/express.d.ts +73 -71
- package/dist/middleware/express.js +1 -29
- package/dist/middleware/fastify.d.ts +69 -67
- package/dist/middleware/fastify.js +1 -46
- package/dist/middleware/hono.d.ts +74 -72
- package/dist/middleware/hono.js +1 -33
- package/dist/middleware/next/handler.d.ts +101 -34
- package/dist/middleware/next/handler.js +1 -53
- package/dist/middleware/sveltekit.d.ts +100 -98
- package/dist/middleware/sveltekit.js +1 -43
- package/dist/object-tree.d.ts +67 -70
- package/dist/object-tree.js +2 -89
- package/dist/packem_shared/AbstractJsonReporter-BawNFYxI.js +1 -0
- package/dist/packem_shared/AbstractJsonReporter-Dt5-5x2R.js +1 -0
- package/dist/packem_shared/JsonReporter-15ln04rX.js +2 -0
- package/dist/packem_shared/JsonReporter-CerNvhg-.js +1 -0
- package/dist/packem_shared/PrettyReporter-Br5njEEy.js +5 -0
- package/dist/packem_shared/PrettyReporter-CgXnwIip.js +44 -0
- package/dist/packem_shared/abstract-json-reporter.d-Bz3lZEDi.d.ts +61 -0
- package/dist/packem_shared/abstract-pretty-reporter-BiHgKxG_.js +33 -0
- package/dist/packem_shared/constants-DKfCaSUR.js +1 -0
- package/dist/packem_shared/constants-ep2nsfdy.js +1 -0
- package/dist/packem_shared/create-middleware-logger.d-DeNLii5l.d.ts +47 -0
- package/dist/packem_shared/createPailError-53jAfQ-T.js +5 -0
- package/dist/packem_shared/headers-S8WyX-2m.js +1 -0
- package/dist/packem_shared/index-Bzp4LnJ5.js +1 -0
- package/dist/packem_shared/pailMiddleware-CWOJRmJq.js +1 -0
- package/dist/packem_shared/storage-DHM1EP2P.js +1 -0
- package/dist/packem_shared/types.d-ByY2ZuYG.d.ts +246 -0
- package/dist/packem_shared/types.d-C51XNfQz.d.ts +194 -0
- package/dist/packem_shared/types.d-CM5ie2qm.d.ts +236 -0
- package/dist/packem_shared/useLogger-qyZrjy4D.js +1 -0
- package/dist/packem_shared/wide-event.d-Ke44zirU.d.ts +704 -0
- package/dist/packem_shared/write-console-log-based-on-level-DfD64owL.js +1 -0
- package/dist/packem_shared/write-stream-Dd4_PTcm.js +1 -0
- package/dist/processor/caller/caller-processor.d.ts +49 -47
- package/dist/processor/caller/caller-processor.js +1 -59
- package/dist/processor/environment-processor.d.ts +113 -113
- package/dist/processor/environment-processor.js +1 -89
- package/dist/processor/message-formatter-processor.d.ts +51 -49
- package/dist/processor/message-formatter-processor.js +1 -715
- package/dist/processor/opentelemetry-processor.d.ts +69 -66
- package/dist/processor/opentelemetry-processor.js +1 -52
- package/dist/processor/redact-processor.d.ts +60 -41
- package/dist/processor/redact-processor.js +1 -31
- package/dist/processor/sampling-processor.d.ts +102 -101
- package/dist/processor/sampling-processor.js +1 -59
- package/dist/reporter/file/json-file-reporter.d.ts +91 -42
- package/dist/reporter/file/json-file-reporter.js +2 -136
- package/dist/reporter/http/abstract-http-reporter.d.ts +213 -211
- package/dist/reporter/http/abstract-http-reporter.js +2 -432
- package/dist/reporter/http/http-reporter.d.ts +40 -36
- package/dist/reporter/http/http-reporter.edge-light.d.ts +430 -38
- package/dist/reporter/http/http-reporter.edge-light.js +2 -728
- package/dist/reporter/http/http-reporter.js +1 -13
- package/dist/reporter/json/index.browser.d.ts +99 -3
- package/dist/reporter/json/index.browser.js +1 -2
- package/dist/reporter/json/index.d.ts +51 -3
- package/dist/reporter/json/index.js +1 -2
- package/dist/reporter/pretty/index.browser.d.ts +106 -2
- package/dist/reporter/pretty/index.browser.js +1 -1
- package/dist/reporter/pretty/index.d.ts +186 -2
- package/dist/reporter/pretty/index.js +1 -1
- package/dist/reporter/simple/simple-reporter.server.d.ts +168 -18
- package/dist/reporter/simple/simple-reporter.server.js +8 -182
- package/dist/wide-event.d.ts +5 -300
- package/dist/wide-event.js +1 -284
- package/package.json +29 -30
- package/dist/constants.d.ts +0 -37
- package/dist/middleware/next/middleware.d.ts +0 -59
- package/dist/middleware/next/storage.d.ts +0 -14
- package/dist/middleware/shared/create-middleware-logger.d.ts +0 -82
- package/dist/middleware/shared/headers.d.ts +0 -14
- package/dist/middleware/shared/routes.d.ts +0 -30
- package/dist/middleware/shared/storage.d.ts +0 -29
- package/dist/packem_shared/AbstractJsonReporter-BO8Calb4.js +0 -284
- package/dist/packem_shared/AbstractJsonReporter-nOj0Ft1F.js +0 -284
- package/dist/packem_shared/JsonReporter-CCmj7oYL.js +0 -28
- package/dist/packem_shared/JsonReporter-Ck2PIAEw.js +0 -58
- package/dist/packem_shared/PrettyReporter-BCvyNzXO.js +0 -2720
- package/dist/packem_shared/PrettyReporter-BtTr13Ha.js +0 -213
- package/dist/packem_shared/abstract-pretty-reporter-CXAKYCb8.js +0 -2635
- package/dist/packem_shared/constants-B1RjD_ps.js +0 -99
- package/dist/packem_shared/constants-omsTHUWB.js +0 -119
- package/dist/packem_shared/createPailError-B_sgL0nF.js +0 -76
- package/dist/packem_shared/headers-BxHWM6KI.js +0 -127
- package/dist/packem_shared/index-Bx3-C0j9.js +0 -658
- package/dist/packem_shared/pailMiddleware-Ci88geIF.js +0 -24
- package/dist/packem_shared/storage-D0vqz8OX.js +0 -36
- package/dist/packem_shared/useLogger-D0rU3lcX.js +0 -33
- package/dist/packem_shared/write-console-log-based-on-level-ree2lDPw.js +0 -15
- package/dist/packem_shared/write-stream-MDqyXmc_.js +0 -6
- package/dist/pail.browser.d.ts +0 -412
- package/dist/pail.server.d.ts +0 -158
- package/dist/processor/caller/get-caller-filename.d.ts +0 -23
- package/dist/reporter/file/utils/rotating-file-stream.d.ts +0 -48
- package/dist/reporter/http/utils/compression.d.ts +0 -7
- package/dist/reporter/http/utils/log-size-error.d.ts +0 -30
- package/dist/reporter/http/utils/retry.d.ts +0 -27
- package/dist/reporter/json/abstract-json-reporter.d.ts +0 -61
- package/dist/reporter/json/json-reporter.browser.d.ts +0 -40
- package/dist/reporter/json/json-reporter.server.d.ts +0 -50
- package/dist/reporter/pretty/abstract-pretty-reporter.d.ts +0 -83
- package/dist/reporter/pretty/pretty-reporter.browser.d.ts +0 -36
- package/dist/reporter/pretty/pretty-reporter.server.d.ts +0 -70
- package/dist/reporter/raw/raw-reporter.browser.d.ts +0 -5
- package/dist/reporter/raw/raw-reporter.server.d.ts +0 -13
- package/dist/reporter/utils/default-inspector-config.d.ts +0 -3
- package/dist/reporter/utils/format-label.d.ts +0 -3
- package/dist/types.d.ts +0 -241
- package/dist/utils/arrayify.d.ts +0 -2
- package/dist/utils/get-longest-badge.d.ts +0 -4
- package/dist/utils/get-longest-label.d.ts +0 -4
- package/dist/utils/merge-types.d.ts +0 -4
- package/dist/utils/stream/safe-stream-handler.d.ts +0 -21
- package/dist/utils/write-console-log-based-on-level.d.ts +0 -4
- package/dist/utils/write-stream.d.ts +0 -2
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { AnsiColors } from '@visulima/colorize';
|
|
2
|
+
import '@visulima/interactive-manager';
|
|
3
|
+
import { LiteralUnion, Primitive } from 'type-fest';
|
|
4
|
+
/**
|
|
5
|
+
* Global namespace for extending Pail's metadata interface.
|
|
6
|
+
*
|
|
7
|
+
* This global declaration allows other packages and applications to extend
|
|
8
|
+
* the Meta interface with custom properties by declaring additional properties
|
|
9
|
+
* in the VisulimaPail.CustomMeta interface.
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* declare global {
|
|
13
|
+
* namespace VisulimaPail {
|
|
14
|
+
* interface CustomMeta<L> {
|
|
15
|
+
* userId?: string;
|
|
16
|
+
* requestId?: string;
|
|
17
|
+
* }
|
|
18
|
+
* }
|
|
19
|
+
* }
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
declare global {
|
|
23
|
+
namespace VisulimaPail {
|
|
24
|
+
interface CustomMeta<L> {}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Metadata object containing all information about a log entry.
|
|
29
|
+
*
|
|
30
|
+
* This interface defines the structure of metadata that is passed to reporters
|
|
31
|
+
* and processors. It contains all the contextual information about a log message
|
|
32
|
+
* including the message itself, timing information, error details, and more.
|
|
33
|
+
* @template L - The log level type
|
|
34
|
+
*/
|
|
35
|
+
interface Meta<L> extends VisulimaPail.CustomMeta<L> {
|
|
36
|
+
badge: string | undefined;
|
|
37
|
+
context: any[] | undefined;
|
|
38
|
+
date: Date | string;
|
|
39
|
+
error: Error | undefined;
|
|
40
|
+
groups: string[];
|
|
41
|
+
label: string | undefined;
|
|
42
|
+
message: Primitive | ReadonlyArray<unknown> | Record<PropertyKey, unknown>;
|
|
43
|
+
prefix: string | undefined;
|
|
44
|
+
repeated?: number;
|
|
45
|
+
scope: string[] | undefined;
|
|
46
|
+
suffix: string | undefined;
|
|
47
|
+
traceError: Error | undefined;
|
|
48
|
+
type: {
|
|
49
|
+
level: ExtendedRfc5424LogLevels | L;
|
|
50
|
+
name: string;
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Extended RFC 5424 Log Levels.
|
|
55
|
+
*
|
|
56
|
+
* Standard syslog severity levels as defined in RFC 5424, plus additional
|
|
57
|
+
* levels commonly used in modern applications. Each level has a numeric
|
|
58
|
+
* priority where lower numbers indicate higher severity.
|
|
59
|
+
* @see https://datatracker.ietf.org/doc/html/rfc5424#section-6.2.1
|
|
60
|
+
*/
|
|
61
|
+
type ExtendedRfc5424LogLevels = "alert" | "critical" | "debug" | "emergency" | "error" | "informational" | "notice" | "trace" | "warning";
|
|
62
|
+
/**
|
|
63
|
+
* Default Log Types.
|
|
64
|
+
*
|
|
65
|
+
* Predefined semantic log types that provide meaningful categorization
|
|
66
|
+
* for different kinds of log messages. Each type has associated styling
|
|
67
|
+
* and log level configuration.
|
|
68
|
+
*/
|
|
69
|
+
type DefaultLogTypes = "alert" | "await" | "complete" | "critical" | "debug" | "emergency" | "error" | "info" | "log" | "notice" | "pending" | "start" | "stop" | "success" | "trace" | "wait" | "warn" | "warning" | "watch";
|
|
70
|
+
/**
|
|
71
|
+
* Logger Function Type.
|
|
72
|
+
*
|
|
73
|
+
* Represents a logging function that can accept either a structured Message object
|
|
74
|
+
* or multiple arguments in the traditional console.log style.
|
|
75
|
+
*/
|
|
76
|
+
interface LoggerFunction {
|
|
77
|
+
(message: Message): void;
|
|
78
|
+
(...message: any[]): void;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Logger Configuration.
|
|
82
|
+
*
|
|
83
|
+
* Configuration object that defines how a specific logger type should behave,
|
|
84
|
+
* including its visual appearance and log level.
|
|
85
|
+
* @template L - The log level type
|
|
86
|
+
*/
|
|
87
|
+
interface LoggerConfiguration<L extends string> {
|
|
88
|
+
badge?: string;
|
|
89
|
+
color?: AnsiColors;
|
|
90
|
+
label: string;
|
|
91
|
+
logLevel: LiteralUnion<ExtendedRfc5424LogLevels, L>;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Logger Types Configuration.
|
|
95
|
+
*
|
|
96
|
+
* A record mapping logger type names to their configurations.
|
|
97
|
+
* @template T - Custom logger type names
|
|
98
|
+
* @template L - Log level types
|
|
99
|
+
*/
|
|
100
|
+
type LoggerTypesConfig<T extends string, L extends string> = Record<T, Partial<LoggerConfiguration<L>>>;
|
|
101
|
+
/**
|
|
102
|
+
* Default Logger Types Configuration.
|
|
103
|
+
*
|
|
104
|
+
* A complete mapping of all default log types to their full configurations.
|
|
105
|
+
* @template L - Log level types
|
|
106
|
+
*/
|
|
107
|
+
type DefaultLoggerTypes<L extends string = string> = Record<DefaultLogTypes, LoggerConfiguration<L>>;
|
|
108
|
+
/**
|
|
109
|
+
* Read-only Metadata.
|
|
110
|
+
*
|
|
111
|
+
* Immutable version of the Meta interface for use in reporters.
|
|
112
|
+
* @template L - The log level type
|
|
113
|
+
*/
|
|
114
|
+
type ReadonlyMeta<L extends string> = Readonly<Meta<L>>;
|
|
115
|
+
/**
|
|
116
|
+
* Reporter Interface.
|
|
117
|
+
*
|
|
118
|
+
* Base interface for all reporters. Reporters are responsible for
|
|
119
|
+
* outputting log messages to various destinations (console, files, etc.).
|
|
120
|
+
* @template L - The log level type
|
|
121
|
+
*/
|
|
122
|
+
interface Reporter<L extends string> {
|
|
123
|
+
log: (meta: ReadonlyMeta<L>) => void;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Stream-Aware Reporter Interface.
|
|
127
|
+
*
|
|
128
|
+
* Extends Reporter with the ability to work with Node.js streams.
|
|
129
|
+
* Used for server-side reporters that need to write to stdout/stderr.
|
|
130
|
+
* @template L - The log level type
|
|
131
|
+
*/
|
|
132
|
+
interface StreamAwareReporter<L extends string> extends Reporter<L> {
|
|
133
|
+
/** Set the stderr stream for error output */
|
|
134
|
+
setStderr: (stderr: NodeJS.WriteStream) => void;
|
|
135
|
+
/** Set the stdout stream for standard output */
|
|
136
|
+
setStdout: (stdout: NodeJS.WriteStream) => void;
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Logger Types Aware Reporter Interface.
|
|
140
|
+
*
|
|
141
|
+
* Extends Reporter with the ability to receive logger type configurations.
|
|
142
|
+
* Allows reporters to customize their output based on logger types.
|
|
143
|
+
* @template T - Custom logger type names
|
|
144
|
+
* @template L - The log level type
|
|
145
|
+
*/
|
|
146
|
+
interface LoggerTypesAwareReporter<T extends string, L extends string> extends Reporter<L> {
|
|
147
|
+
/** Set the logger types configuration */
|
|
148
|
+
setLoggerTypes: (types: LoggerTypesConfig<T, L> & Partial<LoggerTypesConfig<DefaultLogTypes, L>>) => void;
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Stringify-Aware Reporter Interface.
|
|
152
|
+
*
|
|
153
|
+
* Extends Reporter with the ability to receive a custom stringify function.
|
|
154
|
+
* Useful for reporters that need to serialize complex objects.
|
|
155
|
+
* @template L - The log level type
|
|
156
|
+
*/
|
|
157
|
+
interface StringifyAwareReporter<L extends string> extends Reporter<L> {
|
|
158
|
+
/** Set the stringify function for object serialization */
|
|
159
|
+
setStringify: (stringify: any) => void;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Processor Interface.
|
|
163
|
+
*
|
|
164
|
+
* Base interface for all processors. Processors can modify or enhance
|
|
165
|
+
* log metadata before it reaches reporters.
|
|
166
|
+
* @template L - The log level type
|
|
167
|
+
*/
|
|
168
|
+
interface Processor<L extends string> {
|
|
169
|
+
/** Process the log metadata */
|
|
170
|
+
process: (meta: Meta<L>) => Meta<L>;
|
|
171
|
+
}
|
|
172
|
+
interface ConstructorOptions<T extends string, L extends string> {
|
|
173
|
+
disabled?: boolean;
|
|
174
|
+
logLevel?: LiteralUnion<ExtendedRfc5424LogLevels, L>;
|
|
175
|
+
logLevels?: Partial<Record<ExtendedRfc5424LogLevels, number>> & Record<L, number>;
|
|
176
|
+
messages?: {
|
|
177
|
+
timerEnd?: string;
|
|
178
|
+
timerStart?: string;
|
|
179
|
+
};
|
|
180
|
+
processors?: Processor<L>[];
|
|
181
|
+
rawReporter?: Reporter<L>;
|
|
182
|
+
reporters?: Reporter<L>[];
|
|
183
|
+
scope?: string[] | string;
|
|
184
|
+
throttle?: number;
|
|
185
|
+
throttleMin?: number;
|
|
186
|
+
types?: LoggerTypesConfig<T, L> & Partial<LoggerTypesConfig<DefaultLogTypes, L>>;
|
|
187
|
+
}
|
|
188
|
+
type Message = {
|
|
189
|
+
context?: any[];
|
|
190
|
+
message: any;
|
|
191
|
+
prefix?: string;
|
|
192
|
+
suffix?: string;
|
|
193
|
+
};
|
|
194
|
+
export { ConstructorOptions as C, DefaultLogTypes as D, ExtendedRfc5424LogLevels as E, LoggerTypesConfig as L, Meta as M, Processor as P, ReadonlyMeta as R, StringifyAwareReporter as S, LoggerTypesAwareReporter as a, Reporter as b, LoggerFunction as c, DefaultLoggerTypes as d, LoggerConfiguration as e, StreamAwareReporter as f };
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import { AnsiColors } from '@visulima/colorize';
|
|
2
|
+
import { InteractiveManager } from '@visulima/interactive-manager';
|
|
3
|
+
/**
|
|
4
|
+
Matches any [primitive value](https://developer.mozilla.org/en-US/docs/Glossary/Primitive).
|
|
5
|
+
|
|
6
|
+
@category Type
|
|
7
|
+
*/
|
|
8
|
+
type Primitive = null | undefined | string | number | boolean | symbol | bigint;
|
|
9
|
+
/**
|
|
10
|
+
Create a union type by combining primitive types and literal types without sacrificing auto-completion in IDEs for the literal type part of the union.
|
|
11
|
+
|
|
12
|
+
Currently, when a union type of a primitive type is combined with literal types, TypeScript loses all information about the combined literals. Thus, when such type is used in an IDE with autocompletion, no suggestions are made for the declared literals.
|
|
13
|
+
|
|
14
|
+
This type is a workaround for [Microsoft/TypeScript#29729](https://github.com/Microsoft/TypeScript/issues/29729). It will be removed as soon as it's not needed anymore.
|
|
15
|
+
|
|
16
|
+
@example
|
|
17
|
+
```
|
|
18
|
+
import type {LiteralUnion} from 'type-fest';
|
|
19
|
+
|
|
20
|
+
// Before
|
|
21
|
+
|
|
22
|
+
type Pet = 'dog' | 'cat' | string;
|
|
23
|
+
|
|
24
|
+
const petWithoutAutocomplete: Pet = '';
|
|
25
|
+
// Start typing in your TypeScript-enabled IDE.
|
|
26
|
+
// You **will not** get auto-completion for `dog` and `cat` literals.
|
|
27
|
+
|
|
28
|
+
// After
|
|
29
|
+
|
|
30
|
+
type Pet2 = LiteralUnion<'dog' | 'cat', string>;
|
|
31
|
+
|
|
32
|
+
const petWithAutoComplete: Pet2 = '';
|
|
33
|
+
// You **will** get auto-completion for `dog` and `cat` literals.
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
@category Type
|
|
37
|
+
*/
|
|
38
|
+
type LiteralUnion<LiteralType, BaseType extends Primitive> = LiteralType | (BaseType & Record<never, never>);
|
|
39
|
+
/**
|
|
40
|
+
* Global namespace for extending Pail's metadata interface.
|
|
41
|
+
*
|
|
42
|
+
* This global declaration allows other packages and applications to extend
|
|
43
|
+
* the Meta interface with custom properties by declaring additional properties
|
|
44
|
+
* in the VisulimaPail.CustomMeta interface.
|
|
45
|
+
* @example
|
|
46
|
+
* ```typescript
|
|
47
|
+
* declare global {
|
|
48
|
+
* namespace VisulimaPail {
|
|
49
|
+
* interface CustomMeta<L> {
|
|
50
|
+
* userId?: string;
|
|
51
|
+
* requestId?: string;
|
|
52
|
+
* }
|
|
53
|
+
* }
|
|
54
|
+
* }
|
|
55
|
+
* ```
|
|
56
|
+
*/
|
|
57
|
+
declare global {
|
|
58
|
+
namespace VisulimaPail {
|
|
59
|
+
interface CustomMeta<L> {}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Metadata object containing all information about a log entry.
|
|
64
|
+
*
|
|
65
|
+
* This interface defines the structure of metadata that is passed to reporters
|
|
66
|
+
* and processors. It contains all the contextual information about a log message
|
|
67
|
+
* including the message itself, timing information, error details, and more.
|
|
68
|
+
* @template L - The log level type
|
|
69
|
+
*/
|
|
70
|
+
interface Meta<L> extends VisulimaPail.CustomMeta<L> {
|
|
71
|
+
badge: string | undefined;
|
|
72
|
+
context: any[] | undefined;
|
|
73
|
+
date: Date | string;
|
|
74
|
+
error: Error | undefined;
|
|
75
|
+
groups: string[];
|
|
76
|
+
label: string | undefined;
|
|
77
|
+
message: Primitive | ReadonlyArray<unknown> | Record<PropertyKey, unknown>;
|
|
78
|
+
prefix: string | undefined;
|
|
79
|
+
repeated?: number;
|
|
80
|
+
scope: string[] | undefined;
|
|
81
|
+
suffix: string | undefined;
|
|
82
|
+
traceError: Error | undefined;
|
|
83
|
+
type: {
|
|
84
|
+
level: ExtendedRfc5424LogLevels | L;
|
|
85
|
+
name: string;
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Extended RFC 5424 Log Levels.
|
|
90
|
+
*
|
|
91
|
+
* Standard syslog severity levels as defined in RFC 5424, plus additional
|
|
92
|
+
* levels commonly used in modern applications. Each level has a numeric
|
|
93
|
+
* priority where lower numbers indicate higher severity.
|
|
94
|
+
* @see https://datatracker.ietf.org/doc/html/rfc5424#section-6.2.1
|
|
95
|
+
*/
|
|
96
|
+
type ExtendedRfc5424LogLevels = "alert" | "critical" | "debug" | "emergency" | "error" | "informational" | "notice" | "trace" | "warning";
|
|
97
|
+
/**
|
|
98
|
+
* Default Log Types.
|
|
99
|
+
*
|
|
100
|
+
* Predefined semantic log types that provide meaningful categorization
|
|
101
|
+
* for different kinds of log messages. Each type has associated styling
|
|
102
|
+
* and log level configuration.
|
|
103
|
+
*/
|
|
104
|
+
type DefaultLogTypes = "alert" | "await" | "complete" | "critical" | "debug" | "emergency" | "error" | "info" | "log" | "notice" | "pending" | "start" | "stop" | "success" | "trace" | "wait" | "warn" | "warning" | "watch";
|
|
105
|
+
/**
|
|
106
|
+
* Logger Function Type.
|
|
107
|
+
*
|
|
108
|
+
* Represents a logging function that can accept either a structured Message object
|
|
109
|
+
* or multiple arguments in the traditional console.log style.
|
|
110
|
+
*/
|
|
111
|
+
interface LoggerFunction {
|
|
112
|
+
(message: Message): void;
|
|
113
|
+
(...message: any[]): void;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Logger Configuration.
|
|
117
|
+
*
|
|
118
|
+
* Configuration object that defines how a specific logger type should behave,
|
|
119
|
+
* including its visual appearance and log level.
|
|
120
|
+
* @template L - The log level type
|
|
121
|
+
*/
|
|
122
|
+
interface LoggerConfiguration<L extends string> {
|
|
123
|
+
badge?: string;
|
|
124
|
+
color?: AnsiColors;
|
|
125
|
+
label: string;
|
|
126
|
+
logLevel: LiteralUnion<ExtendedRfc5424LogLevels, L>;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Logger Types Configuration.
|
|
130
|
+
*
|
|
131
|
+
* A record mapping logger type names to their configurations.
|
|
132
|
+
* @template T - Custom logger type names
|
|
133
|
+
* @template L - Log level types
|
|
134
|
+
*/
|
|
135
|
+
type LoggerTypesConfig<T extends string, L extends string> = Record<T, Partial<LoggerConfiguration<L>>>;
|
|
136
|
+
/**
|
|
137
|
+
* Default Logger Types Configuration.
|
|
138
|
+
*
|
|
139
|
+
* A complete mapping of all default log types to their full configurations.
|
|
140
|
+
* @template L - Log level types
|
|
141
|
+
*/
|
|
142
|
+
type DefaultLoggerTypes<L extends string = string> = Record<DefaultLogTypes, LoggerConfiguration<L>>;
|
|
143
|
+
/**
|
|
144
|
+
* Read-only Metadata.
|
|
145
|
+
*
|
|
146
|
+
* Immutable version of the Meta interface for use in reporters.
|
|
147
|
+
* @template L - The log level type
|
|
148
|
+
*/
|
|
149
|
+
type ReadonlyMeta<L extends string> = Readonly<Meta<L>>;
|
|
150
|
+
/**
|
|
151
|
+
* Reporter Interface.
|
|
152
|
+
*
|
|
153
|
+
* Base interface for all reporters. Reporters are responsible for
|
|
154
|
+
* outputting log messages to various destinations (console, files, etc.).
|
|
155
|
+
* @template L - The log level type
|
|
156
|
+
*/
|
|
157
|
+
interface Reporter<L extends string> {
|
|
158
|
+
log: (meta: ReadonlyMeta<L>) => void;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Stream-Aware Reporter Interface.
|
|
162
|
+
*
|
|
163
|
+
* Extends Reporter with the ability to work with Node.js streams.
|
|
164
|
+
* Used for server-side reporters that need to write to stdout/stderr.
|
|
165
|
+
* @template L - The log level type
|
|
166
|
+
*/
|
|
167
|
+
interface StreamAwareReporter<L extends string> extends Reporter<L> {
|
|
168
|
+
/** Set the stderr stream for error output */
|
|
169
|
+
setStderr: (stderr: NodeJS.WriteStream) => void;
|
|
170
|
+
/** Set the stdout stream for standard output */
|
|
171
|
+
setStdout: (stdout: NodeJS.WriteStream) => void;
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Logger Types Aware Reporter Interface.
|
|
175
|
+
*
|
|
176
|
+
* Extends Reporter with the ability to receive logger type configurations.
|
|
177
|
+
* Allows reporters to customize their output based on logger types.
|
|
178
|
+
* @template T - Custom logger type names
|
|
179
|
+
* @template L - The log level type
|
|
180
|
+
*/
|
|
181
|
+
interface LoggerTypesAwareReporter<T extends string, L extends string> extends Reporter<L> {
|
|
182
|
+
/** Set the logger types configuration */
|
|
183
|
+
setLoggerTypes: (types: LoggerTypesConfig<T, L> & Partial<LoggerTypesConfig<DefaultLogTypes, L>>) => void;
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Interactive Stream Reporter Interface.
|
|
187
|
+
*
|
|
188
|
+
* Extends StreamAwareReporter with interactive capabilities for terminal UIs.
|
|
189
|
+
* Supports features like progress bars and dynamic updates.
|
|
190
|
+
* @template L - The log level type
|
|
191
|
+
*/
|
|
192
|
+
interface InteractiveStreamReporter<L extends string> extends StreamAwareReporter<L> {
|
|
193
|
+
/** Set the interactive manager for handling interactive output */
|
|
194
|
+
setInteractiveManager: (manager?: InteractiveManager) => void;
|
|
195
|
+
/** Enable or disable interactive mode */
|
|
196
|
+
setIsInteractive: (interactive: boolean) => void;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Processor Interface.
|
|
200
|
+
*
|
|
201
|
+
* Base interface for all processors. Processors can modify or enhance
|
|
202
|
+
* log metadata before it reaches reporters.
|
|
203
|
+
* @template L - The log level type
|
|
204
|
+
*/
|
|
205
|
+
interface Processor<L extends string> {
|
|
206
|
+
/** Process the log metadata */
|
|
207
|
+
process: (meta: Meta<L>) => Meta<L>;
|
|
208
|
+
}
|
|
209
|
+
interface ConstructorOptions<T extends string, L extends string> {
|
|
210
|
+
disabled?: boolean;
|
|
211
|
+
logLevel?: LiteralUnion<ExtendedRfc5424LogLevels, L>;
|
|
212
|
+
logLevels?: Partial<Record<ExtendedRfc5424LogLevels, number>> & Record<L, number>;
|
|
213
|
+
messages?: {
|
|
214
|
+
timerEnd?: string;
|
|
215
|
+
timerStart?: string;
|
|
216
|
+
};
|
|
217
|
+
processors?: Processor<L>[];
|
|
218
|
+
rawReporter?: Reporter<L>;
|
|
219
|
+
reporters?: Reporter<L>[];
|
|
220
|
+
scope?: string[] | string;
|
|
221
|
+
throttle?: number;
|
|
222
|
+
throttleMin?: number;
|
|
223
|
+
types?: LoggerTypesConfig<T, L> & Partial<LoggerTypesConfig<DefaultLogTypes, L>>;
|
|
224
|
+
}
|
|
225
|
+
interface ServerConstructorOptions<T extends string, L extends string> extends ConstructorOptions<T, L> {
|
|
226
|
+
interactive?: boolean;
|
|
227
|
+
stderr: NodeJS.WriteStream;
|
|
228
|
+
stdout: NodeJS.WriteStream;
|
|
229
|
+
}
|
|
230
|
+
type Message = {
|
|
231
|
+
context?: any[];
|
|
232
|
+
message: any;
|
|
233
|
+
prefix?: string;
|
|
234
|
+
suffix?: string;
|
|
235
|
+
};
|
|
236
|
+
export { ConstructorOptions as C, DefaultLogTypes as D, ExtendedRfc5424LogLevels as E, InteractiveStreamReporter as I, LiteralUnion as L, Meta as M, Processor as P, Reporter as R, ServerConstructorOptions as S, LoggerTypesConfig as a, LoggerFunction as b, DefaultLoggerTypes as c, LoggerConfiguration as d, LoggerTypesAwareReporter as e, StreamAwareReporter as f, ReadonlyMeta as g };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var n=Object.defineProperty;var t=(e,r)=>n(e,"name",{value:r,configurable:!0});import{createRequire as i}from"node:module";const a=i(import.meta.url),o=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,c=t(e=>{if(typeof o<"u"&&o.versions&&o.versions.node){const[r,s]=o.versions.node.split(".").map(Number);if(r>22||r===22&&s>=3||r===20&&s>=16)return o.getBuiltinModule(e)}return a(e)},"__cjs_getBuiltinModule"),{AsyncLocalStorage:u}=c("node:async_hooks");var l=Object.defineProperty,g=t((e,r)=>l(e,"name",{value:r,configurable:!0}),"t");const p=new u,_=g(()=>{const e=p.getStore();if(!e)throw new Error("[pail] useLogger() called outside of withPail() context. Wrap your route handler or server action with withPail().");return e},"useLogger");export{p as pailStorage,_ as useLogger};
|