forked from pinojs/pino-http
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.d.ts
86 lines (70 loc) · 2.9 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// Project: https://github.com/pinojs/pino-http#readme
// Definitions by: Christian Rackerseder <https://github.com/screendriver>
// Jeremy Forsythe <https://github.com/jdforsythe>
// Griffin Yourick <https://github.com/tough-griff>
// Jorge Barnaby <https://github.com/yorch>
// Jose Ramirez <https://github.com/jarcodallo>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
// TypeScript Version: 4.0
/// <reference types="node"/>
import { IncomingMessage, ServerResponse } from 'http';
import pino from 'pino';
import { SerializedError, SerializedRequest, SerializedResponse } from 'pino-std-serializers';
declare function PinoHttp(opts?: Options, stream?: pino.DestinationStream): HttpLogger;
declare function PinoHttp(stream?: pino.DestinationStream): HttpLogger;
export interface HttpLogger {
(req: IncomingMessage, res: ServerResponse, next?: () => void): void;
logger: pino.Logger;
}
export type ReqId = number | string | object;
export interface Options extends pino.LoggerOptions {
logger?: pino.Logger | undefined;
genReqId?: GenReqId | undefined;
useLevel?: pino.LevelWithSilent | undefined;
stream?: pino.DestinationStream | undefined;
autoLogging?: boolean | AutoLoggingOptions | undefined;
customLogLevel?: ((req: IncomingMessage, res: ServerResponse, error: Error) => pino.LevelWithSilent) | undefined;
customReceivedMessage?: ((req: IncomingMessage, res: ServerResponse) => string) | undefined;
customSuccessMessage?: ((req: IncomingMessage, res: ServerResponse) => string) | undefined;
customErrorMessage?: ((req: IncomingMessage, res: ServerResponse, error: Error) => string) | undefined;
customAttributeKeys?: CustomAttributeKeys | undefined;
wrapSerializers?: boolean | undefined;
customProps?: ((req: IncomingMessage, res: ServerResponse) => object) | undefined;
quietReqLogger?: boolean | undefined;
}
export interface GenReqId {
(req: IncomingMessage): ReqId;
}
export interface AutoLoggingOptions {
ignore?: ((req: IncomingMessage) => boolean);
ignorePaths?: Array<string | RegExp> | undefined;
getPath?: ((req: IncomingMessage) => string | undefined) | undefined;
}
export interface CustomAttributeKeys {
req?: string | undefined;
res?: string | undefined;
err?: string | undefined;
reqId?: string | undefined;
responseTime?: string | undefined;
}
export interface StdSerializers {
err: SerializedError;
req: SerializedRequest;
res: SerializedResponse;
}
export default PinoHttp;
export { PinoHttp as pinoHttp }
export const startTime: unique symbol;
export const stdSerializers: StdSerializers;
declare module "http" {
interface IncomingMessage {
id: ReqId;
log: pino.Logger;
}
interface ServerResponse {
err?: Error | undefined;
}
interface OutgoingMessage {
[startTime]: number;
}
}