@coralogix/rum-cli 1.1.17 → 1.1.18
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/.prettierrc +15 -0
- package/README.md +26 -19
- package/api/rum-api.ts +104 -91
- package/cli/commands/delete-source-maps-command.ts +34 -0
- package/cli/commands/index.ts +7 -0
- package/cli/commands/update-source-maps-command.ts +38 -0
- package/cli/commands/upload-source-maps-command.ts +38 -0
- package/cli/rum-cli.ts +13 -47
- package/cli/validators/index.ts +9 -10
- package/config/config.ts +21 -21
- package/consts/consts.ts +16 -0
- package/dist/api/rum-api.d.ts +4 -3
- package/dist/api/rum-api.js +60 -72
- package/dist/cli/commands/delete-source-maps-command.d.ts +2 -0
- package/dist/cli/commands/delete-source-maps-command.js +43 -0
- package/dist/cli/commands/index.d.ts +6 -0
- package/dist/cli/commands/index.js +8 -0
- package/dist/cli/commands/update-source-maps-command.d.ts +2 -0
- package/dist/cli/commands/update-source-maps-command.js +47 -0
- package/dist/cli/commands/upload-source-maps-command.d.ts +2 -0
- package/dist/cli/commands/upload-source-maps-command.js +47 -0
- package/dist/cli/rum-cli.js +14 -55
- package/dist/cli/validators/index.js +5 -6
- package/dist/config/config.js +6 -5
- package/dist/{cli/theme/index.d.ts → consts/consts.d.ts} +2 -0
- package/dist/consts/consts.js +16 -0
- package/dist/models/commands.model.d.ts +29 -0
- package/dist/models/commands.model.js +3 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_service.d.ts +88 -1
- package/dist/proto-models/com/coralogix/rum/v2/rum_service.js +228 -4
- package/dist/proto-models/com/coralogix/rum/v2/rum_session_recording_service.d.ts +65 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_session_recording_service.js +182 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.d.ts +92 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.js +271 -2
- package/dist/proto-models/com/coralogix/rum/v2/source_map_release.d.ts +13 -0
- package/dist/proto-models/com/coralogix/rum/v2/source_map_release.js +77 -2
- package/dist/services/source-maps.service.d.ts +5 -0
- package/dist/services/source-maps.service.js +80 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.js +115 -0
- package/models/commands.model.ts +31 -0
- package/package.json +5 -3
- package/proto-models/com/coralogix/rum/v2/rum_service.ts +268 -2
- package/proto-models/com/coralogix/rum/v2/rum_session_recording_service.ts +217 -0
- package/proto-models/com/coralogix/rum/v2/rum_source_map_service.ts +322 -0
- package/proto-models/com/coralogix/rum/v2/source_map_release.ts +90 -0
- package/protofetch.lock +2 -2
- package/protofetch.toml +1 -1
- package/protos/com/coralogix/rum/v2/rum_service.proto +16 -1
- package/protos/com/coralogix/rum/v2/rum_session_recording_service.proto +15 -0
- package/protos/com/coralogix/rum/v2/rum_source_map_service.proto +18 -0
- package/protos/com/coralogix/rum/v2/source_map_release.proto +6 -0
- package/protoset.bin +0 -0
- package/services/source-maps.service.ts +96 -0
- package/utils/index.ts +93 -0
- package/cli/consts/consts.ts +0 -2
- package/cli/theme/index.ts +0 -5
- package/dist/cli/consts/consts.d.ts +0 -2
- package/dist/cli/consts/consts.js +0 -6
- package/dist/cli/theme/index.js +0 -7
- package/dist/model/cli.model.d.ts +0 -1
- package/dist/model/cli.model.js +0 -12
- package/dist/services/source-maps/source-maps.service.d.ts +0 -3
- package/dist/services/source-maps/source-maps.service.js +0 -42
- package/dist/services/source-maps/utils/traverse-folder.util.d.ts +0 -2
- package/dist/services/source-maps/utils/traverse-folder.util.js +0 -42
- package/model/cli.model.ts +0 -8
- package/services/source-maps/source-maps.service.ts +0 -31
- package/services/source-maps/utils/traverse-folder.util.ts +0 -33
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare class SourceMapsService {
|
|
2
|
+
static upload(application: string, version: string, repoName: string | undefined, commitHash: string | undefined, orgName: string | undefined, folderPath: string, env: string, privateKey: string): Promise<void>;
|
|
3
|
+
static update(application: string, version: string, repoName: string | undefined, commitHash: string | undefined, orgName: string | undefined, folderPath: string, env: string, privateKey: string): Promise<void>;
|
|
4
|
+
static delete(application: string, version: string, env: string, privateKey: string): Promise<void>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SourceMapsService = void 0;
|
|
13
|
+
const rum_source_map_service_1 = require("../proto-models/com/coralogix/rum/v2/rum_source_map_service");
|
|
14
|
+
const rum_api_1 = require("../api/rum-api");
|
|
15
|
+
const consts_1 = require("../consts/consts");
|
|
16
|
+
const utils_1 = require("../utils");
|
|
17
|
+
class SourceMapsService {
|
|
18
|
+
static upload(application, version, repoName, commitHash, orgName, folderPath, env, privateKey) {
|
|
19
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20
|
+
const request = rum_source_map_service_1.UploadSourceMapsRequest.create();
|
|
21
|
+
request.application = application;
|
|
22
|
+
request.releaseId = version;
|
|
23
|
+
request.repoName = repoName;
|
|
24
|
+
request.commitHash = commitHash;
|
|
25
|
+
request.user = orgName;
|
|
26
|
+
console.log(consts_1.GRAY_COLOR, '🚀 Uploading source maps...');
|
|
27
|
+
try {
|
|
28
|
+
yield (0, utils_1.traverseFolder)(folderPath, request);
|
|
29
|
+
yield rum_api_1.RumApi.uploadSourceMaps(request, env, privateKey);
|
|
30
|
+
console.log(consts_1.GREEN_COLOR, '✅ Source maps uploaded successfully!');
|
|
31
|
+
console.log(consts_1.GREEN_COLOR, `✅ Total chunk files processed: ${request.files.length}`);
|
|
32
|
+
console.log(consts_1.GREEN_COLOR, '✅ Processing complete.');
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
console.log(consts_1.RED_COLOR, '❌ An error occurred');
|
|
36
|
+
console.error(consts_1.RED_COLOR, error);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
static update(application, version, repoName, commitHash, orgName, folderPath, env, privateKey) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const request = rum_source_map_service_1.UpdateSourceMapRequest.create();
|
|
43
|
+
request.application = application;
|
|
44
|
+
request.releaseId = version;
|
|
45
|
+
request.repoName = repoName;
|
|
46
|
+
request.commitHash = commitHash;
|
|
47
|
+
request.user = orgName;
|
|
48
|
+
console.log(consts_1.GRAY_COLOR, '🔄 Updating source maps...');
|
|
49
|
+
try {
|
|
50
|
+
yield (0, utils_1.traverseFolder)(folderPath, request);
|
|
51
|
+
yield rum_api_1.RumApi.updateSourceMap(request, env, privateKey);
|
|
52
|
+
console.log(consts_1.GREEN_COLOR, '✅ Source maps updated successfully!');
|
|
53
|
+
console.log(consts_1.GREEN_COLOR, `✅ Total chunk files processed: ${request.files.length}`);
|
|
54
|
+
console.log(consts_1.GREEN_COLOR, '✅ Processing complete.');
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
console.log(consts_1.RED_COLOR, '❌ An error occurred');
|
|
58
|
+
console.error(consts_1.RED_COLOR, error);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
static delete(application, version, env, privateKey) {
|
|
63
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
+
const request = rum_source_map_service_1.DeleteSourceMapRequest.create();
|
|
65
|
+
request.application = application;
|
|
66
|
+
request.releaseId = version;
|
|
67
|
+
console.log(consts_1.GRAY_COLOR, '🗑️ Deleting source maps...');
|
|
68
|
+
try {
|
|
69
|
+
yield rum_api_1.RumApi.deleteSourceMap(request, env, privateKey);
|
|
70
|
+
console.log(consts_1.GREEN_COLOR, '✅ Source maps deleted successfully!');
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
console.log(consts_1.RED_COLOR, '❌ An error occurred');
|
|
74
|
+
console.error(consts_1.RED_COLOR, error);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.SourceMapsService = SourceMapsService;
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlLW1hcHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NlcnZpY2VzL3NvdXJjZS1tYXBzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsd0dBSXFFO0FBQ3JFLDRDQUF3QztBQUN4Qyw2Q0FBc0U7QUFDdEUsb0NBQTBDO0FBRTFDLE1BQWEsaUJBQWlCO0lBQzVCLE1BQU0sQ0FBTyxNQUFNLENBQ2pCLFdBQW1CLEVBQ25CLE9BQWUsRUFDZixRQUE0QixFQUM1QixVQUE4QixFQUM5QixPQUEyQixFQUMzQixVQUFrQixFQUNsQixHQUFXLEVBQ1gsVUFBa0I7O1lBRWxCLE1BQU0sT0FBTyxHQUFHLGdEQUF1QixDQUFDLE1BQU0sRUFBRSxDQUFDO1lBRWpELE9BQU8sQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1lBQ2xDLE9BQU8sQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDO1lBQzVCLE9BQU8sQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1lBQzVCLE9BQU8sQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO1lBQ2hDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDO1lBRXZCLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQVUsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO1lBRXZELElBQUk7Z0JBQ0YsTUFBTSxJQUFBLHNCQUFjLEVBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO2dCQUUxQyxNQUFNLGdCQUFNLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztnQkFFeEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxvQkFBVyxFQUFFLHNDQUFzQyxDQUFDLENBQUM7Z0JBQ2pFLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0JBQVcsRUFBRSxrQ0FBa0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO2dCQUNuRixPQUFPLENBQUMsR0FBRyxDQUFDLG9CQUFXLEVBQUUsd0JBQXdCLENBQUMsQ0FBQzthQUNwRDtZQUFDLE9BQU8sS0FBSyxFQUFFO2dCQUNkLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQVMsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO2dCQUM5QyxPQUFPLENBQUMsS0FBSyxDQUFDLGtCQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7YUFDakM7UUFDSCxDQUFDO0tBQUE7SUFFRCxNQUFNLENBQU8sTUFBTSxDQUNqQixXQUFtQixFQUNuQixPQUFlLEVBQ2YsUUFBNEIsRUFDNUIsVUFBOEIsRUFDOUIsT0FBMkIsRUFDM0IsVUFBa0IsRUFDbEIsR0FBVyxFQUNYLFVBQWtCOztZQUVsQixNQUFNLE9BQU8sR0FBRywrQ0FBc0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUVoRCxPQUFPLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztZQUNsQyxPQUFPLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQztZQUM1QixPQUFPLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztZQUM1QixPQUFPLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztZQUNoQyxPQUFPLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQztZQUV2QixPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFVLEVBQUUsNEJBQTRCLENBQUMsQ0FBQztZQUV0RCxJQUFJO2dCQUNGLE1BQU0sSUFBQSxzQkFBYyxFQUFDLFVBQVUsRUFBRSxPQUFPLENBQUMsQ0FBQztnQkFFMUMsTUFBTSxnQkFBTSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO2dCQUV2RCxPQUFPLENBQUMsR0FBRyxDQUFDLG9CQUFXLEVBQUUscUNBQXFDLENBQUMsQ0FBQztnQkFDaEUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxvQkFBVyxFQUFFLGtDQUFrQyxPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7Z0JBQ25GLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0JBQVcsRUFBRSx3QkFBd0IsQ0FBQyxDQUFDO2FBQ3BEO1lBQUMsT0FBTyxLQUFLLEVBQUU7Z0JBQ2QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBUyxFQUFFLHFCQUFxQixDQUFDLENBQUM7Z0JBQzlDLE9BQU8sQ0FBQyxLQUFLLENBQUMsa0JBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQzthQUNqQztRQUNILENBQUM7S0FBQTtJQUVELE1BQU0sQ0FBTyxNQUFNLENBQUMsV0FBbUIsRUFBRSxPQUFlLEVBQUUsR0FBVyxFQUFFLFVBQWtCOztZQUN2RixNQUFNLE9BQU8sR0FBRywrQ0FBc0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUVoRCxPQUFPLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztZQUNsQyxPQUFPLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQztZQUU1QixPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFVLEVBQUUsNkJBQTZCLENBQUMsQ0FBQztZQUV2RCxJQUFJO2dCQUNGLE1BQU0sZ0JBQU0sQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztnQkFFdkQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxvQkFBVyxFQUFFLHFDQUFxQyxDQUFDLENBQUM7YUFDakU7WUFBQyxPQUFPLEtBQUssRUFBRTtnQkFDZCxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFTLEVBQUUscUJBQXFCLENBQUMsQ0FBQztnQkFDOUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO2FBQ2pDO1FBQ0gsQ0FBQztLQUFBO0NBQ0Y7QUF0RkQsOENBc0ZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVsZXRlU291cmNlTWFwUmVxdWVzdCxcbiAgVXBkYXRlU291cmNlTWFwUmVxdWVzdCxcbiAgVXBsb2FkU291cmNlTWFwc1JlcXVlc3QsXG59IGZyb20gJy4uL3Byb3RvLW1vZGVscy9jb20vY29yYWxvZ2l4L3J1bS92Mi9ydW1fc291cmNlX21hcF9zZXJ2aWNlJztcbmltcG9ydCB7IFJ1bUFwaSB9IGZyb20gJy4uL2FwaS9ydW0tYXBpJztcbmltcG9ydCB7IEdSQVlfQ09MT1IsIEdSRUVOX0NPTE9SLCBSRURfQ09MT1IgfSBmcm9tICcuLi9jb25zdHMvY29uc3RzJztcbmltcG9ydCB7IHRyYXZlcnNlRm9sZGVyIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY2xhc3MgU291cmNlTWFwc1NlcnZpY2Uge1xuICBzdGF0aWMgYXN5bmMgdXBsb2FkKFxuICAgIGFwcGxpY2F0aW9uOiBzdHJpbmcsXG4gICAgdmVyc2lvbjogc3RyaW5nLFxuICAgIHJlcG9OYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICAgY29tbWl0SGFzaDogc3RyaW5nIHwgdW5kZWZpbmVkLFxuICAgIG9yZ05hbWU6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBmb2xkZXJQYXRoOiBzdHJpbmcsXG4gICAgZW52OiBzdHJpbmcsXG4gICAgcHJpdmF0ZUtleTogc3RyaW5nLFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCByZXF1ZXN0ID0gVXBsb2FkU291cmNlTWFwc1JlcXVlc3QuY3JlYXRlKCk7XG5cbiAgICByZXF1ZXN0LmFwcGxpY2F0aW9uID0gYXBwbGljYXRpb247XG4gICAgcmVxdWVzdC5yZWxlYXNlSWQgPSB2ZXJzaW9uO1xuICAgIHJlcXVlc3QucmVwb05hbWUgPSByZXBvTmFtZTtcbiAgICByZXF1ZXN0LmNvbW1pdEhhc2ggPSBjb21taXRIYXNoO1xuICAgIHJlcXVlc3QudXNlciA9IG9yZ05hbWU7XG5cbiAgICBjb25zb2xlLmxvZyhHUkFZX0NPTE9SLCAn8J+agCBVcGxvYWRpbmcgc291cmNlIG1hcHMuLi4nKTtcblxuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0cmF2ZXJzZUZvbGRlcihmb2xkZXJQYXRoLCByZXF1ZXN0KTtcblxuICAgICAgYXdhaXQgUnVtQXBpLnVwbG9hZFNvdXJjZU1hcHMocmVxdWVzdCwgZW52LCBwcml2YXRlS2V5KTtcblxuICAgICAgY29uc29sZS5sb2coR1JFRU5fQ09MT1IsICfinIUgU291cmNlIG1hcHMgdXBsb2FkZWQgc3VjY2Vzc2Z1bGx5IScpO1xuICAgICAgY29uc29sZS5sb2coR1JFRU5fQ09MT1IsIGDinIUgVG90YWwgY2h1bmsgZmlsZXMgcHJvY2Vzc2VkOiAke3JlcXVlc3QuZmlsZXMubGVuZ3RofWApO1xuICAgICAgY29uc29sZS5sb2coR1JFRU5fQ09MT1IsICfinIUgUHJvY2Vzc2luZyBjb21wbGV0ZS4nKTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS5sb2coUkVEX0NPTE9SLCAn4p2MIEFuIGVycm9yIG9jY3VycmVkJyk7XG4gICAgICBjb25zb2xlLmVycm9yKFJFRF9DT0xPUiwgZXJyb3IpO1xuICAgIH1cbiAgfVxuXG4gIHN0YXRpYyBhc3luYyB1cGRhdGUoXG4gICAgYXBwbGljYXRpb246IHN0cmluZyxcbiAgICB2ZXJzaW9uOiBzdHJpbmcsXG4gICAgcmVwb05hbWU6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBjb21taXRIYXNoOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICAgb3JnTmFtZTogc3RyaW5nIHwgdW5kZWZpbmVkLFxuICAgIGZvbGRlclBhdGg6IHN0cmluZyxcbiAgICBlbnY6IHN0cmluZyxcbiAgICBwcml2YXRlS2V5OiBzdHJpbmcsXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IHJlcXVlc3QgPSBVcGRhdGVTb3VyY2VNYXBSZXF1ZXN0LmNyZWF0ZSgpO1xuXG4gICAgcmVxdWVzdC5hcHBsaWNhdGlvbiA9IGFwcGxpY2F0aW9uO1xuICAgIHJlcXVlc3QucmVsZWFzZUlkID0gdmVyc2lvbjtcbiAgICByZXF1ZXN0LnJlcG9OYW1lID0gcmVwb05hbWU7XG4gICAgcmVxdWVzdC5jb21taXRIYXNoID0gY29tbWl0SGFzaDtcbiAgICByZXF1ZXN0LnVzZXIgPSBvcmdOYW1lO1xuXG4gICAgY29uc29sZS5sb2coR1JBWV9DT0xPUiwgJ/CflIQgVXBkYXRpbmcgc291cmNlIG1hcHMuLi4nKTtcblxuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0cmF2ZXJzZUZvbGRlcihmb2xkZXJQYXRoLCByZXF1ZXN0KTtcblxuICAgICAgYXdhaXQgUnVtQXBpLnVwZGF0ZVNvdXJjZU1hcChyZXF1ZXN0LCBlbnYsIHByaXZhdGVLZXkpO1xuXG4gICAgICBjb25zb2xlLmxvZyhHUkVFTl9DT0xPUiwgJ+KchSBTb3VyY2UgbWFwcyB1cGRhdGVkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgICAgIGNvbnNvbGUubG9nKEdSRUVOX0NPTE9SLCBg4pyFIFRvdGFsIGNodW5rIGZpbGVzIHByb2Nlc3NlZDogJHtyZXF1ZXN0LmZpbGVzLmxlbmd0aH1gKTtcbiAgICAgIGNvbnNvbGUubG9nKEdSRUVOX0NPTE9SLCAn4pyFIFByb2Nlc3NpbmcgY29tcGxldGUuJyk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUubG9nKFJFRF9DT0xPUiwgJ+KdjCBBbiBlcnJvciBvY2N1cnJlZCcpO1xuICAgICAgY29uc29sZS5lcnJvcihSRURfQ09MT1IsIGVycm9yKTtcbiAgICB9XG4gIH1cblxuICBzdGF0aWMgYXN5bmMgZGVsZXRlKGFwcGxpY2F0aW9uOiBzdHJpbmcsIHZlcnNpb246IHN0cmluZywgZW52OiBzdHJpbmcsIHByaXZhdGVLZXk6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IHJlcXVlc3QgPSBEZWxldGVTb3VyY2VNYXBSZXF1ZXN0LmNyZWF0ZSgpO1xuXG4gICAgcmVxdWVzdC5hcHBsaWNhdGlvbiA9IGFwcGxpY2F0aW9uO1xuICAgIHJlcXVlc3QucmVsZWFzZUlkID0gdmVyc2lvbjtcblxuICAgIGNvbnNvbGUubG9nKEdSQVlfQ09MT1IsICfwn5eR77iPIERlbGV0aW5nIHNvdXJjZSBtYXBzLi4uJyk7XG5cbiAgICB0cnkge1xuICAgICAgYXdhaXQgUnVtQXBpLmRlbGV0ZVNvdXJjZU1hcChyZXF1ZXN0LCBlbnYsIHByaXZhdGVLZXkpO1xuXG4gICAgICBjb25zb2xlLmxvZyhHUkVFTl9DT0xPUiwgJ+KchSBTb3VyY2UgbWFwcyBkZWxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS5sb2coUkVEX0NPTE9SLCAn4p2MIEFuIGVycm9yIG9jY3VycmVkJyk7XG4gICAgICBjb25zb2xlLmVycm9yKFJFRF9DT0xPUiwgZXJyb3IpO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { UploadSourceMapsRequest } from '../proto-models/com/coralogix/rum/v2/rum_source_map_service';
|
|
2
|
+
import { FileMetadata } from '../proto-models/com/coralogix/rum/v2/file';
|
|
3
|
+
export declare const traverseFolder: (folderPath: string, request: UploadSourceMapsRequest) => Promise<void>;
|
|
4
|
+
export declare const compressFileContentChunks: (fileContent: Uint8Array) => Uint8Array;
|
|
5
|
+
export declare const validateCompressedFilesSize: (compressedFiles: FileMetadata[], maxCompressedFilesSize: number) => void;
|
|
6
|
+
export declare const checkMissingArguments: <T>(options: T, requiredArgs: (keyof T)[]) => void;
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
+
};
|
|
37
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
+
exports.checkMissingArguments = exports.validateCompressedFilesSize = exports.compressFileContentChunks = exports.traverseFolder = void 0;
|
|
39
|
+
const pako = __importStar(require("pako"));
|
|
40
|
+
const fs_1 = require("fs");
|
|
41
|
+
const config_1 = __importDefault(require("../config"));
|
|
42
|
+
const path = __importStar(require("path"));
|
|
43
|
+
const consts_1 = require("../consts/consts");
|
|
44
|
+
const { readdir, stat, readFile } = fs_1.promises;
|
|
45
|
+
const traverseFolder = (folderPath, request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
46
|
+
const stack = [folderPath];
|
|
47
|
+
while (stack.length) {
|
|
48
|
+
const currentPath = stack.pop();
|
|
49
|
+
const entries = yield readdir(currentPath, { withFileTypes: true });
|
|
50
|
+
yield Promise.all(entries.map((file) => __awaiter(void 0, void 0, void 0, function* () {
|
|
51
|
+
const { name } = file;
|
|
52
|
+
const entryPath = path.join(currentPath, name);
|
|
53
|
+
const isDotMapFile = file.isFile() && name.endsWith('.js.map');
|
|
54
|
+
if (file.isDirectory())
|
|
55
|
+
stack.push(entryPath);
|
|
56
|
+
else if (isDotMapFile)
|
|
57
|
+
request.files.push(yield getFileMetadata(entryPath));
|
|
58
|
+
})));
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
exports.traverseFolder = traverseFolder;
|
|
62
|
+
const getFileMetadata = (filePath) => __awaiter(void 0, void 0, void 0, function* () {
|
|
63
|
+
const { size } = yield stat(filePath);
|
|
64
|
+
const { name } = path.parse(filePath);
|
|
65
|
+
const content = yield readFile(filePath);
|
|
66
|
+
return { chunkName: name, size, content };
|
|
67
|
+
});
|
|
68
|
+
const compressFileContentChunks = (fileContent) => {
|
|
69
|
+
const { chunkSize } = config_1.default.rumApi; // 512 KB chunk size
|
|
70
|
+
const deflate = new pako.Deflate();
|
|
71
|
+
const totalChunks = Math.ceil(fileContent.length / chunkSize);
|
|
72
|
+
for (let i = 0; i < totalChunks; i++) {
|
|
73
|
+
const start = i * chunkSize;
|
|
74
|
+
const end = start + chunkSize;
|
|
75
|
+
const chunk = fileContent.subarray(start, end);
|
|
76
|
+
const isLastChunk = i === totalChunks - 1;
|
|
77
|
+
deflate.push(chunk, isLastChunk);
|
|
78
|
+
}
|
|
79
|
+
const { err, msg, result } = deflate;
|
|
80
|
+
if (err)
|
|
81
|
+
console.error(consts_1.RED_COLOR, msg);
|
|
82
|
+
return result;
|
|
83
|
+
};
|
|
84
|
+
exports.compressFileContentChunks = compressFileContentChunks;
|
|
85
|
+
const validateCompressedFilesSize = (compressedFiles, maxCompressedFilesSize) => {
|
|
86
|
+
const compressedFilesSize = compressedFiles.reduce((sum, file) => sum + file.content.length, 0);
|
|
87
|
+
if (compressedFilesSize > maxCompressedFilesSize) {
|
|
88
|
+
// Convert sizes to megabytes (MB)
|
|
89
|
+
const compressedFilesSizeMB = (compressedFilesSize / consts_1.MB).toFixed(2);
|
|
90
|
+
const maxCompressedFilesSizeMB = (maxCompressedFilesSize / consts_1.MB).toFixed(2);
|
|
91
|
+
const errorMessage = `
|
|
92
|
+
❌ Error: The total size of compressed files exceeds the maximum allowed size.
|
|
93
|
+
Total Compressed Files Size: ${compressedFilesSizeMB} MB
|
|
94
|
+
Maximum Allowed Size: ${maxCompressedFilesSizeMB} MB
|
|
95
|
+
`;
|
|
96
|
+
console.error(consts_1.RED_COLOR, errorMessage);
|
|
97
|
+
process.exit(1);
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
exports.validateCompressedFilesSize = validateCompressedFilesSize;
|
|
101
|
+
const checkMissingArguments = (options, requiredArgs) => {
|
|
102
|
+
const missingArgs = [];
|
|
103
|
+
requiredArgs.forEach((arg) => {
|
|
104
|
+
if (!options[arg])
|
|
105
|
+
missingArgs.push(arg);
|
|
106
|
+
});
|
|
107
|
+
if (missingArgs.length > 0) {
|
|
108
|
+
const missingArgsList = missingArgs.map(arg => `- ${arg}`).join('\n');
|
|
109
|
+
const errorMessage = `❌ Missing required arguments:\n${missingArgsList}\nPlease provide the necessary options`;
|
|
110
|
+
console.error(consts_1.RED_COLOR, errorMessage);
|
|
111
|
+
process.exit(1);
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
exports.checkMissingArguments = checkMissingArguments;
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAC7B,2BAAoD;AAEpD,uDAA+B;AAC/B,2CAA6B;AAC7B,6CAAiD;AAGjD,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,aAAU,CAAC;AAExC,MAAM,cAAc,GAAG,CAAO,UAAkB,EAAE,OAAgC,EAAiB,EAAE;IAC1G,MAAM,KAAK,GAAa,CAAC,UAAU,CAAC,CAAC;IAErC,OAAO,KAAK,CAAC,MAAM,EAAE;QACnB,MAAM,WAAW,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC;QAChC,MAAM,OAAO,GAAa,MAAM,OAAO,CAAC,WAAY,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAE/E,MAAM,OAAO,CAAC,GAAG,CACf,OAAO,CAAC,GAAG,CAAC,CAAO,IAAY,EAAE,EAAE;YACjC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC;YACtB,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,WAAqB,EAAE,IAAI,CAAC,CAAC;YACzD,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAE/D,IAAI,IAAI,CAAC,WAAW,EAAE;gBAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;iBACzC,IAAI,YAAY;gBAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC;QAC9E,CAAC,CAAA,CAAC,CACH,CAAC;KACH;AACH,CAAC,CAAA,CAAC;AAlBW,QAAA,cAAc,kBAkBzB;AAEF,MAAM,eAAe,GAAG,CAAO,QAAgB,EAAyB,EAAE;IACxE,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAEzC,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;AAC5C,CAAC,CAAA,CAAC;AAEK,MAAM,yBAAyB,GAAG,CAAC,WAAuB,EAAc,EAAE;IAC/E,MAAM,EAAE,SAAS,EAAE,GAAG,gBAAM,CAAC,MAAM,CAAC,CAAC,oBAAoB;IACzD,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;IACnC,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;IAE9D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,EAAE,EAAE;QACpC,MAAM,KAAK,GAAG,CAAC,GAAG,SAAS,CAAC;QAC5B,MAAM,GAAG,GAAG,KAAK,GAAG,SAAS,CAAC;QAC9B,MAAM,KAAK,GAAG,WAAW,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAE/C,MAAM,WAAW,GAAG,CAAC,KAAK,WAAW,GAAG,CAAC,CAAC;QAE1C,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;KAClC;IAED,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;IAErC,IAAI,GAAG;QAAE,OAAO,CAAC,KAAK,CAAC,kBAAS,EAAE,GAAG,CAAC,CAAC;IAEvC,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AApBW,QAAA,yBAAyB,6BAoBpC;AAEK,MAAM,2BAA2B,GAAG,CAAC,eAA+B,EAAE,sBAA8B,EAAQ,EAAE;IACnH,MAAM,mBAAmB,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAEhG,IAAI,mBAAmB,GAAG,sBAAsB,EAAE;QAChD,kCAAkC;QAClC,MAAM,qBAAqB,GAAW,CAAC,mBAAmB,GAAG,WAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,wBAAwB,GAAW,CAAC,sBAAsB,GAAG,WAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAElF,MAAM,YAAY,GAAG;;2CAEkB,qBAAqB;oCAC5B,wBAAwB;aAC/C,CAAC;QAEV,OAAO,CAAC,KAAK,CAAC,kBAAS,EAAE,YAAY,CAAC,CAAC;QACvC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KACjB;AACH,CAAC,CAAC;AAjBW,QAAA,2BAA2B,+BAiBtC;AAEK,MAAM,qBAAqB,GAAG,CAAI,OAAU,EAAE,YAAyB,EAAQ,EAAE;IACtF,MAAM,WAAW,GAAa,EAAE,CAAC;IAEjC,YAAY,CAAC,OAAO,CAAC,CAAC,GAAY,EAAE,EAAE;QACpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;YAAE,WAAW,CAAC,IAAI,CAAC,GAAa,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;QAC1B,MAAM,eAAe,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtE,MAAM,YAAY,GAAG,kCAAkC,eAAe,wCAAwC,CAAC;QAC/G,OAAO,CAAC,KAAK,CAAC,kBAAS,EAAE,YAAY,CAAC,CAAC;QACvC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KACjB;AACH,CAAC,CAAC;AAbW,QAAA,qBAAqB,yBAahC","sourcesContent":["import * as pako from 'pako';\nimport { Dirent, promises as fsPromises } from 'fs';\nimport { UploadSourceMapsRequest } from '../proto-models/com/coralogix/rum/v2/rum_source_map_service';\nimport config from '../config';\nimport * as path from 'path';\nimport { MB, RED_COLOR } from '../consts/consts';\nimport { FileMetadata } from '../proto-models/com/coralogix/rum/v2/file';\n\nconst { readdir, stat, readFile } = fsPromises;\n\nexport const traverseFolder = async (folderPath: string, request: UploadSourceMapsRequest): Promise<void> => {\n  const stack: string[] = [folderPath];\n\n  while (stack.length) {\n    const currentPath = stack.pop();\n    const entries: Dirent[] = await readdir(currentPath!, { withFileTypes: true });\n\n    await Promise.all(\n      entries.map(async (file: Dirent) => {\n        const { name } = file;\n        const entryPath = path.join(currentPath as string, name);\n        const isDotMapFile = file.isFile() && name.endsWith('.js.map');\n\n        if (file.isDirectory()) stack.push(entryPath);\n        else if (isDotMapFile) request.files.push(await getFileMetadata(entryPath));\n      }),\n    );\n  }\n};\n\nconst getFileMetadata = async (filePath: string): Promise<FileMetadata> => {\n  const { size } = await stat(filePath);\n  const { name } = path.parse(filePath);\n  const content = await readFile(filePath);\n\n  return { chunkName: name, size, content };\n};\n\nexport const compressFileContentChunks = (fileContent: Uint8Array): Uint8Array => {\n  const { chunkSize } = config.rumApi; // 512 KB chunk size\n  const deflate = new pako.Deflate();\n  const totalChunks = Math.ceil(fileContent.length / chunkSize);\n\n  for (let i = 0; i < totalChunks; i++) {\n    const start = i * chunkSize;\n    const end = start + chunkSize;\n    const chunk = fileContent.subarray(start, end);\n\n    const isLastChunk = i === totalChunks - 1;\n\n    deflate.push(chunk, isLastChunk);\n  }\n\n  const { err, msg, result } = deflate;\n\n  if (err) console.error(RED_COLOR, msg);\n\n  return result;\n};\n\nexport const validateCompressedFilesSize = (compressedFiles: FileMetadata[], maxCompressedFilesSize: number): void => {\n  const compressedFilesSize = compressedFiles.reduce((sum, file) => sum + file.content.length, 0);\n\n  if (compressedFilesSize > maxCompressedFilesSize) {\n    // Convert sizes to megabytes (MB)\n    const compressedFilesSizeMB: string = (compressedFilesSize / MB).toFixed(2);\n    const maxCompressedFilesSizeMB: string = (maxCompressedFilesSize / MB).toFixed(2);\n\n    const errorMessage = `\n            ❌ Error: The total size of compressed files exceeds the maximum allowed size.\n            Total Compressed Files Size: ${compressedFilesSizeMB} MB\n            Maximum Allowed Size: ${maxCompressedFilesSizeMB} MB\n            `;\n\n    console.error(RED_COLOR, errorMessage);\n    process.exit(1);\n  }\n};\n\nexport const checkMissingArguments = <T>(options: T, requiredArgs: (keyof T)[]): void => {\n  const missingArgs: string[] = [];\n\n  requiredArgs.forEach((arg: keyof T) => {\n    if (!options[arg]) missingArgs.push(arg as string);\n  });\n\n  if (missingArgs.length > 0) {\n    const missingArgsList = missingArgs.map(arg => `- ${arg}`).join('\\n');\n    const errorMessage = `❌ Missing required arguments:\\n${missingArgsList}\\nPlease provide the necessary options`;\n    console.error(RED_COLOR, errorMessage);\n    process.exit(1);\n  }\n};\n"]}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export interface DeleteCommandOptions {
|
|
2
|
+
privateKey: string;
|
|
3
|
+
application: string;
|
|
4
|
+
version: string;
|
|
5
|
+
env: string;
|
|
6
|
+
help?: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface UpdateCommandOptions {
|
|
10
|
+
privateKey: string;
|
|
11
|
+
application: string;
|
|
12
|
+
version: string;
|
|
13
|
+
folderPath: string;
|
|
14
|
+
commitHash?: string;
|
|
15
|
+
repoName?: string;
|
|
16
|
+
orgName?: string;
|
|
17
|
+
env: string;
|
|
18
|
+
help?: string;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface UploadCommandOptions {
|
|
22
|
+
privateKey: string;
|
|
23
|
+
application: string;
|
|
24
|
+
version: string;
|
|
25
|
+
folderPath: string;
|
|
26
|
+
commitHash?: string;
|
|
27
|
+
repoName?: string;
|
|
28
|
+
orgName?: string;
|
|
29
|
+
env: string;
|
|
30
|
+
help?: string;
|
|
31
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@coralogix/rum-cli",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.18",
|
|
4
4
|
"description": "corlogix rum cli",
|
|
5
5
|
"bin": {
|
|
6
6
|
"coralogix-rum-cli": "dist/cli/rum-cli.js"
|
|
@@ -12,7 +12,8 @@
|
|
|
12
12
|
"build": "rm -rf ./dist/* && tsc -p tsconfig.build.json",
|
|
13
13
|
"start": "ts-node cli/rum-cli.ts",
|
|
14
14
|
"proto": "npm run proto:generate",
|
|
15
|
-
"proto:generate": "./generate-protos.sh"
|
|
15
|
+
"proto:generate": "./generate-protos.sh",
|
|
16
|
+
"format:ts": "prettier --write \"**/*.ts\""
|
|
16
17
|
},
|
|
17
18
|
"dependencies": {
|
|
18
19
|
"bunyan": "^1.8.15",
|
|
@@ -34,7 +35,8 @@
|
|
|
34
35
|
"grpc-tools": "^1.11.2",
|
|
35
36
|
"ts-node": "10.6.0",
|
|
36
37
|
"ts-proto": "^1.104.0",
|
|
37
|
-
"typescript": "^4.9.5"
|
|
38
|
+
"typescript": "^4.9.5",
|
|
39
|
+
"prettier": "^2.8.7"
|
|
38
40
|
},
|
|
39
41
|
"lint-staged": {
|
|
40
42
|
"*.ts": [
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import Long from "long";
|
|
3
3
|
import _m0 from "protobufjs/minimal";
|
|
4
4
|
import { Chunk, MappedChunk } from "./chunk";
|
|
5
|
-
import { SourceMapRelease } from "./source_map_release";
|
|
5
|
+
import { ReleasePoint, SourceMapRelease } from "./source_map_release";
|
|
6
6
|
import { Filter, TemplateResult } from "./template";
|
|
7
7
|
|
|
8
8
|
export const protobufPackage = "com.coralogix.rum.v2";
|
|
@@ -29,6 +29,7 @@ export interface GetRumTemplatesRequest {
|
|
|
29
29
|
metadataFilters: Filter[];
|
|
30
30
|
isArchive: boolean;
|
|
31
31
|
freeText?: string | undefined;
|
|
32
|
+
luceneQuery?: string | undefined;
|
|
32
33
|
}
|
|
33
34
|
|
|
34
35
|
export interface GetRumTemplatesResponse {
|
|
@@ -44,6 +45,20 @@ export interface GetSourceMapReleasesResponse {
|
|
|
44
45
|
sourceMapReleases: SourceMapRelease[];
|
|
45
46
|
}
|
|
46
47
|
|
|
48
|
+
export interface GetSourceMapReleasesInternalRequest {
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export interface GetSourceMapReleasesInternalResponse {
|
|
52
|
+
releases: SourceMapRelease[];
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export interface GetReleasesSeriesPointsRequest {
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export interface GetReleasesSeriesPointsResponse {
|
|
59
|
+
releasesPoints: ReleasePoint[];
|
|
60
|
+
}
|
|
61
|
+
|
|
47
62
|
function createBaseGetMappedStackTraceRequest(): GetMappedStackTraceRequest {
|
|
48
63
|
return { application: "", releaseId: "", chunks: [] };
|
|
49
64
|
}
|
|
@@ -269,7 +284,15 @@ export const GetMappedStackTraceResponse = {
|
|
|
269
284
|
};
|
|
270
285
|
|
|
271
286
|
function createBaseGetRumTemplatesRequest(): GetRumTemplatesRequest {
|
|
272
|
-
return {
|
|
287
|
+
return {
|
|
288
|
+
startTime: 0,
|
|
289
|
+
endTime: 0,
|
|
290
|
+
dataFilters: [],
|
|
291
|
+
metadataFilters: [],
|
|
292
|
+
isArchive: false,
|
|
293
|
+
freeText: undefined,
|
|
294
|
+
luceneQuery: undefined,
|
|
295
|
+
};
|
|
273
296
|
}
|
|
274
297
|
|
|
275
298
|
export const GetRumTemplatesRequest = {
|
|
@@ -292,6 +315,9 @@ export const GetRumTemplatesRequest = {
|
|
|
292
315
|
if (message.freeText !== undefined) {
|
|
293
316
|
writer.uint32(50).string(message.freeText);
|
|
294
317
|
}
|
|
318
|
+
if (message.luceneQuery !== undefined) {
|
|
319
|
+
writer.uint32(58).string(message.luceneQuery);
|
|
320
|
+
}
|
|
295
321
|
return writer;
|
|
296
322
|
},
|
|
297
323
|
|
|
@@ -344,6 +370,13 @@ export const GetRumTemplatesRequest = {
|
|
|
344
370
|
|
|
345
371
|
message.freeText = reader.string();
|
|
346
372
|
continue;
|
|
373
|
+
case 7:
|
|
374
|
+
if (tag !== 58) {
|
|
375
|
+
break;
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
message.luceneQuery = reader.string();
|
|
379
|
+
continue;
|
|
347
380
|
}
|
|
348
381
|
if ((tag & 7) === 4 || tag === 0) {
|
|
349
382
|
break;
|
|
@@ -363,6 +396,7 @@ export const GetRumTemplatesRequest = {
|
|
|
363
396
|
: [],
|
|
364
397
|
isArchive: isSet(object.isArchive) ? Boolean(object.isArchive) : false,
|
|
365
398
|
freeText: isSet(object.freeText) ? String(object.freeText) : undefined,
|
|
399
|
+
luceneQuery: isSet(object.luceneQuery) ? String(object.luceneQuery) : undefined,
|
|
366
400
|
};
|
|
367
401
|
},
|
|
368
402
|
|
|
@@ -382,6 +416,7 @@ export const GetRumTemplatesRequest = {
|
|
|
382
416
|
}
|
|
383
417
|
message.isArchive !== undefined && (obj.isArchive = message.isArchive);
|
|
384
418
|
message.freeText !== undefined && (obj.freeText = message.freeText);
|
|
419
|
+
message.luceneQuery !== undefined && (obj.luceneQuery = message.luceneQuery);
|
|
385
420
|
return obj;
|
|
386
421
|
},
|
|
387
422
|
|
|
@@ -397,6 +432,7 @@ export const GetRumTemplatesRequest = {
|
|
|
397
432
|
message.metadataFilters = object.metadataFilters?.map((e) => Filter.fromPartial(e)) || [];
|
|
398
433
|
message.isArchive = object.isArchive ?? false;
|
|
399
434
|
message.freeText = object.freeText ?? undefined;
|
|
435
|
+
message.luceneQuery = object.luceneQuery ?? undefined;
|
|
400
436
|
return message;
|
|
401
437
|
},
|
|
402
438
|
};
|
|
@@ -596,6 +632,220 @@ export const GetSourceMapReleasesResponse = {
|
|
|
596
632
|
},
|
|
597
633
|
};
|
|
598
634
|
|
|
635
|
+
function createBaseGetSourceMapReleasesInternalRequest(): GetSourceMapReleasesInternalRequest {
|
|
636
|
+
return {};
|
|
637
|
+
}
|
|
638
|
+
|
|
639
|
+
export const GetSourceMapReleasesInternalRequest = {
|
|
640
|
+
encode(_: GetSourceMapReleasesInternalRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
|
641
|
+
return writer;
|
|
642
|
+
},
|
|
643
|
+
|
|
644
|
+
decode(input: _m0.Reader | Uint8Array, length?: number): GetSourceMapReleasesInternalRequest {
|
|
645
|
+
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
646
|
+
let end = length === undefined ? reader.len : reader.pos + length;
|
|
647
|
+
const message = createBaseGetSourceMapReleasesInternalRequest();
|
|
648
|
+
while (reader.pos < end) {
|
|
649
|
+
const tag = reader.uint32();
|
|
650
|
+
switch (tag >>> 3) {
|
|
651
|
+
}
|
|
652
|
+
if ((tag & 7) === 4 || tag === 0) {
|
|
653
|
+
break;
|
|
654
|
+
}
|
|
655
|
+
reader.skipType(tag & 7);
|
|
656
|
+
}
|
|
657
|
+
return message;
|
|
658
|
+
},
|
|
659
|
+
|
|
660
|
+
fromJSON(_: any): GetSourceMapReleasesInternalRequest {
|
|
661
|
+
return {};
|
|
662
|
+
},
|
|
663
|
+
|
|
664
|
+
toJSON(_: GetSourceMapReleasesInternalRequest): unknown {
|
|
665
|
+
const obj: any = {};
|
|
666
|
+
return obj;
|
|
667
|
+
},
|
|
668
|
+
|
|
669
|
+
create(base?: DeepPartial<GetSourceMapReleasesInternalRequest>): GetSourceMapReleasesInternalRequest {
|
|
670
|
+
return GetSourceMapReleasesInternalRequest.fromPartial(base ?? {});
|
|
671
|
+
},
|
|
672
|
+
|
|
673
|
+
fromPartial(_: DeepPartial<GetSourceMapReleasesInternalRequest>): GetSourceMapReleasesInternalRequest {
|
|
674
|
+
const message = createBaseGetSourceMapReleasesInternalRequest();
|
|
675
|
+
return message;
|
|
676
|
+
},
|
|
677
|
+
};
|
|
678
|
+
|
|
679
|
+
function createBaseGetSourceMapReleasesInternalResponse(): GetSourceMapReleasesInternalResponse {
|
|
680
|
+
return { releases: [] };
|
|
681
|
+
}
|
|
682
|
+
|
|
683
|
+
export const GetSourceMapReleasesInternalResponse = {
|
|
684
|
+
encode(message: GetSourceMapReleasesInternalResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
|
685
|
+
for (const v of message.releases) {
|
|
686
|
+
SourceMapRelease.encode(v!, writer.uint32(10).fork()).ldelim();
|
|
687
|
+
}
|
|
688
|
+
return writer;
|
|
689
|
+
},
|
|
690
|
+
|
|
691
|
+
decode(input: _m0.Reader | Uint8Array, length?: number): GetSourceMapReleasesInternalResponse {
|
|
692
|
+
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
693
|
+
let end = length === undefined ? reader.len : reader.pos + length;
|
|
694
|
+
const message = createBaseGetSourceMapReleasesInternalResponse();
|
|
695
|
+
while (reader.pos < end) {
|
|
696
|
+
const tag = reader.uint32();
|
|
697
|
+
switch (tag >>> 3) {
|
|
698
|
+
case 1:
|
|
699
|
+
if (tag !== 10) {
|
|
700
|
+
break;
|
|
701
|
+
}
|
|
702
|
+
|
|
703
|
+
message.releases.push(SourceMapRelease.decode(reader, reader.uint32()));
|
|
704
|
+
continue;
|
|
705
|
+
}
|
|
706
|
+
if ((tag & 7) === 4 || tag === 0) {
|
|
707
|
+
break;
|
|
708
|
+
}
|
|
709
|
+
reader.skipType(tag & 7);
|
|
710
|
+
}
|
|
711
|
+
return message;
|
|
712
|
+
},
|
|
713
|
+
|
|
714
|
+
fromJSON(object: any): GetSourceMapReleasesInternalResponse {
|
|
715
|
+
return {
|
|
716
|
+
releases: Array.isArray(object?.releases) ? object.releases.map((e: any) => SourceMapRelease.fromJSON(e)) : [],
|
|
717
|
+
};
|
|
718
|
+
},
|
|
719
|
+
|
|
720
|
+
toJSON(message: GetSourceMapReleasesInternalResponse): unknown {
|
|
721
|
+
const obj: any = {};
|
|
722
|
+
if (message.releases) {
|
|
723
|
+
obj.releases = message.releases.map((e) => e ? SourceMapRelease.toJSON(e) : undefined);
|
|
724
|
+
} else {
|
|
725
|
+
obj.releases = [];
|
|
726
|
+
}
|
|
727
|
+
return obj;
|
|
728
|
+
},
|
|
729
|
+
|
|
730
|
+
create(base?: DeepPartial<GetSourceMapReleasesInternalResponse>): GetSourceMapReleasesInternalResponse {
|
|
731
|
+
return GetSourceMapReleasesInternalResponse.fromPartial(base ?? {});
|
|
732
|
+
},
|
|
733
|
+
|
|
734
|
+
fromPartial(object: DeepPartial<GetSourceMapReleasesInternalResponse>): GetSourceMapReleasesInternalResponse {
|
|
735
|
+
const message = createBaseGetSourceMapReleasesInternalResponse();
|
|
736
|
+
message.releases = object.releases?.map((e) => SourceMapRelease.fromPartial(e)) || [];
|
|
737
|
+
return message;
|
|
738
|
+
},
|
|
739
|
+
};
|
|
740
|
+
|
|
741
|
+
function createBaseGetReleasesSeriesPointsRequest(): GetReleasesSeriesPointsRequest {
|
|
742
|
+
return {};
|
|
743
|
+
}
|
|
744
|
+
|
|
745
|
+
export const GetReleasesSeriesPointsRequest = {
|
|
746
|
+
encode(_: GetReleasesSeriesPointsRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
|
747
|
+
return writer;
|
|
748
|
+
},
|
|
749
|
+
|
|
750
|
+
decode(input: _m0.Reader | Uint8Array, length?: number): GetReleasesSeriesPointsRequest {
|
|
751
|
+
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
752
|
+
let end = length === undefined ? reader.len : reader.pos + length;
|
|
753
|
+
const message = createBaseGetReleasesSeriesPointsRequest();
|
|
754
|
+
while (reader.pos < end) {
|
|
755
|
+
const tag = reader.uint32();
|
|
756
|
+
switch (tag >>> 3) {
|
|
757
|
+
}
|
|
758
|
+
if ((tag & 7) === 4 || tag === 0) {
|
|
759
|
+
break;
|
|
760
|
+
}
|
|
761
|
+
reader.skipType(tag & 7);
|
|
762
|
+
}
|
|
763
|
+
return message;
|
|
764
|
+
},
|
|
765
|
+
|
|
766
|
+
fromJSON(_: any): GetReleasesSeriesPointsRequest {
|
|
767
|
+
return {};
|
|
768
|
+
},
|
|
769
|
+
|
|
770
|
+
toJSON(_: GetReleasesSeriesPointsRequest): unknown {
|
|
771
|
+
const obj: any = {};
|
|
772
|
+
return obj;
|
|
773
|
+
},
|
|
774
|
+
|
|
775
|
+
create(base?: DeepPartial<GetReleasesSeriesPointsRequest>): GetReleasesSeriesPointsRequest {
|
|
776
|
+
return GetReleasesSeriesPointsRequest.fromPartial(base ?? {});
|
|
777
|
+
},
|
|
778
|
+
|
|
779
|
+
fromPartial(_: DeepPartial<GetReleasesSeriesPointsRequest>): GetReleasesSeriesPointsRequest {
|
|
780
|
+
const message = createBaseGetReleasesSeriesPointsRequest();
|
|
781
|
+
return message;
|
|
782
|
+
},
|
|
783
|
+
};
|
|
784
|
+
|
|
785
|
+
function createBaseGetReleasesSeriesPointsResponse(): GetReleasesSeriesPointsResponse {
|
|
786
|
+
return { releasesPoints: [] };
|
|
787
|
+
}
|
|
788
|
+
|
|
789
|
+
export const GetReleasesSeriesPointsResponse = {
|
|
790
|
+
encode(message: GetReleasesSeriesPointsResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
|
791
|
+
for (const v of message.releasesPoints) {
|
|
792
|
+
ReleasePoint.encode(v!, writer.uint32(10).fork()).ldelim();
|
|
793
|
+
}
|
|
794
|
+
return writer;
|
|
795
|
+
},
|
|
796
|
+
|
|
797
|
+
decode(input: _m0.Reader | Uint8Array, length?: number): GetReleasesSeriesPointsResponse {
|
|
798
|
+
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
799
|
+
let end = length === undefined ? reader.len : reader.pos + length;
|
|
800
|
+
const message = createBaseGetReleasesSeriesPointsResponse();
|
|
801
|
+
while (reader.pos < end) {
|
|
802
|
+
const tag = reader.uint32();
|
|
803
|
+
switch (tag >>> 3) {
|
|
804
|
+
case 1:
|
|
805
|
+
if (tag !== 10) {
|
|
806
|
+
break;
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
message.releasesPoints.push(ReleasePoint.decode(reader, reader.uint32()));
|
|
810
|
+
continue;
|
|
811
|
+
}
|
|
812
|
+
if ((tag & 7) === 4 || tag === 0) {
|
|
813
|
+
break;
|
|
814
|
+
}
|
|
815
|
+
reader.skipType(tag & 7);
|
|
816
|
+
}
|
|
817
|
+
return message;
|
|
818
|
+
},
|
|
819
|
+
|
|
820
|
+
fromJSON(object: any): GetReleasesSeriesPointsResponse {
|
|
821
|
+
return {
|
|
822
|
+
releasesPoints: Array.isArray(object?.releasesPoints)
|
|
823
|
+
? object.releasesPoints.map((e: any) => ReleasePoint.fromJSON(e))
|
|
824
|
+
: [],
|
|
825
|
+
};
|
|
826
|
+
},
|
|
827
|
+
|
|
828
|
+
toJSON(message: GetReleasesSeriesPointsResponse): unknown {
|
|
829
|
+
const obj: any = {};
|
|
830
|
+
if (message.releasesPoints) {
|
|
831
|
+
obj.releasesPoints = message.releasesPoints.map((e) => e ? ReleasePoint.toJSON(e) : undefined);
|
|
832
|
+
} else {
|
|
833
|
+
obj.releasesPoints = [];
|
|
834
|
+
}
|
|
835
|
+
return obj;
|
|
836
|
+
},
|
|
837
|
+
|
|
838
|
+
create(base?: DeepPartial<GetReleasesSeriesPointsResponse>): GetReleasesSeriesPointsResponse {
|
|
839
|
+
return GetReleasesSeriesPointsResponse.fromPartial(base ?? {});
|
|
840
|
+
},
|
|
841
|
+
|
|
842
|
+
fromPartial(object: DeepPartial<GetReleasesSeriesPointsResponse>): GetReleasesSeriesPointsResponse {
|
|
843
|
+
const message = createBaseGetReleasesSeriesPointsResponse();
|
|
844
|
+
message.releasesPoints = object.releasesPoints?.map((e) => ReleasePoint.fromPartial(e)) || [];
|
|
845
|
+
return message;
|
|
846
|
+
},
|
|
847
|
+
};
|
|
848
|
+
|
|
599
849
|
export type RumServiceDefinition = typeof RumServiceDefinition;
|
|
600
850
|
export const RumServiceDefinition = {
|
|
601
851
|
name: "RumService",
|
|
@@ -625,6 +875,22 @@ export const RumServiceDefinition = {
|
|
|
625
875
|
responseStream: false,
|
|
626
876
|
options: {},
|
|
627
877
|
},
|
|
878
|
+
getSourceMapReleasesInternal: {
|
|
879
|
+
name: "GetSourceMapReleasesInternal",
|
|
880
|
+
requestType: GetSourceMapReleasesInternalRequest,
|
|
881
|
+
requestStream: false,
|
|
882
|
+
responseType: GetSourceMapReleasesInternalResponse,
|
|
883
|
+
responseStream: false,
|
|
884
|
+
options: {},
|
|
885
|
+
},
|
|
886
|
+
getReleasesSeriesPoints: {
|
|
887
|
+
name: "GetReleasesSeriesPoints",
|
|
888
|
+
requestType: GetReleasesSeriesPointsRequest,
|
|
889
|
+
requestStream: false,
|
|
890
|
+
responseType: GetReleasesSeriesPointsResponse,
|
|
891
|
+
responseStream: false,
|
|
892
|
+
options: {},
|
|
893
|
+
},
|
|
628
894
|
},
|
|
629
895
|
} as const;
|
|
630
896
|
|