/
pino-logger.js
83 lines (67 loc) · 2.61 KB
/
pino-logger.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
/*
This file is part of botten-nappet -- a Twitch bot and streaming tool.
<https://joelpurra.com/projects/botten-nappet/>
Copyright (c) 2018 Joel Purra <https://joelpurra.com/>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const assert = require("power-assert");
export default class PinoLogger {
constructor(parentPinoLogger) {
assert.strictEqual(arguments.length, 1);
assert.strictEqual(typeof parentPinoLogger, "object");
this._parentPinoLogger = parentPinoLogger;
this._loggingMethods = [
"fatal",
"error",
"warn",
"info",
"debug",
"trace",
];
this._loggingMethods.forEach(
(loggingMethod) => {
this[loggingMethod] = (...args) => {
this._parentPinoLogger[loggingMethod]({
// TODO: serialize error objects etcetera.
// args: this._serialize(args),
args: args,
});
// TODO: configure to flush only during development/debugging.
this._parentPinoLogger.flush();
};
}
);
}
child(childName) {
assert.strictEqual(arguments.length, 1);
assert.strictEqual(typeof childName, "string");
assert(childName.length > 0);
const childBindings = {
childName: childName,
};
const pinoLogger = this._parentPinoLogger.child(childBindings);
const childLogger = new PinoLogger(pinoLogger);
return childLogger;
}
// _valueReplacer(/* eslint-disable no-unused-vars */key/* eslint-enable no-unused-vars */, value) {
// if (value !== null && typeof value === "object" && value.stack) {
// return value.toString();
// }
//
// return value;
// }
//
// _serialize(value) {
// // TODO: serialize error objects etcetera.
// return JSON.stringify(value, this._valueReplacer.bind(this), 2);
// }
}