@coralogix/rum-cli 1.1.37 → 1.1.38

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
@@ -68,7 +68,6 @@ coralogix-rum-cli upload-proguard -k <privateKey> -a <application> -v <version>
68
68
  - `-c, --commit-hash <commitHash>`: GitHub commit hash (optional).
69
69
  - `-n, --repo-name <repoName>`: GitHub repository name (optional).
70
70
  - `-o, --org-name <orgName>`: GitHub organization name (optional).
71
- - `-g, --generate`: Update existing release or create a new one if not found (optional).
72
71
  - `-h, --help`: Display help.
73
72
 
74
73
  ## Environments
@@ -17,7 +17,7 @@ class BaseService {
17
17
  return __awaiter(this, void 0, void 0, function* () {
18
18
  const request = blobset_service_1.UploadBlobRequest.create();
19
19
  const api = this.getApi();
20
- console.log(consts_1.GRAY_COLOR, `🚀 Uploading ${this.getLogPrefix()}...`);
20
+ console.log(consts_1.GRAY_COLOR, `🚀 Uploading ${this.getLogPrefix()}... (${new Date().toUTCString()})`);
21
21
  try {
22
22
  yield this.getFileProcessorMethod()(folderPath, request, this.getFileExtension());
23
23
  yield api.upload(request, application, version, repoName, commitHash, orgName, env, privateKey);
@@ -31,4 +31,4 @@ class BaseService {
31
31
  }
32
32
  }
33
33
  exports.BaseService = BaseService;
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc2VydmljZXMvYmFzZS9iYXNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaUdBQWdHO0FBQ2hHLGdEQUE4RDtBQUk5RCxNQUFzQixXQUFXO0lBTXpCLE1BQU0sQ0FDVixXQUFtQixFQUNuQixPQUFlLEVBQ2YsUUFBNEIsRUFDNUIsVUFBOEIsRUFDOUIsT0FBMkIsRUFDM0IsVUFBa0IsRUFDbEIsR0FBVyxFQUNYLFVBQWtCOztZQUVsQixNQUFNLE9BQU8sR0FBc0IsbUNBQWlCLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDOUQsTUFBTSxHQUFHLEdBQVksSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBRW5DLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQVUsRUFBRSxnQkFBZ0IsSUFBSSxDQUFDLFlBQVksRUFBRSxLQUFLLENBQUMsQ0FBQztZQUVsRSxJQUFJO2dCQUNGLE1BQU0sSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUMsVUFBVSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO2dCQUVsRixNQUFNLEdBQUcsQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO2dCQUVoRyxPQUFPLENBQUMsR0FBRyxDQUFDLG9CQUFXLEVBQUUsS0FBSyxJQUFJLENBQUMsWUFBWSxFQUFFLHlCQUF5QixDQUFDLENBQUM7Z0JBQzVFLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0JBQVcsRUFBRSx3QkFBd0IsQ0FBQyxDQUFDO2FBQ3BEO1lBQUMsT0FBTyxLQUFLLEVBQUU7Z0JBQ2QsTUFBTSxLQUFLLENBQUM7YUFDYjtRQUNILENBQUM7S0FBQTtDQUNGO0FBaENELGtDQWdDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVwbG9hZEJsb2JSZXF1ZXN0IH0gZnJvbSAnLi4vLi4vcHJvdG8tbW9kZWxzL2NvbS9jb3JhbG9naXgvYmxvYnNldC92Mi9ibG9ic2V0X3NlcnZpY2UnO1xuaW1wb3J0IHsgR1JBWV9DT0xPUiwgR1JFRU5fQ09MT1IgfSBmcm9tICcuLi8uLi9jb25zdHMvY29uc3RzJztcbmltcG9ydCB7IGNvbnNvbGVFcnJvciB9IGZyb20gJy4uLy4uL3V0aWxzL3NoYXJlZC51dGlscyc7XG5pbXBvcnQgeyBCYXNlQXBpIH0gZnJvbSAnLi4vLi4vYXBpL2Jhc2UvYmFzZS5hcGknO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZVNlcnZpY2Uge1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0QXBpKCk6IEJhc2VBcGk7XG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXRGaWxlUHJvY2Vzc29yTWV0aG9kKCk6IChwYXRoOiBzdHJpbmcsIHJlcXVlc3Q6IFVwbG9hZEJsb2JSZXF1ZXN0LCBmaWxlRXh0ZW5zaW9uOiBzdHJpbmcpID0+IFByb21pc2U8dm9pZD47XG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXRMb2dQcmVmaXgoKTogc3RyaW5nO1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0RmlsZUV4dGVuc2lvbigpOiBzdHJpbmc7XG5cbiAgYXN5bmMgdXBsb2FkKFxuICAgIGFwcGxpY2F0aW9uOiBzdHJpbmcsXG4gICAgdmVyc2lvbjogc3RyaW5nLFxuICAgIHJlcG9OYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICAgY29tbWl0SGFzaDogc3RyaW5nIHwgdW5kZWZpbmVkLFxuICAgIG9yZ05hbWU6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBmb2xkZXJQYXRoOiBzdHJpbmcsXG4gICAgZW52OiBzdHJpbmcsXG4gICAgcHJpdmF0ZUtleTogc3RyaW5nLFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCByZXF1ZXN0OiBVcGxvYWRCbG9iUmVxdWVzdCA9IFVwbG9hZEJsb2JSZXF1ZXN0LmNyZWF0ZSgpO1xuICAgIGNvbnN0IGFwaTogQmFzZUFwaSA9IHRoaXMuZ2V0QXBpKCk7XG5cbiAgICBjb25zb2xlLmxvZyhHUkFZX0NPTE9SLCBg8J+agCBVcGxvYWRpbmcgJHt0aGlzLmdldExvZ1ByZWZpeCgpfS4uLmApO1xuXG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IHRoaXMuZ2V0RmlsZVByb2Nlc3Nvck1ldGhvZCgpKGZvbGRlclBhdGgsIHJlcXVlc3QsIHRoaXMuZ2V0RmlsZUV4dGVuc2lvbigpKTtcblxuICAgICAgYXdhaXQgYXBpLnVwbG9hZChyZXF1ZXN0LCBhcHBsaWNhdGlvbiwgdmVyc2lvbiwgcmVwb05hbWUsIGNvbW1pdEhhc2gsIG9yZ05hbWUsIGVudiwgcHJpdmF0ZUtleSk7XG5cbiAgICAgIGNvbnNvbGUubG9nKEdSRUVOX0NPTE9SLCBg4pyFICR7dGhpcy5nZXRMb2dQcmVmaXgoKX0gdXBsb2FkZWQgc3VjY2Vzc2Z1bGx5IWApO1xuICAgICAgY29uc29sZS5sb2coR1JFRU5fQ09MT1IsICfinIUgUHJvY2Vzc2luZyBjb21wbGV0ZS4nKTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfVxuICB9XG59XG4iXX0=
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc2VydmljZXMvYmFzZS9iYXNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaUdBQWdHO0FBQ2hHLGdEQUE4RDtBQUc5RCxNQUFzQixXQUFXO0lBTXpCLE1BQU0sQ0FDVixXQUFtQixFQUNuQixPQUFlLEVBQ2YsUUFBNEIsRUFDNUIsVUFBOEIsRUFDOUIsT0FBMkIsRUFDM0IsVUFBa0IsRUFDbEIsR0FBVyxFQUNYLFVBQWtCOztZQUVsQixNQUFNLE9BQU8sR0FBc0IsbUNBQWlCLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDOUQsTUFBTSxHQUFHLEdBQVksSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBRW5DLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQVUsRUFBRSxnQkFBZ0IsSUFBSSxDQUFDLFlBQVksRUFBRSxRQUFRLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBRWhHLElBQUk7Z0JBQ0YsTUFBTSxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7Z0JBRWxGLE1BQU0sR0FBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsVUFBVSxDQUFDLENBQUM7Z0JBRWhHLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0JBQVcsRUFBRSxLQUFLLElBQUksQ0FBQyxZQUFZLEVBQUUseUJBQXlCLENBQUMsQ0FBQztnQkFDNUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxvQkFBVyxFQUFFLHdCQUF3QixDQUFDLENBQUM7YUFDcEQ7WUFBQyxPQUFPLEtBQUssRUFBRTtnQkFDZCxNQUFNLEtBQUssQ0FBQzthQUNiO1FBQ0gsQ0FBQztLQUFBO0NBQ0Y7QUFoQ0Qsa0NBZ0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVXBsb2FkQmxvYlJlcXVlc3QgfSBmcm9tICcuLi8uLi9wcm90by1tb2RlbHMvY29tL2NvcmFsb2dpeC9ibG9ic2V0L3YyL2Jsb2JzZXRfc2VydmljZSc7XG5pbXBvcnQgeyBHUkFZX0NPTE9SLCBHUkVFTl9DT0xPUiB9IGZyb20gJy4uLy4uL2NvbnN0cy9jb25zdHMnO1xuaW1wb3J0IHsgQmFzZUFwaSB9IGZyb20gJy4uLy4uL2FwaS9iYXNlL2Jhc2UuYXBpJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VTZXJ2aWNlIHtcbiAgcHJvdGVjdGVkIGFic3RyYWN0IGdldEFwaSgpOiBCYXNlQXBpO1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0RmlsZVByb2Nlc3Nvck1ldGhvZCgpOiAocGF0aDogc3RyaW5nLCByZXF1ZXN0OiBVcGxvYWRCbG9iUmVxdWVzdCwgZmlsZUV4dGVuc2lvbjogc3RyaW5nKSA9PiBQcm9taXNlPHZvaWQ+O1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0TG9nUHJlZml4KCk6IHN0cmluZztcbiAgcHJvdGVjdGVkIGFic3RyYWN0IGdldEZpbGVFeHRlbnNpb24oKTogc3RyaW5nO1xuXG4gIGFzeW5jIHVwbG9hZChcbiAgICBhcHBsaWNhdGlvbjogc3RyaW5nLFxuICAgIHZlcnNpb246IHN0cmluZyxcbiAgICByZXBvTmFtZTogc3RyaW5nIHwgdW5kZWZpbmVkLFxuICAgIGNvbW1pdEhhc2g6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBvcmdOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICAgZm9sZGVyUGF0aDogc3RyaW5nLFxuICAgIGVudjogc3RyaW5nLFxuICAgIHByaXZhdGVLZXk6IHN0cmluZyxcbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgcmVxdWVzdDogVXBsb2FkQmxvYlJlcXVlc3QgPSBVcGxvYWRCbG9iUmVxdWVzdC5jcmVhdGUoKTtcbiAgICBjb25zdCBhcGk6IEJhc2VBcGkgPSB0aGlzLmdldEFwaSgpO1xuXG4gICAgY29uc29sZS5sb2coR1JBWV9DT0xPUiwgYPCfmoAgVXBsb2FkaW5nICR7dGhpcy5nZXRMb2dQcmVmaXgoKX0uLi4gKCR7bmV3IERhdGUoKS50b1VUQ1N0cmluZygpfSlgKTtcblxuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0aGlzLmdldEZpbGVQcm9jZXNzb3JNZXRob2QoKShmb2xkZXJQYXRoLCByZXF1ZXN0LCB0aGlzLmdldEZpbGVFeHRlbnNpb24oKSk7XG5cbiAgICAgIGF3YWl0IGFwaS51cGxvYWQocmVxdWVzdCwgYXBwbGljYXRpb24sIHZlcnNpb24sIHJlcG9OYW1lLCBjb21taXRIYXNoLCBvcmdOYW1lLCBlbnYsIHByaXZhdGVLZXkpO1xuXG4gICAgICBjb25zb2xlLmxvZyhHUkVFTl9DT0xPUiwgYOKchSAke3RoaXMuZ2V0TG9nUHJlZml4KCl9IHVwbG9hZGVkIHN1Y2Nlc3NmdWxseSFgKTtcbiAgICAgIGNvbnNvbGUubG9nKEdSRUVOX0NPTE9SLCAn4pyFIFByb2Nlc3NpbmcgY29tcGxldGUuJyk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -31,6 +31,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
31
31
  step((generator = generator.apply(thisArg, _arguments || [])).next());
32
32
  });
33
33
  };
