-
Notifications
You must be signed in to change notification settings - Fork 1.8k
/
splat.js
86 lines (77 loc) · 1.39 KB
/
splat.js
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
const winston = require('../');
let { format } = winston;
/*
* Simple helper for stringifying all remaining
* properties.
*/
function rest(info) {
return JSON.stringify(Object.assign({}, info, {
level: undefined,
message: undefined,
splat: undefined,
label: undefined
}));
}
let logger = winston.createLogger({
transports: [new winston.transports.Console({ level: 'info' })],
format: format.combine(
format.splat(),
format.printf(info => `[${info.label}] ${info.message} ${rest(info)}`)
)
});
logger.log(
'info',
'any message',
{
label: 'label!',
extra: true
}
);
logger.log(
'info',
'let\'s %s some %s',
'interpolate',
'splat parameters',
{
label: 'label!',
extra: true
}
);
logger.log(
'info',
'first is a string %s [[%j]]',
'behold a string',
{ beAware: 'this will interpolate' },
{
label: 'label!',
extra: true
}
);
logger.log(
'info',
'first is an object [[%j]]',
{ beAware: 'this will interpolate' },
{
label: 'label!',
extra: true
}
);
//
// Non-enumerable properties (such as "message" and "stack" in Error
// instances) will not be merged into any `info`.
//
const terr = new Error('lol please stop doing this');
terr.label = 'error';
terr.extra = true;
logger.log(
'info',
'any message',
terr
);
logger.log(
'info',
'let\'s %s some %s',
'interpolate',
'splat parameters',
terr
);