@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,
|
|
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
|
-
|
|
113
|
-
|
|
114
|
-
|
|
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
|
-
|
|
122
|
-
|
|
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
|
-
|
|
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.
|
|
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
|
-
"
|
|
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
|
-
|
|
83
|
-
const stats = await stat(folderPath);
|
|
84
|
+
const stats = await stat(folderPath);
|
|
84
85
|
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
|
|
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
|
}
|