34
+ var __importDefault = (this && this.__importDefault) || function (mod) {
35
+ return (mod && mod.__esModule) ? mod : { "default": mod };
36
+ };
34
37
  Object.defineProperty(exports, "__esModule", { value: true });
35
38
  exports.FileProcessor = void 0;
36
39
  const fs = __importStar(require("fs"));
@@ -38,6 +41,7 @@ const fs_1 = require("fs");
38
41
  const path = __importStar(require("path"));
39
42
  const shared_utils_1 = require("./shared.utils");
40
43
  const zlib = __importStar(require("node:zlib"));
44
+ const node_assert_1 = __importDefault(require("node:assert"));
41
45
  const { readdir, stat, readFile } = fs_1.promises;
42
46
  class FileProcessor {
43
47
  static traverseProguardFolder(proguardPath, request, fileExtension) {
@@ -109,17 +113,12 @@ class FileProcessor {
109
113
  }
110
114
  static traverse(folderPath, request, fileExtension) {
111
115
  return __awaiter(this, void 0, void 0, function* () {
112
- try {
113
- const stats = yield stat(folderPath);
114
- if (stats.isFile() && folderPath.endsWith(fileExtension)) {
115
- return yield this.processSingleFile(folderPath, request, fileExtension);
116
- }
117
- else if (stats.isDirectory()) {
118
- return yield this.processDirectory(folderPath, request, fileExtension);
119
- }
116
+ const stats = yield stat(folderPath);
117
+ if (stats.isFile() && folderPath.endsWith(fileExtension)) {
118
+ return yield this.processSingleFile(folderPath, request, fileExtension);
120
119
  }
121
- catch (error) {
122
- (0, shared_utils_1.consoleError)(`Error traversing directory: ${error}`);
120
+ else if (stats.isDirectory()) {
121
+ return yield this.processDirectory(folderPath, request, fileExtension);
123
122
  }
124
123
  });
125
124
  }
@@ -151,7 +150,8 @@ class FileProcessor {
151
150
  if (dirent.isFile() && dirent.name.endsWith(fileExtension)) {
152
151
  const content = yield readFile(filePath);
153
152
  const { name } = path.parse(filePath);
154
- fileDataList.push({ name, content: content.toString('base64') });
153
+ const { size } = yield stat(filePath);
154
+ fileDataList.push({ name, size, content: content.toString('base64') });
155
155
  }
156
156
  else if (dirent.isDirectory()) {
157
157
  yield traverseDirectory(filePath);
@@ -159,6 +159,10 @@ class FileProcessor {
159
159
  }
160
160
  });
161
161
  yield traverseDirectory(folderPath);
162
+ // Assert that at least one file was found
163
+ (0, node_assert_1.default)(fileDataList.length > 0, `No files with extension ${fileExtension} found in the directory: 📁 ${folderPath}`);
164
+ console.log(`Found ${fileDataList.length} ${fileExtension} files in ${folderPath} directory.`);
165
+ fileDataList.forEach(file => console.log(`⛶ ${file.name}, Size: ${file.size} bytes`));
162
166
  const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify(fileDataList)));
163
167
  request.data = new Uint8Array(compressedContent);
164
168
  });
