-
Notifications
You must be signed in to change notification settings - Fork 0
/
log-koa-example.ts
69 lines (58 loc) · 1.61 KB
/
log-koa-example.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
import * as Koa from 'koa';
interface ILogData {
method: string;
url: string;
query: string;
remoteAddress: string;
host: string;
userAgent: string;
statusCode: number;
errorMessage: string;
errorStack: string;
data: any;
responseTime: number;
}
function outputLog(data: Partial<ILogData>, thrownError: any) {
if (true /*config.prettyLog*/) {
console.log(`${data.statusCode} ${data.method} ${data.url} - ${data.responseTime}ms`);
if (thrownError) {
console.error(thrownError);
}
}
else if (data.statusCode as number < 400) {
process.stdout.write(JSON.stringify(data) + '\n');
}
else {
process.stderr.write(JSON.stringify(data) + '\n');
}
}
export async function logger(ctx: Koa.Context, next: () => Promise<any>) {
const start = new Date().getMilliseconds();
const logData: Partial<ILogData> = {
method: ctx.method,
url: ctx.url,
query: ctx.query,
remoteAddress: ctx.request.ip,
host: ctx.headers['host'],
userAgent: ctx.headers['user-agent'],
};
let errorThrown: any = null;
try {
await next();
logData.statusCode = ctx.status;
}
catch (e) {
errorThrown = e;
logData.errorMessage = e.message;
logData.errorStack = e.stack;
logData.statusCode = e.status || 500;
if (e.data) {
logData.data = e.data;
}
}
logData.responseTime = new Date().getMilliseconds() - start;
outputLog(logData, errorThrown);
if (errorThrown) {
throw errorThrown;
}
}