mongodb-log-writer 1.1.0 → 1.1.4
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/lib/index.d.ts +1 -0
- package/lib/index.js +17 -6
- package/lib/index.js.map +1 -1
- package/package.json +1 -1
package/lib/index.d.ts
CHANGED
|
@@ -39,6 +39,7 @@ export declare class MongoLogWriter extends Writable {
|
|
|
39
39
|
error(id: MongoLogId, context: string, message: string, attr?: unknown): void;
|
|
40
40
|
fatal(id: MongoLogId, context: string, message: string, attr?: unknown): void;
|
|
41
41
|
};
|
|
42
|
+
mongoLogId: typeof mongoLogId;
|
|
42
43
|
}
|
|
43
44
|
interface MongoLogOptions {
|
|
44
45
|
directory: string;
|
package/lib/index.js
CHANGED
|
@@ -11,7 +11,6 @@ const path_1 = __importDefault(require("path"));
|
|
|
11
11
|
const stream_1 = require("stream");
|
|
12
12
|
const util_1 = require("util");
|
|
13
13
|
const zlib_1 = require("zlib");
|
|
14
|
-
const v8_1 = __importDefault(require("v8"));
|
|
15
14
|
function mongoLogId(id) {
|
|
16
15
|
return { __value: id };
|
|
17
16
|
}
|
|
@@ -38,6 +37,7 @@ function validateLogEntry(info) {
|
|
|
38
37
|
class MongoLogWriter extends stream_1.Writable {
|
|
39
38
|
constructor(logId, logFilePath, target, now) {
|
|
40
39
|
super({ objectMode: true });
|
|
40
|
+
this.mongoLogId = mongoLogId;
|
|
41
41
|
this._logId = logId;
|
|
42
42
|
this._logFilePath = logFilePath;
|
|
43
43
|
this._target = target;
|
|
@@ -67,7 +67,6 @@ class MongoLogWriter extends stream_1.Writable {
|
|
|
67
67
|
ctx: info.ctx,
|
|
68
68
|
msg: info.msg
|
|
69
69
|
};
|
|
70
|
-
this.emit('log', fullInfo);
|
|
71
70
|
if (info.attr) {
|
|
72
71
|
if (Object.prototype.toString.call(info.attr) === '[object Error]') {
|
|
73
72
|
fullInfo.attr = {
|
|
@@ -82,12 +81,14 @@ class MongoLogWriter extends stream_1.Writable {
|
|
|
82
81
|
fullInfo.attr = info.attr;
|
|
83
82
|
}
|
|
84
83
|
}
|
|
84
|
+
this.emit('log', fullInfo);
|
|
85
85
|
try {
|
|
86
86
|
bson_1.EJSON.stringify(fullInfo.attr);
|
|
87
87
|
}
|
|
88
88
|
catch (_b) {
|
|
89
89
|
try {
|
|
90
|
-
const
|
|
90
|
+
const v8 = require('v8');
|
|
91
|
+
const cloned = v8.deserialize(v8.serialize(fullInfo.attr));
|
|
91
92
|
bson_1.EJSON.stringify(cloned);
|
|
92
93
|
fullInfo.attr = cloned;
|
|
93
94
|
}
|
|
@@ -202,18 +203,23 @@ class MongoLogManager {
|
|
|
202
203
|
const logId = new bson_1.ObjectId().toString();
|
|
203
204
|
const doGzip = !!this._options.gzip;
|
|
204
205
|
const logFilePath = path_1.default.join(this._options.directory, `${logId}_log${doGzip ? '.gz' : ''}`);
|
|
206
|
+
let originalTarget;
|
|
205
207
|
let stream;
|
|
208
|
+
let logWriter;
|
|
206
209
|
try {
|
|
207
210
|
stream = (0, fs_1.createWriteStream)(logFilePath, { mode: 0o600 });
|
|
211
|
+
originalTarget = stream;
|
|
208
212
|
await (0, events_1.once)(stream, 'ready');
|
|
209
213
|
if (doGzip) {
|
|
210
|
-
const originalTarget = stream;
|
|
211
214
|
stream = (0, zlib_1.createGzip)({
|
|
212
215
|
flush: zlib_1.constants.Z_SYNC_FLUSH,
|
|
213
216
|
level: zlib_1.constants.Z_MAX_LEVEL
|
|
214
217
|
});
|
|
215
218
|
stream.pipe(originalTarget);
|
|
216
219
|
}
|
|
220
|
+
else {
|
|
221
|
+
stream.on('finish', () => stream.emit('log-finish'));
|
|
222
|
+
}
|
|
217
223
|
}
|
|
218
224
|
catch (err) {
|
|
219
225
|
this._options.onwarn(err, logFilePath);
|
|
@@ -222,9 +228,14 @@ class MongoLogManager {
|
|
|
222
228
|
cb();
|
|
223
229
|
}
|
|
224
230
|
});
|
|
225
|
-
|
|
231
|
+
originalTarget = stream;
|
|
232
|
+
logWriter = new MongoLogWriter(logId, null, stream);
|
|
233
|
+
}
|
|
234
|
+
if (!logWriter) {
|
|
235
|
+
logWriter = new MongoLogWriter(logId, logFilePath, stream);
|
|
226
236
|
}
|
|
227
|
-
|
|
237
|
+
originalTarget.on('finish', () => logWriter === null || logWriter === void 0 ? void 0 : logWriter.emit('log-finish'));
|
|
238
|
+
return logWriter;
|
|
228
239
|
}
|
|
229
240
|
}
|
|
230
241
|
exports.MongoLogManager = MongoLogManager;
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AAAA,+BAAuC;AACvC,mCAA8B;AAC9B,2BAAuD;AACvD,gDAAwB;AACxB,mCAAkC;AAClC,+BAA+B;AAC/B,+BAA8D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|