@@ -179,4 +183,4 @@ class FileProcessor {
179
183
  }
180
184
  }
181
185
  exports.FileProcessor = FileProcessor;
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-processor.utils.js","sourceRoot":"","sources":["../../utils/file-processor.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport { Dirent, promises as fsPromises } from 'fs';\nimport * as path from 'path';\nimport { consoleError } from './shared.utils';\nimport { UploadBlobRequest } from '../proto-models/com/coralogix/blobset/v2/blobset_service';\nimport * as zlib from 'node:zlib';\n\nconst { readdir, stat, readFile } = fsPromises;\n\nexport class FileProcessor {\n  static async traverseProguardFolder(proguardPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      const processTxtFile = async (proguardFile: string) => {\n        const content = await readFile(proguardFile);\n        const compressedContent = zlib.gzipSync(content);\n        request.data = new Uint8Array(compressedContent);\n      };\n\n      // Check if the folder itself is a .txt file\n      if (proguardPath.endsWith(fileExtension)) {\n        await processTxtFile(proguardPath);\n        return;\n      }\n\n      const files: Dirent[] = await readdir(proguardPath, { withFileTypes: true });\n\n      for (const file of files) {\n        const filePath: string = path.join(proguardPath, file.name);\n\n        if (file.name.endsWith('.txt')) {\n          await processTxtFile(filePath);\n          return;\n        } else {\n          await FileProcessor.traverseProguardFolder(filePath, request, fileExtension);\n        }\n      }\n    } catch (error) {\n      consoleError(`Error traversing directory: ${JSON.stringify(error)}`);\n    }\n  }\n\n  static async traverseDsymFolder(dsymPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      const processDsymFolder = async (dsymFolderPath: string) => {\n        const dwarfPath = await FileProcessor.getDwarfPath(dsymFolderPath);\n        const content = await readFile(dwarfPath);\n        const compressedContent = zlib.gzipSync(content);\n        request.data = new Uint8Array(compressedContent);\n      };\n\n      // Check if the folder itself is a .dSYM folder\n      if (dsymPath.endsWith(fileExtension)) {\n        await processDsymFolder(dsymPath);\n        return;\n      }\n\n      const files: Dirent[] = await readdir(dsymPath, { withFileTypes: true });\n\n      for (const file of files) {\n        // Skip .DS_Store and hidden files\n        if (file.name === '.DS_Store' || file.name.startsWith('.')) {\n          continue;\n        }\n\n        const filePath: string = path.join(dsymPath, file.name);\n\n        if (file.isDirectory()) {\n          if (file.name.endsWith(fileExtension)) {\n            await processDsymFolder(filePath);\n            return;\n          } else {\n            await FileProcessor.traverseDsymFolder(filePath, request, fileExtension);\n          }\n        }\n      }\n    } catch (error) {\n      consoleError(`Error traversing directory: ${JSON.stringify(error)}`);\n    }\n  }\n\n  static async traverse(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      const stats = await stat(folderPath);\n\n      if (stats.isFile() && folderPath.endsWith(fileExtension)) {\n        return await this.processSingleFile(folderPath, request, fileExtension);\n      } else if (stats.isDirectory()) {\n        return await this.processDirectory(folderPath, request, fileExtension);\n      }\n    } catch (error) {\n      consoleError(`Error traversing directory: ${error}`);\n    }\n  }\n\n  private static async processSingleFile(filePath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      if (!filePath.endsWith(fileExtension)) {\n        consoleError(`File ${filePath} does not have the correct extension: ${fileExtension}`);\n      }\n\n      const content = await readFile(filePath);\n\n      const { name } = path.parse(filePath);\n\n      const fileData = { name, content: content.toString('base64') };\n\n      const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify([fileData])));\n\n      request.data = new Uint8Array(compressedContent);\n    } catch (error) {\n      consoleError(`Error processing file: ${error}`);\n      throw error;\n    }\n  }\n\n  private static async processDirectory(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    const fileDataList: { name: string; content: string }[] = [];\n\n    const traverseDirectory = async (currentPath: string): Promise<void> => {\n      const files = await readdir(currentPath, { withFileTypes: true });\n\n      for (const dirent of files) {\n        const filePath = path.join(currentPath, dirent.name);\n\n        if (dirent.isFile() && dirent.name.endsWith(fileExtension)) {\n          const content = await readFile(filePath);\n          const { name } = path.parse(filePath);\n          fileDataList.push({ name, content: content.toString('base64') });\n        } else if (dirent.isDirectory()) {\n          await traverseDirectory(filePath);\n        }\n      }\n    };\n\n    await traverseDirectory(folderPath);\n\n    const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify(fileDataList)));\n    request.data = new Uint8Array(compressedContent);\n  }\n\n  private static async getDwarfPath(dsymPath: string): Promise<string> {\n    const dwarfPath: string = 'Contents/Resources/DWARF';\n    const targetPath: string = path.join(dsymPath, dwarfPath);\n    const files = fs.readdirSync(targetPath);\n    if (files.length === 1) {\n      return path.join(dsymPath, dwarfPath, files[0]);\n    } else {\n      consoleError(`Expected exactly one file in the directory, but found: ${files.length}`);\n      return '';\n    }\n  }\n}\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-processor.utils.js","sourceRoot":"","sources":["../../utils/file-processor.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport { Dirent, promises as fsPromises } from 'fs';\nimport * as path from 'path';\nimport { consoleError } from './shared.utils';\nimport { UploadBlobRequest } from '../proto-models/com/coralogix/blobset/v2/blobset_service';\nimport * as zlib from 'node:zlib';\nimport assert from 'node:assert';\n\n\nconst { readdir, stat, readFile } = fsPromises;\n\nexport class FileProcessor {\n  static async traverseProguardFolder(proguardPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      const processTxtFile = async (proguardFile: string) => {\n        const content = await readFile(proguardFile);\n        const compressedContent = zlib.gzipSync(content);\n        request.data = new Uint8Array(compressedContent);\n      };\n\n      // Check if the folder itself is a .txt file\n      if (proguardPath.endsWith(fileExtension)) {\n        await processTxtFile(proguardPath);\n        return;\n      }\n\n      const files: Dirent[] = await readdir(proguardPath, { withFileTypes: true });\n\n      for (const file of files) {\n        const filePath: string = path.join(proguardPath, file.name);\n\n        if (file.name.endsWith('.txt')) {\n          await processTxtFile(filePath);\n          return;\n        } else {\n          await FileProcessor.traverseProguardFolder(filePath, request, fileExtension);\n        }\n      }\n    } catch (error) {\n      consoleError(`Error traversing directory: ${JSON.stringify(error)}`);\n    }\n  }\n\n  static async traverseDsymFolder(dsymPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      const processDsymFolder = async (dsymFolderPath: string) => {\n        const dwarfPath = await FileProcessor.getDwarfPath(dsymFolderPath);\n        const content = await readFile(dwarfPath);\n        const compressedContent = zlib.gzipSync(content);\n        request.data = new Uint8Array(compressedContent);\n      };\n\n      // Check if the folder itself is a .dSYM folder\n      if (dsymPath.endsWith(fileExtension)) {\n        await processDsymFolder(dsymPath);\n        return;\n      }\n\n      const files: Dirent[] = await readdir(dsymPath, { withFileTypes: true });\n\n      for (const file of files) {\n        // Skip .DS_Store and hidden files\n        if (file.name === '.DS_Store' || file.name.startsWith('.')) {\n          continue;\n        }\n\n        const filePath: string = path.join(dsymPath, file.name);\n\n        if (file.isDirectory()) {\n          if (file.name.endsWith(fileExtension)) {\n            await processDsymFolder(filePath);\n            return;\n          } else {\n            await FileProcessor.traverseDsymFolder(filePath, request, fileExtension);\n          }\n        }\n      }\n    } catch (error) {\n      consoleError(`Error traversing directory: ${JSON.stringify(error)}`);\n    }\n  }\n\n  static async traverse(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    const stats = await stat(folderPath);\n\n    if (stats.isFile() && folderPath.endsWith(fileExtension)) {\n      return await this.processSingleFile(folderPath, request, fileExtension);\n    } else if (stats.isDirectory()) {\n      return await this.processDirectory(folderPath, request, fileExtension);\n    }\n  }\n\n  private static async processSingleFile(filePath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    try {\n      if (!filePath.endsWith(fileExtension)) {\n        consoleError(`File ${filePath} does not have the correct extension: ${fileExtension}`);\n      }\n\n      const content = await readFile(filePath);\n\n      const { name } = path.parse(filePath);\n\n      const fileData = { name, content: content.toString('base64') };\n\n      const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify([fileData])));\n\n      request.data = new Uint8Array(compressedContent);\n    } catch (error) {\n      consoleError(`Error processing file: ${error}`);\n      throw error;\n    }\n  }\n\n  private static async processDirectory(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {\n    const fileDataList: { name: string; size: number; content: string }[] = [];\n\n    const traverseDirectory = async (currentPath: string): Promise<void> => {\n      const files = await readdir(currentPath, { withFileTypes: true });\n\n      for (const dirent of files) {\n        const filePath = path.join(currentPath, dirent.name);\n\n        if (dirent.isFile() && dirent.name.endsWith(fileExtension)) {\n          const content = await readFile(filePath);\n          const { name } = path.parse(filePath);\n          const {size} = await stat(filePath);\n          fileDataList.push({ name, size, content: content.toString('base64') });\n        } else if (dirent.isDirectory()) {\n          await traverseDirectory(filePath);\n        }\n      }\n    };\n\n    await traverseDirectory(folderPath);\n    // Assert that at least one file was found\n    assert(fileDataList.length > 0, `No files with extension ${fileExtension} found in the directory: 📁 ${folderPath}`);\n    console.log(`Found ${fileDataList.length} ${fileExtension} files in ${folderPath} directory.`);\n    fileDataList.forEach(file => console.log(`⛶ ${file.name}, Size: ${file.size} bytes`));\n    const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify(fileDataList)));\n    request.data = new Uint8Array(compressedContent);\n  }\n\n  private static async getDwarfPath(dsymPath: string): Promise<string> {\n    const dwarfPath: string = 'Contents/Resources/DWARF';\n    const targetPath: string = path.join(dsymPath, dwarfPath);\n    const files = fs.readdirSync(targetPath);\n    if (files.length === 1) {\n      return path.join(dsymPath, dwarfPath, files[0]);\n    } else {\n      consoleError(`Expected exactly one file in the directory, but found: ${files.length}`);\n      return '';\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@coralogix/rum-cli",
3
- "version": "1.1.37",
3
+ "version": "1.1.38",
4
4
  "description": "coralogix rum cli",
5
5
  "bin": {
6
6
  "coralogix-rum-cli": "dist/cli/rum-cli.js"
@@ -28,10 +28,10 @@
28
28
  "cx-protofetch": "0.1.11",
29
29
  "google-proto-files": "^3.0.1",
30
30
  "google-protobuf": "^3.19.3",
31
- "protobufjs": "^7.2.4",
32
31
  "grpc-tools": "^1.11.2",
33
32
  "prettier": "^2.8.7",
34
- "ts-node": "10.6.0",
33
+ "protobufjs": "^7.2.4",
34
+ "ts-node": "^10.6.0",
35
35
  "ts-proto": "^1.104.0",
36
36
  "typescript": "^4.9.5"
37
37
  },
package/protoset.bin CHANGED
Binary file
@@ -1,6 +1,5 @@
1
1
  import { UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
2
2
  import { GRAY_COLOR, GREEN_COLOR } from '../../consts/consts';
3
- import { consoleError } from '../../utils/shared.utils';
4
3
  import { BaseApi } from '../../api/base/base.api';
5
4
 
6
5
  export abstract class BaseService {
@@ -22,7 +21,7 @@ export abstract class BaseService {
22
21
  const request: UploadBlobRequest = UploadBlobRequest.create();
23
22
  const api: BaseApi = this.getApi();
24
23
 
25
- console.log(GRAY_COLOR, `🚀 Uploading ${this.getLogPrefix()}...`);
24
+ console.log(GRAY_COLOR, `🚀 Uploading ${this.getLogPrefix()}... (${new Date().toUTCString()})`);
26
25
 
27
26
  try {
28
27
  await this.getFileProcessorMethod()(folderPath, request, this.getFileExtension());
@@ -4,6 +4,8 @@ import * as path from 'path';
4
4
  import { consoleError } from './shared.utils';
5
5
  import { UploadBlobRequest } from '../proto-models/com/coralogix/blobset/v2/blobset_service';
6
6
  import * as zlib from 'node:zlib';
7
+ import assert from 'node:assert';
8
+
7
9
 
8
10
  const { readdir, stat, readFile } = fsPromises;
9
11
 
@@ -79,16 +81,12 @@ export class FileProcessor {
79
81
  }
80
82
 
81
83
  static async traverse(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {
82
- try {
83
- const stats = await stat(folderPath);
84
+ const stats = await stat(folderPath);
84
85
 
85
- if (stats.isFile() && folderPath.endsWith(fileExtension)) {
86
- return await this.processSingleFile(folderPath, request, fileExtension);
87
- } else if (stats.isDirectory()) {
88
- return await this.processDirectory(folderPath, request, fileExtension);
89
- }
90
- } catch (error) {
91
- consoleError(`Error traversing directory: ${error}`);
86
+ if (stats.isFile() && folderPath.endsWith(fileExtension)) {
87
+ return await this.processSingleFile(folderPath, request, fileExtension);
88
+ } else if (stats.isDirectory()) {
89
+ return await this.processDirectory(folderPath, request, fileExtension);
92
90
  }
93
91
  }
94
92
 
@@ -114,7 +112,7 @@ export class FileProcessor {
114
112
  }
115
113
 
116
114
  private static async processDirectory(folderPath: string, request: UploadBlobRequest, fileExtension: string): Promise<void> {
117
- const fileDataList: { name: string; content: string }[] = [];
115
+ const fileDataList: { name: string; size: number; content: string }[] = [];
118
116
 
119
117
  const traverseDirectory = async (currentPath: string): Promise<void> => {
120
118
  const files = await readdir(currentPath, { withFileTypes: true });
@@ -125,7 +123,8 @@ export class FileProcessor {
125
123
  if (dirent.isFile() && dirent.name.endsWith(fileExtension)) {
126
124
  const content = await readFile(filePath);
127
125
  const { name } = path.parse(filePath);
128
- fileDataList.push({ name, content: content.toString('base64') });
126
+ const {size} = await stat(filePath);
127
+ fileDataList.push({ name, size, content: content.toString('base64') });
129
128
  } else if (dirent.isDirectory()) {
130
129
  await traverseDirectory(filePath);
131
130
  }
@@ -133,7 +132,10 @@ export class FileProcessor {
133
132
  };
134
133
 
135
134
  await traverseDirectory(folderPath);
136
-
135
+ // Assert that at least one file was found
136
+ assert(fileDataList.length > 0, `No files with extension ${fileExtension} found in the directory: 📁 ${folderPath}`);
137
+ console.log(`Found ${fileDataList.length} ${fileExtension} files in ${folderPath} directory.`);
138
+ fileDataList.forEach(file => console.log(`⛶ ${file.name}, Size: ${file.size} bytes`));
137
139
  const compressedContent = zlib.gzipSync(Buffer.from(JSON.stringify(fileDataList)));
138
140
  request.data = new Uint8Array(compressedContent);
139
141
  }