@mongosh/cli-repl 1.0.5 → 1.1.1

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/log-writer.js DELETED
@@ -1,206 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.MongoLogManager = exports.MongoLogWriter = exports.mongoLogId = void 0;
7
- const bson_1 = require("bson");
8
- const events_1 = require("events");
9
- const fs_1 = require("fs");
10
- const path_1 = __importDefault(require("path"));
11
- const stream_1 = require("stream");
12
- const util_1 = require("util");
13
- const v8_1 = __importDefault(require("v8"));
14
- function mongoLogId(id) {
15
- return { __value: id };
16
- }
17
- exports.mongoLogId = mongoLogId;
18
- function validateLogEntry(info) {
19
- var _a;
20
- if (typeof info.s !== 'string') {
21
- return new TypeError('Cannot log messages without a severity field');
22
- }
23
- if (typeof info.c !== 'string') {
24
- return new TypeError('Cannot log messages without a component field');
25
- }
26
- if (typeof ((_a = info.id) === null || _a === void 0 ? void 0 : _a.__value) !== 'number') {
27
- return new TypeError('Cannot log messages without an id field');
28
- }
29
- if (typeof info.ctx !== 'string') {
30
- return new TypeError('Cannot log messages without a context field');
31
- }
32
- if (typeof info.msg !== 'string') {
33
- return new TypeError('Cannot log messages without a message field');
34
- }
35
- return null;
36
- }
37
- class MongoLogWriter extends stream_1.Writable {
38
- constructor(logId, logFilePath, target, now) {
39
- super({ objectMode: true });
40
- this._logId = logId;
41
- this._logFilePath = logFilePath;
42
- this._target = target;
43
- this._now = now !== null && now !== void 0 ? now : (() => new Date());
44
- }
45
- get logId() {
46
- return this._logId;
47
- }
48
- get logFilePath() {
49
- return this._logFilePath;
50
- }
51
- _write(info, encoding, callback) {
52
- var _a;
53
- const validationError = validateLogEntry(info);
54
- if (validationError) {
55
- callback(validationError);
56
- return;
57
- }
58
- const fullInfo = {
59
- t: (_a = info.t) !== null && _a !== void 0 ? _a : this._now(),
60
- s: info.s,
61
- c: info.c,
62
- id: info.id.__value,
63
- ctx: info.ctx,
64
- msg: info.msg
65
- };
66
- if (info.attr) {
67
- if (Object.prototype.toString.call(info.attr) === '[object Error]') {
68
- fullInfo.attr = {
69
- stack: info.attr.stack,
70
- name: info.attr.name,
71
- message: info.attr.message,
72
- code: info.attr.code,
73
- ...info.attr
74
- };
75
- }
76
- else {
77
- fullInfo.attr = info.attr;
78
- }
79
- }
80
- try {
81
- bson_1.EJSON.stringify(fullInfo.attr);
82
- }
83
- catch (_b) {
84
- try {
85
- const cloned = v8_1.default.deserialize(v8_1.default.serialize(fullInfo.attr));
86
- bson_1.EJSON.stringify(cloned);
87
- fullInfo.attr = cloned;
88
- }
89
- catch (_c) {
90
- try {
91
- const cloned = JSON.parse(JSON.stringify(fullInfo.attr));
92
- bson_1.EJSON.stringify(cloned);
93
- fullInfo.attr = cloned;
94
- }
95
- catch (_d) {
96
- fullInfo.attr = { _inspected: util_1.inspect(fullInfo.attr) };
97
- }
98
- }
99
- }
100
- this._target.write(bson_1.EJSON.stringify(fullInfo, { relaxed: true }) + '\n', callback);
101
- }
102
- _final(callback) {
103
- this._target.end(callback);
104
- }
105
- async flush() {
106
- await new Promise(resolve => this._target.write('', resolve));
107
- }
108
- info(component, id, context, message, attr) {
109
- const logEntry = {
110
- s: 'I',
111
- c: component,
112
- id: id,
113
- ctx: context,
114
- msg: message,
115
- attr: attr
116
- };
117
- this.write(logEntry);
118
- }
119
- warn(component, id, context, message, attr) {
120
- const logEntry = {
121
- s: 'W',
122
- c: component,
123
- id: id,
124
- ctx: context,
125
- msg: message,
126
- attr: attr
127
- };
128
- this.write(logEntry);
129
- }
130
- error(component, id, context, message, attr) {
131
- const logEntry = {
132
- s: 'E',
133
- c: component,
134
- id: id,
135
- ctx: context,
136
- msg: message,
137
- attr: attr
138
- };
139
- this.write(logEntry);
140
- }
141
- fatal(component, id, context, message, attr) {
142
- const logEntry = {
143
- s: 'F',
144
- c: component,
145
- id: id,
146
- ctx: context,
147
- msg: message,
148
- attr: attr
149
- };
150
- this.write(logEntry);
151
- }
152
- }
153
- exports.MongoLogWriter = MongoLogWriter;
154
- class MongoLogManager {
155
- constructor(options) {
156
- this._options = options;
157
- }
158
- async cleanupOldLogfiles() {
159
- var _a, _b;
160
- const dir = this._options.directory;
161
- let dirHandle;
162
- try {
163
- dirHandle = await fs_1.promises.opendir(dir);
164
- }
165
- catch (_c) {
166
- return;
167
- }
168
- for await (const dirent of dirHandle) {
169
- if (!dirent.isFile())
170
- continue;
171
- const { id } = (_b = (_a = dirent.name.match(/^(?<id>[a-f0-9]{24})_log$/i)) === null || _a === void 0 ? void 0 : _a.groups) !== null && _b !== void 0 ? _b : {};
172
- if (!id)
173
- continue;
174
- if (new bson_1.ObjectId(id).generationTime < (Date.now() / 1000) - this._options.retentionDays * 86400) {
175
- const toUnlink = path_1.default.join(dir, dirent.name);
176
- try {
177
- await fs_1.promises.unlink(toUnlink);
178
- }
179
- catch (err) {
180
- this._options.onerror(err, toUnlink);
181
- }
182
- }
183
- }
184
- }
185
- async createLogWriter() {
186
- const logId = new bson_1.ObjectId().toString();
187
- const logFilePath = path_1.default.join(this._options.directory, `${logId}_log`);
188
- let stream;
189
- try {
190
- stream = fs_1.createWriteStream(logFilePath, { mode: 0o600 });
191
- await events_1.once(stream, 'ready');
192
- }
193
- catch (err) {
194
- this._options.onwarn(err, logFilePath);
195
- stream = new stream_1.Writable({
196
- write(chunk, enc, cb) {
197
- cb();
198
- }
199
- });
200
- return new MongoLogWriter(logId, null, stream);
201
- }
202
- return new MongoLogWriter(logId, logFilePath, stream);
203
- }
204
- }
205
- exports.MongoLogManager = MongoLogManager;
206
- //# sourceMappingURL=log-writer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"log-writer.js","sourceRoot":"","sources":["../src/log-writer.ts"],"names":[],"mappings":"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"}
@@ -1,20 +0,0 @@
1
- import type { MongoshBus } from '@mongosh/types';
2
- import { MongoLogWriter } from './log-writer';
3
- interface MongoshAnalytics {
4
- identify(message: {
5
- userId: string;
6
- traits: {
7
- platform: string;
8
- };
9
- }): void;
10
- track(message: {
11
- userId: string;
12
- event: string;
13
- properties: {
14
- mongosh_version: string;
15
- [key: string]: any;
16
- };
17
- }): void;
18
- }
19
- export default function setupLoggerAndTelemetry(logId: string, bus: MongoshBus, makeLogger: () => MongoLogWriter, makeAnalytics: () => MongoshAnalytics): void;
20
- export {};
@@ -1,314 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const mongodb_redact_1 = __importDefault(require("mongodb-redact"));
7
- const history_1 = require("@mongosh/history");
8
- const util_1 = require("util");
9
- const build_info_1 = require("./build-info");
10
- const log_writer_1 = require("./log-writer");
11
- class NoopAnalytics {
12
- identify(_info) { }
13
- track(_info) { }
14
- }
15
- function setupLoggerAndTelemetry(logId, bus, makeLogger, makeAnalytics) {
16
- const log = makeLogger();
17
- const mongosh_version = require('../package.json').version;
18
- let userId;
19
- let telemetry;
20
- const userTraits = {
21
- platform: process.platform,
22
- arch: process.arch
23
- };
24
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000000), 'log', 'Starting log', {
25
- execPath: process.execPath,
26
- ...build_info_1.buildInfo()
27
- });
28
- let analytics = new NoopAnalytics();
29
- try {
30
- analytics = makeAnalytics();
31
- }
32
- catch (e) {
33
- log.error('MONGOSH', log_writer_1.mongoLogId(1000000001), 'analytics', 'Failed to instantiate analytics provider', e);
34
- }
35
- let hasStartedMongoshRepl = false;
36
- bus.on('mongosh:start-mongosh-repl', (ev) => {
37
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000002), 'repl', 'Started REPL', ev);
38
- hasStartedMongoshRepl = true;
39
- });
40
- let usesShellOption = false;
41
- bus.on('mongosh:start-loading-cli-scripts', (event) => {
42
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000003), 'repl', 'Start loading CLI scripts');
43
- usesShellOption = event.usesShellOption;
44
- });
45
- bus.on('mongosh:connect', function (args) {
46
- const connectionUri = history_1.redactURICredentials(args.uri);
47
- const { uri: _uri, ...argsWithoutUri } = args;
48
- const params = { session_id: logId, userId, connectionUri, ...argsWithoutUri };
49
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000004), 'connect', 'Connecting to server', params);
50
- if (telemetry) {
51
- analytics.track({
52
- userId,
53
- event: 'New Connection',
54
- properties: {
55
- mongosh_version,
56
- session_id: logId,
57
- ...argsWithoutUri
58
- }
59
- });
60
- }
61
- });
62
- bus.on('mongosh:driver-initialized', function (driverMetadata) {
63
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000004), 'connect', 'Driver initialized', driverMetadata);
64
- });
65
- bus.on('mongosh:new-user', function (id, enableTelemetry) {
66
- userId = id;
67
- telemetry = enableTelemetry;
68
- if (telemetry)
69
- analytics.identify({ userId, traits: userTraits });
70
- });
71
- bus.on('mongosh:update-user', function (id, enableTelemetry) {
72
- userId = id;
73
- telemetry = enableTelemetry;
74
- if (telemetry)
75
- analytics.identify({ userId, traits: userTraits });
76
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000005), 'config', 'User updated', { enableTelemetry });
77
- });
78
- bus.on('mongosh:error', function (error, context) {
79
- if (context === 'fatal') {
80
- log.fatal('MONGOSH', log_writer_1.mongoLogId(1000000006), context, `${error.name}: ${error.message}`, error);
81
- }
82
- else {
83
- log.error('MONGOSH', log_writer_1.mongoLogId(1000000006), context, `${error.name}: ${error.message}`, error);
84
- }
85
- if (telemetry && error.name.includes('Mongosh')) {
86
- analytics.track({
87
- userId,
88
- event: 'Error',
89
- properties: {
90
- mongosh_version,
91
- name: error.name,
92
- code: error.code,
93
- scope: error.scope,
94
- metadata: error.metadata
95
- }
96
- });
97
- }
98
- });
99
- bus.on('mongosh:evaluate-input', function (args) {
100
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000007), 'repl', 'Evaluating input', args);
101
- });
102
- bus.on('mongosh:use', function (args) {
103
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000008), 'shell-api', 'Used "use" command', args);
104
- if (telemetry) {
105
- analytics.track({
106
- userId,
107
- event: 'Use',
108
- properties: {
109
- mongosh_version
110
- }
111
- });
112
- }
113
- });
114
- bus.on('mongosh:show', function (args) {
115
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000009), 'shell-api', 'Used "show" command', args);
116
- if (telemetry) {
117
- analytics.track({
118
- userId,
119
- event: 'Show',
120
- properties: {
121
- mongosh_version,
122
- method: args.method
123
- }
124
- });
125
- }
126
- });
127
- bus.on('mongosh:setCtx', function (args) {
128
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000010), 'shell-api', 'Initialized context', args);
129
- });
130
- bus.on('mongosh:api-call', function (args) {
131
- let arg;
132
- try {
133
- arg = JSON.parse(JSON.stringify(args));
134
- }
135
- catch (_a) {
136
- arg = { _inspected: util_1.inspect(args) };
137
- }
138
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000011), 'shell-api', 'Performed API call', mongodb_redact_1.default(arg));
139
- });
140
- bus.on('mongosh:api-load-file', function (args) {
141
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000012), 'shell-api', 'Loading file via load()', args);
142
- if (telemetry) {
143
- analytics.track({
144
- userId,
145
- event: hasStartedMongoshRepl ? 'Script Loaded' : 'Script Loaded CLI',
146
- properties: {
147
- mongosh_version,
148
- nested: args.nested,
149
- ...(hasStartedMongoshRepl ? {} : { shell: usesShellOption })
150
- }
151
- });
152
- }
153
- });
154
- bus.on('mongosh:eval-cli-script', function () {
155
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000013), 'repl', 'Evaluating script passed on the command line');
156
- if (telemetry) {
157
- analytics.track({
158
- userId,
159
- event: 'Script Evaluated',
160
- properties: {
161
- mongosh_version,
162
- shell: usesShellOption
163
- }
164
- });
165
- }
166
- });
167
- bus.on('mongosh:mongoshrc-load', function () {
168
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000014), 'repl', 'Loading .mongoshrc.js');
169
- if (telemetry) {
170
- analytics.track({
171
- userId,
172
- event: 'Mongoshrc Loaded',
173
- properties: {
174
- mongosh_version
175
- }
176
- });
177
- }
178
- });
179
- bus.on('mongosh:mongoshrc-mongorc-warn', function () {
180
- log.info('MONGOSH', log_writer_1.mongoLogId(1000000015), 'repl', 'Warning about .mongorc.js/.mongoshrc.js mismatch');
181
- if (telemetry) {
182
- analytics.track({
183
- userId,
184
- event: 'Mongorc Warning',
185
- properties: {
186
- mongosh_version
187
- }
188
- });
189
- }
190
- });
191
- bus.on('mongosh:mongocryptd-tryspawn', function (ev) {
192
- log.info('MONGOCRYPTD', log_writer_1.mongoLogId(1000000016), 'mongocryptd', 'Trying to spawn mongocryptd', ev);
193
- });
194
- bus.on('mongosh:mongocryptd-error', function (ev) {
195
- log.warn('MONGOCRYPTD', log_writer_1.mongoLogId(1000000017), 'mongocryptd', 'Error running mongocryptd', ev);
196
- });
197
- bus.on('mongosh:mongocryptd-log', function (ev) {
198
- log.info('MONGOCRYPTD', log_writer_1.mongoLogId(1000000018), 'mongocryptd', 'mongocryptd log message', ev);
199
- });
200
- bus.on('mongosh-snippets:loaded', function (ev) {
201
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000019), 'snippets', 'Loaded snippets', ev);
202
- });
203
- bus.on('mongosh-snippets:npm-lookup', function (ev) {
204
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000020), 'snippets', 'Performing npm lookup', ev);
205
- });
206
- bus.on('mongosh-snippets:npm-lookup-stopped', function () {
207
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000021), 'snippets', 'npm lookup stopped');
208
- });
209
- bus.on('mongosh-snippets:npm-download-failed', function (ev) {
210
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000022), 'snippets', 'npm download failed', ev);
211
- });
212
- bus.on('mongosh-snippets:npm-download-active', function (ev) {
213
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000023), 'snippets', 'npm download active', ev);
214
- });
215
- bus.on('mongosh-snippets:fetch-index', function (ev) {
216
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000024), 'snippets', 'Fetching snippet index', ev);
217
- });
218
- bus.on('mongosh-snippets:fetch-cache-invalid', function () {
219
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000025), 'snippets', 'Snippet cache invalid');
220
- });
221
- bus.on('mongosh-snippets:fetch-index-error', function (ev) {
222
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000026), 'snippets', 'Fetching snippet index failed', ev);
223
- });
224
- bus.on('mongosh-snippets:fetch-index-done', function () {
225
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000027), 'snippets', 'Fetching snippet index done');
226
- });
227
- bus.on('mongosh-snippets:package-json-edit-error', function (ev) {
228
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000028), 'snippets', 'Modifying snippets package.json failed', ev);
229
- });
230
- bus.on('mongosh-snippets:spawn-child', function (ev) {
231
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000029), 'snippets', 'Spawning helper', ev);
232
- });
233
- bus.on('mongosh-snippets:load-snippet', function (ev) {
234
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000030), 'snippets', 'Loading snippet', ev);
235
- });
236
- bus.on('mongosh-snippets:snippet-command', function (ev) {
237
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000031), 'snippets', 'Running snippet command', ev);
238
- if (telemetry && ev.args[0] === 'install') {
239
- analytics.track({
240
- userId,
241
- event: 'Snippet Install',
242
- properties: {
243
- mongosh_version
244
- }
245
- });
246
- }
247
- });
248
- bus.on('mongosh-snippets:transform-error', function (ev) {
249
- log.info('MONGOSH-SNIPPETS', log_writer_1.mongoLogId(1000000032), 'snippets', 'Rewrote error message', ev);
250
- });
251
- const deprecatedApiCalls = new Set();
252
- bus.on('mongosh:deprecated-api-call', function (ev) {
253
- deprecatedApiCalls.add(`${ev.class}#${ev.method}`);
254
- });
255
- bus.on('mongosh:evaluate-finished', function () {
256
- deprecatedApiCalls.forEach(e => {
257
- const [clazz, method] = e.split('#');
258
- log.warn('MONGOSH', log_writer_1.mongoLogId(1000000033), 'shell-api', 'Deprecated API call', { class: clazz, method });
259
- if (telemetry) {
260
- analytics.track({
261
- userId,
262
- event: 'Deprecated Method',
263
- properties: {
264
- mongosh_version,
265
- class: clazz,
266
- method
267
- }
268
- });
269
- }
270
- });
271
- deprecatedApiCalls.clear();
272
- });
273
- bus.on('mongosh-sp:connect-heartbeat-failure', function (ev) {
274
- var _a;
275
- log.warn('MONGOSH-SP', log_writer_1.mongoLogId(1000000034), 'connect', 'Server heartbeat failure', {
276
- ...ev,
277
- failure: (_a = ev.failure) === null || _a === void 0 ? void 0 : _a.message
278
- });
279
- });
280
- bus.on('mongosh-sp:connect-heartbeat-succeeded', function (ev) {
281
- log.info('MONGOSH-SP', log_writer_1.mongoLogId(1000000035), 'connect', 'Server heartbeat succeeded', ev);
282
- });
283
- bus.on('mongosh-sp:connect-fail-early', function () {
284
- log.warn('MONGOSH-SP', log_writer_1.mongoLogId(1000000036), 'connect', 'Aborting connection attempt as irrecoverable');
285
- });
286
- bus.on('mongosh-sp:connect-attempt-finished', function () {
287
- log.info('MONGOSH-SP', log_writer_1.mongoLogId(1000000037), 'connect', 'Connection attempt finished');
288
- });
289
- bus.on('mongosh-sp:resolve-srv-error', function (ev) {
290
- var _a;
291
- log.error('MONGOSH-SP', log_writer_1.mongoLogId(1000000038), 'connect', 'Resolving SRV record failed', {
292
- from: history_1.redactURICredentials(ev.from),
293
- error: (_a = ev.error) === null || _a === void 0 ? void 0 : _a.message,
294
- duringLoad: ev.duringLoad
295
- });
296
- });
297
- bus.on('mongosh-sp:resolve-srv-succeeded', function (ev) {
298
- log.info('MONGOSH-SP', log_writer_1.mongoLogId(1000000039), 'connect', 'Resolving SRV record succeeded', {
299
- from: history_1.redactURICredentials(ev.from),
300
- to: history_1.redactURICredentials(ev.to)
301
- });
302
- });
303
- bus.on('mongosh-sp:reset-connection-options', function () {
304
- log.info('MONGOSH-SP', log_writer_1.mongoLogId(1000000040), 'connect', 'Reconnect because of changed connection options');
305
- });
306
- bus.on('mongosh-sp:missing-optional-dependency', function (ev) {
307
- log.error('MONGOSH-SP', log_writer_1.mongoLogId(1000000041), 'deps', 'Missing optional dependency', {
308
- name: ev.name,
309
- error: ev === null || ev === void 0 ? void 0 : ev.error.message
310
- });
311
- });
312
- }
313
- exports.default = setupLoggerAndTelemetry;
314
- //# sourceMappingURL=setup-logger-and-telemetry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"setup-logger-and-telemetry.js","sourceRoot":"","sources":["../src/setup-logger-and-telemetry.ts"],"names":[],"mappings":"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"}