@coralogix/rum-cli 1.1.11 → 1.1.13

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/README.md CHANGED
@@ -9,6 +9,7 @@ The Coralogix RUM CLI is a command-line interface tool that simplifies the proce
9
9
  - [Coralogix Real User Monitoring Docs](https://coralogix.com/docs/real-user-monitoring/)
10
10
 
11
11
  - [Coralogix SDK for Browsers](https://www.npmjs.com/package/@coralogix/browser)
12
+
12
13
  # Installation
13
14
 
14
15
  To install the Coralogix RUM CLI, follow these steps:
@@ -31,7 +32,7 @@ Here are some examples of how to use the Coralogix RUM CLI:
31
32
 
32
33
  # Upload source maps
33
34
 
34
- ### Options:
35
+ ## Options
35
36
 
36
37
  - `-k, --private-key <privateKey>`: Private key to authenticate with the Coralogix API.
37
38
  - `-a, --application <application>`: Name of the application.
@@ -43,9 +44,13 @@ Here are some examples of how to use the Coralogix RUM CLI:
43
44
  - `-o, --org-name <orgName>`: GitHub organization name (optional).
44
45
  - `-h, --help`: Display help.
45
46
 
47
+ ## Source maps folder size limit
48
+
49
+ The source map folder size limit is 100MB in this project. Please ensure that it does not exceed this limit.
46
50
 
51
+ ## Integration
47
52
 
48
- ### For CI Integration:
53
+ ### <u> CI Integration: </u>
49
54
 
50
55
  1. Create a new file named `upload-source-maps.sh` and open it for editing.
51
56
 
@@ -70,7 +75,8 @@ COMMIT_HASH=$(git rev-parse HEAD)
70
75
  coralogix-rum-cli upload-source-maps -k "$PRIVATE_KEY" -a "$APPLICATION" -v "$VERSION" -f "$SOURCE_MAPS_PATH" -e "$ENV" -c "$COMMIT_HASH" -n "$REPO_NAME" -o "$ORG_NAME"
71
76
  ```
72
77
 
73
- ### For Non-CI Integration:
78
+ ### <u> Non-CI Integration: </u>
79
+
74
80
  1. Open a terminal window,and run the following command:
75
81
  ```bash
76
82
  coralogix-rum-cli upload-source-maps -k "$PRIVATE_KEY" -a "$APPLICATION" -v "$VERSION" -f "$SOURCE_MAPS_PATH" -e "$ENV" -c "$COMMIT_HASH" -n "$REPO_NAME" -o "$ORG_NAME"
package/api/rum-api.ts CHANGED
@@ -8,11 +8,12 @@ import {
8
8
  RumSourceMapServiceDefinition,
9
9
  UploadSourceMapsRequest
10
10
  } from "../proto-models/com/coralogix/rum/v2/rum_source_map_service";
11
+ import {MB} from "../cli/consts/consts";
11
12
 
12
13
  export class RumApi {
13
14
  static async uploadSourceMaps(request: UploadSourceMapsRequest, env: string, privateKey: string) {
14
15
 
15
- const {maxMessageSize, keepaliveTimeMs, keepaliveTimeoutMs} = config.rumApi;
16
+ const {maxMessageSize, keepaliveTimeMs, keepaliveTimeoutMs, maxCompressedFilesSize} = config.rumApi;
16
17
 
17
18
  try {
18
19
  const channel = createChannel(envToDomain[env], undefined, {
@@ -36,6 +37,8 @@ export class RumApi {
36
37
  })
37
38
  );
38
39
 
40
+ this.validateCompressedFilesSize(compressedFiles, maxCompressedFilesSize);
41
+
39
42
  const metadata = new Metadata();
40
43
 
41
44
  metadata.set('Authorization', `Bearer ${privateKey}`);
@@ -75,5 +78,24 @@ export class RumApi {
75
78
 
76
79
  return result;
77
80
  }
81
+
82
+ private static validateCompressedFilesSize(compressedFiles: FileMetadata[], maxCompressedFilesSize: number): void {
83
+ const compressedFilesSize = compressedFiles.reduce((sum, file) => sum + file.content.length, 0);
84
+
85
+ if (compressedFilesSize > maxCompressedFilesSize) {
86
+ // Convert sizes to megabytes (MB)
87
+ const compressedFilesSizeMB: string = (compressedFilesSize / MB).toFixed(2);
88
+ const maxCompressedFilesSizeMB: string = (maxCompressedFilesSize / MB).toFixed(2);
89
+
90
+ const errorMessage = `
91
+ ❌ Error: The total size of compressed files exceeds the maximum allowed size.
92
+ Total Compressed Files Size: ${compressedFilesSizeMB} MB
93
+ Maximum Allowed Size: ${maxCompressedFilesSizeMB} MB
94
+ `;
95
+
96
+ console.error(RED_COLOR, errorMessage);
97
+ process.exit(1);
98
+ }
99
+ }
78
100
  }
79
101
 
@@ -0,0 +1,2 @@
1
+ export const KB = 1024;
2
+ export const MB = 1024 * 1024;
package/config/config.ts CHANGED
@@ -1,3 +1,5 @@
1
+ import {KB, MB} from "../cli/consts/consts";
2
+
1
3
  export interface LoggerConfig {
2
4
  maxLogSize: number;
3
5
  logLevel: string;
@@ -8,6 +10,7 @@ export interface rumApiConfig {
8
10
  keepaliveTimeMs: number
9
11
  keepaliveTimeoutMs: number
10
12
  chunkSize: number,
13
+ maxCompressedFilesSize :number
11
14
  }
12
15
 
13
16
  export interface Config {
@@ -21,10 +24,11 @@ const config: Config = {
21
24
  logLevel: 'debug',
22
25
  },
23
26
  rumApi: {
24
- maxMessageSize: 400000 * 1024,
25
27
  keepaliveTimeMs: 120000,
26
28
  keepaliveTimeoutMs: 120000,
27
- chunkSize: 512 * 1024 // 512 KB chunk size
29
+ maxMessageSize: 100 * MB, // 100MB in bytes
30
+ maxCompressedFilesSize: 100 * MB, // 100MB in bytes
31
+ chunkSize: 512 * KB, // 512 KB chunk size,
28
32
  }
29
33
  };
30
34
 
@@ -2,4 +2,5 @@ import { UploadSourceMapsRequest } from "../proto-models/com/coralogix/rum/v2/ru
2
2
  export declare class RumApi {
3
3
  static uploadSourceMaps(request: UploadSourceMapsRequest, env: string, privateKey: string): Promise<void>;
4
4
  private static compressFileContentChunks;
5
+ private static validateCompressedFilesSize;
5
6
  }
@@ -42,10 +42,11 @@ const pako = __importStar(require("pako"));
42
42
  const config_1 = __importDefault(require("../config/config"));
43
43
  const theme_1 = require("../cli/theme");
44
44
  const rum_source_map_service_1 = require("../proto-models/com/coralogix/rum/v2/rum_source_map_service");
45
+ const consts_1 = require("../cli/consts/consts");
45
46
  class RumApi {
46
47
  static uploadSourceMaps(request, env, privateKey) {
47
48
  return __awaiter(this, void 0, void 0, function* () {
48
- const { maxMessageSize, keepaliveTimeMs, keepaliveTimeoutMs } = config_1.default.rumApi;
49
+ const { maxMessageSize, keepaliveTimeMs, keepaliveTimeoutMs, maxCompressedFilesSize } = config_1.default.rumApi;
49
50
  try {
50
51
  const channel = (0, nice_grpc_1.createChannel)(cli_model_1.envToDomain[env], undefined, {
51
52
  "grpc.max_receive_message_length": maxMessageSize,
@@ -60,6 +61,7 @@ class RumApi {
60
61
  const size = compressedChunks.length;
61
62
  return { chunkName: file.chunkName, size, content: compressedChunks };
62
63
  })));
64
+ this.validateCompressedFilesSize(compressedFiles, maxCompressedFilesSize);
63
65
  const metadata = new nice_grpc_1.Metadata();
64
66
  metadata.set('Authorization', `Bearer ${privateKey}`);
65
67
  yield client.uploadSourceMaps({
@@ -77,6 +79,21 @@ class RumApi {
77
79
  });
78
80
  }
79
81
  ;
82
+ static validateCompressedFilesSize(compressedFiles, maxCompressedFilesSize) {
83
+ const compressedFilesSize = compressedFiles.reduce((sum, file) => sum + file.content.length, 0);
84
+ if (compressedFilesSize > maxCompressedFilesSize) {
85
+ // Convert sizes to megabytes (MB)
86
+ const compressedFilesSizeMB = (compressedFilesSize / consts_1.MB).toFixed(2);
87
+ const maxCompressedFilesSizeMB = (maxCompressedFilesSize / consts_1.MB).toFixed(2);
88
+ const errorMessage = `
89
+ ❌ Error: The total size of compressed files exceeds the maximum allowed size.
90
+ Total Compressed Files Size: ${compressedFilesSizeMB} MB
91
+ Maximum Allowed Size: ${maxCompressedFilesSizeMB} MB
92
+ `;
93
+ console.error(theme_1.RED_COLOR, errorMessage);
94
+ process.exit(1);
95
+ }
96
+ }
80
97
  }
81
98
  exports.RumApi = RumApi;
82
99
  RumApi.compressFileContentChunks = (fileContent) => {
@@ -95,4 +112,4 @@ RumApi.compressFileContentChunks = (fileContent) => {
95
112
  console.error(theme_1.RED_COLOR, msg);
96
113
  return result;
97
114
  };
98
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVtLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2FwaS9ydW0tYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXdFO0FBQ3hFLGtEQUErQztBQUMvQywyQ0FBNkI7QUFDN0IsOERBQXNDO0FBQ3RDLHdDQUF1QztBQUV2Qyx3R0FHcUU7QUFFckUsTUFBYSxNQUFNO0lBQ2YsTUFBTSxDQUFPLGdCQUFnQixDQUFDLE9BQWdDLEVBQUUsR0FBVyxFQUFFLFVBQWtCOztZQUUzRixNQUFNLEVBQUMsY0FBYyxFQUFFLGVBQWUsRUFBRSxrQkFBa0IsRUFBQyxHQUFHLGdCQUFNLENBQUMsTUFBTSxDQUFDO1lBRTVFLElBQUk7Z0JBQ0EsTUFBTSxPQUFPLEdBQUcsSUFBQSx5QkFBYSxFQUFDLHVCQUFXLENBQUMsR0FBRyxDQUFDLEVBQUUsU0FBUyxFQUFFO29CQUN2RCxpQ0FBaUMsRUFBRSxjQUFjO29CQUNqRCw4QkFBOEIsRUFBRSxjQUFjO29CQUM5Qyx3QkFBd0IsRUFBRSxlQUFlO29CQUN6QywyQkFBMkIsRUFBRSxrQkFBa0I7aUJBQ2xELENBQUMsQ0FBQztnQkFFSCxNQUFNLE1BQU0sR0FBaUQsSUFBQSx3QkFBWSxFQUFDLHNEQUE2QixFQUFFLE9BQU8sQ0FBQyxDQUFDO2dCQUVsSCxNQUFNLEVBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUMsR0FBRyxPQUFPLENBQUM7Z0JBRTVFLE1BQU0sZUFBZSxHQUFtQixNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQ3JELEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBTyxJQUFrQixFQUFFLEVBQUU7b0JBQ25DLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFFdEUsTUFBTSxJQUFJLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxDQUFDO29CQUVyQyxPQUFPLEVBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBQyxDQUFDO2dCQUN4RSxDQUFDLENBQUEsQ0FBQyxDQUNMLENBQUM7Z0JBRUYsTUFBTSxRQUFRLEdBQUcsSUFBSSxvQkFBUSxFQUFFLENBQUM7Z0JBRWhDLFFBQVEsQ0FBQyxHQUFHLENBQUMsZUFBZSxFQUFFLFVBQVUsVUFBVSxFQUFFLENBQUMsQ0FBQztnQkFFdEQsTUFBTSxNQUFNLENBQUMsZ0JBQWdCLENBQUM7b0JBQzFCLEtBQUssRUFBRSxlQUFlO29CQUN0QixTQUFTO29CQUNULFdBQVc7b0JBQ1gsUUFBUTtvQkFDUixVQUFVO29CQUNWLElBQUk7aUJBQ1AsRUFBRSxFQUFDLFFBQVEsRUFBQyxDQUFDLENBQUM7YUFFbEI7WUFBQyxPQUFPLEtBQUssRUFBRTtnQkFDWixNQUFNLEtBQUssQ0FBQzthQUNmO1FBQ0wsQ0FBQztLQUFBO0lBQUEsQ0FBQzs7QUEzQ04sd0JBa0VDO0FBckJrQixnQ0FBeUIsR0FBRyxDQUFDLFdBQXVCLEVBQWMsRUFBRTtJQUMvRSxNQUFNLEVBQUMsU0FBUyxFQUFDLEdBQUcsZ0JBQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxvQkFBb0I7SUFDdkQsTUFBTSxPQUFPLEdBQUcsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkMsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDO0lBRTlELEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDbEMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLFNBQVMsQ0FBQztRQUM1QixNQUFNLEdBQUcsR0FBRyxLQUFLLEdBQUcsU0FBUyxDQUFDO1FBQzlCLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBRS9DLE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBSyxXQUFXLEdBQUcsQ0FBQyxDQUFDO1FBRTFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0tBQ3BDO0lBRUQsTUFBTSxFQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFDLEdBQUcsT0FBTyxDQUFDO0lBRW5DLElBQUksR0FBRztRQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsaUJBQVMsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUV2QyxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NsaWVudCwgY3JlYXRlQ2hhbm5lbCwgY3JlYXRlQ2xpZW50LCBNZXRhZGF0YX0gZnJvbSAnbmljZS1ncnBjJztcbmltcG9ydCB7ZW52VG9Eb21haW59IGZyb20gXCIuLi9tb2RlbC9jbGkubW9kZWxcIjtcbmltcG9ydCAqIGFzIHBha28gZnJvbSAncGFrbyc7XG5pbXBvcnQgY29uZmlnIGZyb20gXCIuLi9jb25maWcvY29uZmlnXCI7XG5pbXBvcnQge1JFRF9DT0xPUn0gZnJvbSBcIi4uL2NsaS90aGVtZVwiO1xuaW1wb3J0IHtGaWxlTWV0YWRhdGF9IGZyb20gXCIuLi9wcm90by1tb2RlbHMvY29tL2NvcmFsb2dpeC9ydW0vdjIvZmlsZVwiO1xuaW1wb3J0IHtcbiAgICBSdW1Tb3VyY2VNYXBTZXJ2aWNlRGVmaW5pdGlvbixcbiAgICBVcGxvYWRTb3VyY2VNYXBzUmVxdWVzdFxufSBmcm9tIFwiLi4vcHJvdG8tbW9kZWxzL2NvbS9jb3JhbG9naXgvcnVtL3YyL3J1bV9zb3VyY2VfbWFwX3NlcnZpY2VcIjtcblxuZXhwb3J0IGNsYXNzIFJ1bUFwaSB7XG4gICAgc3RhdGljIGFzeW5jIHVwbG9hZFNvdXJjZU1hcHMocmVxdWVzdDogVXBsb2FkU291cmNlTWFwc1JlcXVlc3QsIGVudjogc3RyaW5nLCBwcml2YXRlS2V5OiBzdHJpbmcpIHtcblxuICAgICAgICBjb25zdCB7bWF4TWVzc2FnZVNpemUsIGtlZXBhbGl2ZVRpbWVNcywga2VlcGFsaXZlVGltZW91dE1zfSA9IGNvbmZpZy5ydW1BcGk7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IGNoYW5uZWwgPSBjcmVhdGVDaGFubmVsKGVudlRvRG9tYWluW2Vudl0sIHVuZGVmaW5lZCwge1xuICAgICAgICAgICAgICAgIFwiZ3JwYy5tYXhfcmVjZWl2ZV9tZXNzYWdlX2xlbmd0aFwiOiBtYXhNZXNzYWdlU2l6ZSxcbiAgICAgICAgICAgICAgICBcImdycGMubWF4X3NlbmRfbWVzc2FnZV9sZW5ndGhcIjogbWF4TWVzc2FnZVNpemUsXG4gICAgICAgICAgICAgICAgJ2dycGMua2VlcGFsaXZlX3RpbWVfbXMnOiBrZWVwYWxpdmVUaW1lTXMsXG4gICAgICAgICAgICAgICAgJ2dycGMua2VlcGFsaXZlX3RpbWVvdXRfbXMnOiBrZWVwYWxpdmVUaW1lb3V0TXMsXG4gICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgY29uc3QgY2xpZW50OiBDbGllbnQ8dHlwZW9mIFJ1bVNvdXJjZU1hcFNlcnZpY2VEZWZpbml0aW9uPiA9IGNyZWF0ZUNsaWVudChSdW1Tb3VyY2VNYXBTZXJ2aWNlRGVmaW5pdGlvbiwgY2hhbm5lbCk7XG5cbiAgICAgICAgICAgIGNvbnN0IHtmaWxlcywgcmVsZWFzZUlkLCBhcHBsaWNhdGlvbiwgcmVwb05hbWUsIGNvbW1pdEhhc2gsIHVzZXJ9ID0gcmVxdWVzdDtcblxuICAgICAgICAgICAgY29uc3QgY29tcHJlc3NlZEZpbGVzOiBGaWxlTWV0YWRhdGFbXSA9IGF3YWl0IFByb21pc2UuYWxsKFxuICAgICAgICAgICAgICAgIGZpbGVzLm1hcChhc3luYyAoZmlsZTogRmlsZU1ldGFkYXRhKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGNvbXByZXNzZWRDaHVua3MgPSB0aGlzLmNvbXByZXNzRmlsZUNvbnRlbnRDaHVua3MoZmlsZS5jb250ZW50KTtcblxuICAgICAgICAgICAgICAgICAgICBjb25zdCBzaXplID0gY29tcHJlc3NlZENodW5rcy5sZW5ndGg7XG5cbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHtjaHVua05hbWU6IGZpbGUuY2h1bmtOYW1lLCBzaXplLCBjb250ZW50OiBjb21wcmVzc2VkQ2h1bmtzfTtcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKTtcblxuICAgICAgICAgICAgY29uc3QgbWV0YWRhdGEgPSBuZXcgTWV0YWRhdGEoKTtcblxuICAgICAgICAgICAgbWV0YWRhdGEuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3ByaXZhdGVLZXl9YCk7XG5cbiAgICAgICAgICAgIGF3YWl0IGNsaWVudC51cGxvYWRTb3VyY2VNYXBzKHtcbiAgICAgICAgICAgICAgICBmaWxlczogY29tcHJlc3NlZEZpbGVzLFxuICAgICAgICAgICAgICAgIHJlbGVhc2VJZCxcbiAgICAgICAgICAgICAgICBhcHBsaWNhdGlvbixcbiAgICAgICAgICAgICAgICByZXBvTmFtZSxcbiAgICAgICAgICAgICAgICBjb21taXRIYXNoLFxuICAgICAgICAgICAgICAgIHVzZXJcbiAgICAgICAgICAgIH0sIHttZXRhZGF0YX0pO1xuXG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfVxuICAgIH07XG5cbiAgICBwcml2YXRlIHN0YXRpYyBjb21wcmVzc0ZpbGVDb250ZW50Q2h1bmtzID0gKGZpbGVDb250ZW50OiBVaW50OEFycmF5KTogVWludDhBcnJheSA9PiB7XG4gICAgICAgIGNvbnN0IHtjaHVua1NpemV9ID0gY29uZmlnLnJ1bUFwaTsgLy8gNTEyIEtCIGNodW5rIHNpemVcbiAgICAgICAgY29uc3QgZGVmbGF0ZSA9IG5ldyBwYWtvLkRlZmxhdGUoKTtcbiAgICAgICAgY29uc3QgdG90YWxDaHVua3MgPSBNYXRoLmNlaWwoZmlsZUNvbnRlbnQubGVuZ3RoIC8gY2h1bmtTaXplKTtcblxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRvdGFsQ2h1bmtzOyBpKyspIHtcbiAgICAgICAgICAgIGNvbnN0IHN0YXJ0ID0gaSAqIGNodW5rU2l6ZTtcbiAgICAgICAgICAgIGNvbnN0IGVuZCA9IHN0YXJ0ICsgY2h1bmtTaXplO1xuICAgICAgICAgICAgY29uc3QgY2h1bmsgPSBmaWxlQ29udGVudC5zdWJhcnJheShzdGFydCwgZW5kKTtcblxuICAgICAgICAgICAgY29uc3QgaXNMYXN0Q2h1bmsgPSBpID09PSB0b3RhbENodW5rcyAtIDE7XG5cbiAgICAgICAgICAgIGRlZmxhdGUucHVzaChjaHVuaywgaXNMYXN0Q2h1bmspO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qge2VyciwgbXNnLCByZXN1bHR9ID0gZGVmbGF0ZTtcblxuICAgICAgICBpZiAoZXJyKSBjb25zb2xlLmVycm9yKFJFRF9DT0xPUiwgbXNnKTtcblxuICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cbn1cblxuIl19
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rum-api.js","sourceRoot":"","sources":["../../api/rum-api.ts"],"names":[],"mappings":"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","sourcesContent":["import {Client, createChannel, createClient, Metadata} from 'nice-grpc';\nimport {envToDomain} from \"../model/cli.model\";\nimport * as pako from 'pako';\nimport config from \"../config/config\";\nimport {RED_COLOR} from \"../cli/theme\";\nimport {FileMetadata} from \"../proto-models/com/coralogix/rum/v2/file\";\nimport {\n    RumSourceMapServiceDefinition,\n    UploadSourceMapsRequest\n} from \"../proto-models/com/coralogix/rum/v2/rum_source_map_service\";\nimport {MB} from \"../cli/consts/consts\";\n\nexport class RumApi {\n    static async uploadSourceMaps(request: UploadSourceMapsRequest, env: string, privateKey: string) {\n\n        const {maxMessageSize, keepaliveTimeMs, keepaliveTimeoutMs, maxCompressedFilesSize} = config.rumApi;\n\n        try {\n            const channel = createChannel(envToDomain[env], undefined, {\n                \"grpc.max_receive_message_length\": maxMessageSize,\n                \"grpc.max_send_message_length\": maxMessageSize,\n                'grpc.keepalive_time_ms': keepaliveTimeMs,\n                'grpc.keepalive_timeout_ms': keepaliveTimeoutMs,\n            });\n\n            const client: Client<typeof RumSourceMapServiceDefinition> = createClient(RumSourceMapServiceDefinition, channel);\n\n            const {files, releaseId, application, repoName, commitHash, user} = request;\n\n            const compressedFiles: FileMetadata[] = await Promise.all(\n                files.map(async (file: FileMetadata) => {\n                    const compressedChunks = this.compressFileContentChunks(file.content);\n\n                    const size = compressedChunks.length;\n\n                    return {chunkName: file.chunkName, size, content: compressedChunks};\n                })\n            );\n\n            this.validateCompressedFilesSize(compressedFiles, maxCompressedFilesSize);\n\n            const metadata = new Metadata();\n\n            metadata.set('Authorization', `Bearer ${privateKey}`);\n\n            await client.uploadSourceMaps({\n                files: compressedFiles,\n                releaseId,\n                application,\n                repoName,\n                commitHash,\n                user\n            }, {metadata});\n\n        } catch (error) {\n            throw error;\n        }\n    };\n\n    private static 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\n    private static 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}\n\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const KB = 1024;
2
+ export declare const MB: number;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MB = exports.KB = void 0;
4
+ exports.KB = 1024;
5
+ exports.MB = 1024 * 1024;
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vY2xpL2NvbnN0cy9jb25zdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxFQUFFLEdBQUcsSUFBSSxDQUFDO0FBQ1YsUUFBQSxFQUFFLEdBQUcsSUFBSSxHQUFHLElBQUksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBLQiA9IDEwMjQ7XG5leHBvcnQgY29uc3QgTUIgPSAxMDI0ICogMTAyNDsiXX0=
@@ -7,6 +7,7 @@ export interface rumApiConfig {
7
7
  keepaliveTimeMs: number;
8
8
  keepaliveTimeoutMs: number;
9
9
  chunkSize: number;
10
+ maxCompressedFilesSize: number;
10
11
  }
11
12
  export interface Config {
12
13
  logger: LoggerConfig;
@@ -1,16 +1,18 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ const consts_1 = require("../cli/consts/consts");
3
4
  const config = {
4
5
  logger: {
5
6
  maxLogSize: 10000,
6
7
  logLevel: 'debug',
7
8
  },
8
9
  rumApi: {
9
- maxMessageSize: 400000 * 1024,
10
10
  keepaliveTimeMs: 120000,
11
11
  keepaliveTimeoutMs: 120000,
12
- chunkSize: 512 * 1024 // 512 KB chunk size
12
+ maxMessageSize: 100 * consts_1.MB,
13
+ maxCompressedFilesSize: 100 * consts_1.MB,
14
+ chunkSize: 512 * consts_1.KB, // 512 KB chunk size,
13
15
  }
14
16
  };
15
17
  exports.default = config;
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uZmlnL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQWlCQSxNQUFNLE1BQU0sR0FBVztJQUNuQixNQUFNLEVBQUU7UUFDSixVQUFVLEVBQUUsS0FBSztRQUNqQixRQUFRLEVBQUUsT0FBTztLQUNwQjtJQUNELE1BQU0sRUFBRTtRQUNKLGNBQWMsRUFBRSxNQUFNLEdBQUcsSUFBSTtRQUM3QixlQUFlLEVBQUUsTUFBTTtRQUN2QixrQkFBa0IsRUFBRSxNQUFNO1FBQzFCLFNBQVMsRUFBRSxHQUFHLEdBQUcsSUFBSSxDQUFDLG9CQUFvQjtLQUM3QztDQUNKLENBQUM7QUFFRixrQkFBZSxNQUFNLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIExvZ2dlckNvbmZpZyB7XG4gICAgbWF4TG9nU2l6ZTogbnVtYmVyO1xuICAgIGxvZ0xldmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgcnVtQXBpQ29uZmlnIHtcbiAgICBtYXhNZXNzYWdlU2l6ZTogbnVtYmVyLFxuICAgIGtlZXBhbGl2ZVRpbWVNczogbnVtYmVyXG4gICAga2VlcGFsaXZlVGltZW91dE1zOiBudW1iZXJcbiAgICBjaHVua1NpemU6IG51bWJlcixcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICAgIGxvZ2dlcjogTG9nZ2VyQ29uZmlnO1xuICAgIHJ1bUFwaTogcnVtQXBpQ29uZmlnO1xufVxuXG5jb25zdCBjb25maWc6IENvbmZpZyA9IHtcbiAgICBsb2dnZXI6IHtcbiAgICAgICAgbWF4TG9nU2l6ZTogMTAwMDAsXG4gICAgICAgIGxvZ0xldmVsOiAnZGVidWcnLFxuICAgIH0sXG4gICAgcnVtQXBpOiB7XG4gICAgICAgIG1heE1lc3NhZ2VTaXplOiA0MDAwMDAgKiAxMDI0LFxuICAgICAgICBrZWVwYWxpdmVUaW1lTXM6IDEyMDAwMCxcbiAgICAgICAga2VlcGFsaXZlVGltZW91dE1zOiAxMjAwMDAsXG4gICAgICAgIGNodW5rU2l6ZTogNTEyICogMTAyNCAvLyA1MTIgS0IgY2h1bmsgc2l6ZVxuICAgIH1cbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNvbmZpZztcbiJdfQ==
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uZmlnL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUE0QztBQW9CNUMsTUFBTSxNQUFNLEdBQVc7SUFDbkIsTUFBTSxFQUFFO1FBQ0osVUFBVSxFQUFFLEtBQUs7UUFDakIsUUFBUSxFQUFFLE9BQU87S0FDcEI7SUFDRCxNQUFNLEVBQUU7UUFDSixlQUFlLEVBQUUsTUFBTTtRQUN2QixrQkFBa0IsRUFBRSxNQUFNO1FBQzFCLGNBQWMsRUFBRSxHQUFHLEdBQUcsV0FBRTtRQUN4QixzQkFBc0IsRUFBRSxHQUFHLEdBQUcsV0FBRTtRQUNoQyxTQUFTLEVBQUUsR0FBRyxHQUFHLFdBQUUsRUFBRSxxQkFBcUI7S0FDN0M7Q0FDSixDQUFDO0FBRUYsa0JBQWUsTUFBTSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtLQiwgTUJ9IGZyb20gXCIuLi9jbGkvY29uc3RzL2NvbnN0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dlckNvbmZpZyB7XG4gICAgbWF4TG9nU2l6ZTogbnVtYmVyO1xuICAgIGxvZ0xldmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgcnVtQXBpQ29uZmlnIHtcbiAgICBtYXhNZXNzYWdlU2l6ZTogbnVtYmVyLFxuICAgIGtlZXBhbGl2ZVRpbWVNczogbnVtYmVyXG4gICAga2VlcGFsaXZlVGltZW91dE1zOiBudW1iZXJcbiAgICBjaHVua1NpemU6IG51bWJlcixcbiAgICBtYXhDb21wcmVzc2VkRmlsZXNTaXplIDpudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICAgIGxvZ2dlcjogTG9nZ2VyQ29uZmlnO1xuICAgIHJ1bUFwaTogcnVtQXBpQ29uZmlnO1xufVxuXG5jb25zdCBjb25maWc6IENvbmZpZyA9IHtcbiAgICBsb2dnZXI6IHtcbiAgICAgICAgbWF4TG9nU2l6ZTogMTAwMDAsXG4gICAgICAgIGxvZ0xldmVsOiAnZGVidWcnLFxuICAgIH0sXG4gICAgcnVtQXBpOiB7XG4gICAgICAgIGtlZXBhbGl2ZVRpbWVNczogMTIwMDAwLFxuICAgICAgICBrZWVwYWxpdmVUaW1lb3V0TXM6IDEyMDAwMCxcbiAgICAgICAgbWF4TWVzc2FnZVNpemU6IDEwMCAqIE1CLCAvLyAxMDBNQiBpbiBieXRlc1xuICAgICAgICBtYXhDb21wcmVzc2VkRmlsZXNTaXplOiAxMDAgKiBNQiwgLy8gMTAwTUIgaW4gYnl0ZXNcbiAgICAgICAgY2h1bmtTaXplOiA1MTIgKiBLQiwgLy8gNTEyIEtCIGNodW5rIHNpemUsXG4gICAgfVxufTtcblxuZXhwb3J0IGRlZmF1bHQgY29uZmlnO1xuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@coralogix/rum-cli",
3
- "version": "1.1.11",
3
+ "version": "1.1.13",
4
4
  "description": "corlogix rum cli",
5
5
  "bin": {
6
6
  "coralogix-rum-cli": "dist/cli/rum-cli.js"