@coralogix/rum-cli 1.1.11 → 1.1.12
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 +2 -0
- package/api/rum-api.ts +23 -1
- package/cli/consts/consts.ts +2 -0
- package/config/config.ts +6 -2
- package/dist/api/rum-api.d.ts +1 -0
- package/dist/api/rum-api.js +19 -2
- package/dist/cli/consts/consts.d.ts +2 -0
- package/dist/cli/consts/consts.js +6 -0
- package/dist/config/config.d.ts +1 -0
- package/dist/config/config.js +5 -3
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -43,7 +43,9 @@ Here are some examples of how to use the Coralogix RUM CLI:
|
|
|
43
43
|
- `-o, --org-name <orgName>`: GitHub organization name (optional).
|
|
44
44
|
- `-h, --help`: Display help.
|
|
45
45
|
|
|
46
|
+
## Source maps folder size limit
|
|
46
47
|
|
|
48
|
+
The source map folder size limit is 100MB in this project. Please ensure that it does not exceed this limit.
|
|
47
49
|
|
|
48
50
|
### For CI Integration:
|
|
49
51
|
|
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
|
|
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
|
-
|
|
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
|
|
package/dist/api/rum-api.d.ts
CHANGED
|
@@ -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
|
}
|
package/dist/api/rum-api.js
CHANGED
|
@@ -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,
|
|
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,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=
|
package/dist/config/config.d.ts
CHANGED
package/dist/config/config.js
CHANGED
|
@@ -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
|
-
|
|
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,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uZmlnL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUE0QztBQW9CNUMsTUFBTSxNQUFNLEdBQVc7SUFDbkIsTUFBTSxFQUFFO1FBQ0osVUFBVSxFQUFFLEtBQUs7UUFDakIsUUFBUSxFQUFFLE9BQU87S0FDcEI7SUFDRCxNQUFNLEVBQUU7UUFDSixlQUFlLEVBQUUsTUFBTTtRQUN2QixrQkFBa0IsRUFBRSxNQUFNO1FBQzFCLGNBQWMsRUFBRSxHQUFHLEdBQUcsV0FBRTtRQUN4QixzQkFBc0IsRUFBRSxHQUFHLEdBQUcsV0FBRTtRQUNoQyxTQUFTLEVBQUUsR0FBRyxHQUFHLFdBQUUsRUFBRSxxQkFBcUI7S0FDN0M7Q0FDSixDQUFDO0FBRUYsa0JBQWUsTUFBTSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtLQiwgTUJ9IGZyb20gXCIuLi9jbGkvY29uc3RzL2NvbnN0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dlckNvbmZpZyB7XG4gICAgbWF4TG9nU2l6ZTogbnVtYmVyO1xuICAgIGxvZ0xldmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgcnVtQXBpQ29uZmlnIHtcbiAgICBtYXhNZXNzYWdlU2l6ZTogbnVtYmVyLFxuICAgIGtlZXBhbGl2ZVRpbWVNczogbnVtYmVyXG4gICAga2VlcGFsaXZlVGltZW91dE1zOiBudW1iZXJcbiAgICBjaHVua1NpemU6IG51bWJlcixcbiAgICBtYXhDb21wcmVzc2VkRmlsZXNTaXplIDpudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICAgIGxvZ2dlcjogTG9nZ2VyQ29uZmlnO1xuICAgIHJ1bUFwaTogcnVtQXBpQ29uZmlnO1xufVxuXG5jb25zdCBjb25maWc6IENvbmZpZyA9IHtcbiAgICBsb2dnZXI6IHtcbiAgICAgICAgbWF4TG9nU2l6ZTogMTAwMDAsXG4gICAgICAgIGxvZ0xldmVsOiAnZGVidWcnLFxuICAgIH0sXG4gICAgcnVtQXBpOiB7XG4gICAgICAgIGtlZXBhbGl2ZVRpbWVNczogMTIwMDAwLFxuICAgICAgICBrZWVwYWxpdmVUaW1lb3V0TXM6IDEyMDAwMCxcbiAgICAgICAgbWF4TWVzc2FnZVNpemU6IDEwMCAqIE1CLCAvLyAxMDBNQiBpbiBieXRlc1xuICAgICAgICBtYXhDb21wcmVzc2VkRmlsZXNTaXplOiAxMDAgKiBNQiwgLy8gMTAwTUIgaW4gYnl0ZXNcbiAgICAgICAgY2h1bmtTaXplOiA1MTIgKiBLQiwgLy8gNTEyIEtCIGNodW5rIHNpemUsXG4gICAgfVxufTtcblxuZXhwb3J0IGRlZmF1bHQgY29uZmlnO1xuIl19
|