From a5096ce413e1f808c0e857e958ef9aa3d5de888b Mon Sep 17 00:00:00 2001 From: lohxt1 Date: Mon, 16 Dec 2024 14:51:02 +0530 Subject: [PATCH 1/5] revert: rename-item watcher fix -- tbd --- packages/bruno-electron/src/ipc/collection.js | 20 +++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/packages/bruno-electron/src/ipc/collection.js b/packages/bruno-electron/src/ipc/collection.js index d1ff7c3f9..519da8b37 100644 --- a/packages/bruno-electron/src/ipc/collection.js +++ b/packages/bruno-electron/src/ipc/collection.js @@ -349,10 +349,10 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection // rename item ipcMain.handle('renderer:rename-item', async (event, oldPath, newPath, newName) => { const tempDir = path.join(os.tmpdir(), `temp-folder-${Date.now()}`); - const parentDir = path.dirname(oldPath); + // const parentDir = path.dirname(oldPath); const isWindowsOSAndNotWSLAndItemHasSubDirectories = isWindowsOS() && !isWSLPath(oldPath) && hasSubDirectories(oldPath); - let parentDirUnwatched = false; - let parentDirRewatched = false; + // let parentDirUnwatched = false; + // let parentDirRewatched = false; try { // Normalize paths if they are WSL paths @@ -376,8 +376,8 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection moveRequestUid(bruFile, newBruFilePath); } - watcher.unlinkItemPathInWatcher(parentDir); - parentDirUnwatched = true; + // watcher.unlinkItemPathInWatcher(parentDir); + // parentDirUnwatched = true; /** * If it is windows OS @@ -396,8 +396,8 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection } else { await fs.renameSync(oldPath, newPath); } - watcher.addItemPathInWatcher(parentDir); - parentDirRewatched = true; + // watcher.addItemPathInWatcher(parentDir); + // parentDirRewatched = true; return newPath; } @@ -424,9 +424,9 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection } catch (error) { // in case an error occurs during the rename file operations after unlinking the parent dir // and the rewatch fails, we need to add it back to watcher - if (parentDirUnwatched && !parentDirRewatched) { - watcher.addItemPathInWatcher(parentDir); - } + // if (parentDirUnwatched && !parentDirRewatched) { + // watcher.addItemPathInWatcher(parentDir); + // } // in case the rename file operations fails, and we see that the temp dir exists // and the old path does not exist, we need to restore the data from the temp dir to the old path From 0ad0af041b066b8ea57729ec81a42a6a012c6f7b Mon Sep 17 00:00:00 2001 From: lohxt1 Date: Mon, 16 Dec 2024 18:46:16 +0530 Subject: [PATCH 2/5] fix: validations updates --- packages/bruno-app/src/utils/collections/index.js | 4 ++-- packages/bruno-app/src/utils/common/index.js | 2 +- packages/bruno-app/src/utils/importers/common.js | 4 ++-- packages/bruno-electron/src/store/global-environments.js | 4 ++-- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/packages/bruno-app/src/utils/collections/index.js b/packages/bruno-app/src/utils/collections/index.js index 3a691e53f..e28bc0d13 100644 --- a/packages/bruno-app/src/utils/collections/index.js +++ b/packages/bruno-app/src/utils/collections/index.js @@ -797,8 +797,8 @@ export const getGlobalEnvironmentVariables = ({ globalEnvironments, activeGlobal const environment = globalEnvironments?.find(env => env?.uid === activeGlobalEnvironmentUid); if (environment) { each(environment.variables, (variable) => { - if (variable.name && variable.value && variable.enabled) { - variables[variable.name] = variable.value; + if (variable.name && variable.enabled) { + variables[variable.name] = variable.value || ''; } }); } diff --git a/packages/bruno-app/src/utils/common/index.js b/packages/bruno-app/src/utils/common/index.js index 1244966b7..10ca09e50 100644 --- a/packages/bruno-app/src/utils/common/index.js +++ b/packages/bruno-app/src/utils/common/index.js @@ -173,4 +173,4 @@ export const generateUidBasedOnHash = (str) => { return `${hash}`.padEnd(21, '0'); }; -export const stringifyIfNot = v => typeof v === 'string' ? v : String(v); +export const stringifyIfNot = v => typeof v === 'string' ? v : ''; diff --git a/packages/bruno-app/src/utils/importers/common.js b/packages/bruno-app/src/utils/importers/common.js index c99048419..88c4c7872 100644 --- a/packages/bruno-app/src/utils/importers/common.js +++ b/packages/bruno-app/src/utils/importers/common.js @@ -79,9 +79,9 @@ export const transformItemsInCollection = (collection) => { // from 5 feb 2024, multipartFormData needs to have a type // this was introduced when we added support for file uploads // below logic is to make older collection exports backward compatible - let multipartFormData = _.get(item, 'request.body.multipartForm'); + let multipartFormData = get(item, 'request.body.multipartForm'); if (multipartFormData) { - _.each(multipartFormData, (form) => { + each(multipartFormData, (form) => { if (!form.type) { form.type = 'text'; } diff --git a/packages/bruno-electron/src/store/global-environments.js b/packages/bruno-electron/src/store/global-environments.js index e8c03c434..2f9c1b309 100644 --- a/packages/bruno-electron/src/store/global-environments.js +++ b/packages/bruno-electron/src/store/global-environments.js @@ -18,7 +18,7 @@ class GlobalEnvironmentsStore { return globalEnvironments?.map(env => { const variables = env.variables?.map(v => ({ ...v, - value: v?.secret ? (this.isValidValue(v.value) ? encryptString(v.value) : '') : v?.value + value: v?.secret ? (this.isValidValue(v.value) ? encryptString(v.value) : '') : (v?.value || '') })) || []; return { @@ -32,7 +32,7 @@ class GlobalEnvironmentsStore { return globalEnvironments?.map(env => { const variables = env.variables?.map(v => ({ ...v, - value: v?.secret ? (this.isValidValue(v.value) ? decryptString(v.value) : '') : v?.value + value: v?.secret ? (this.isValidValue(v.value) ? decryptString(v.value) : '') : (v?.value || '') })) || []; return { From 7a8d1624d1c24e9a30369f41d747098a874778c5 Mon Sep 17 00:00:00 2001 From: lohxt1 Date: Mon, 16 Dec 2024 22:09:10 +0530 Subject: [PATCH 3/5] fix: updates --- .../src/providers/ReduxStore/slices/global-environments.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/bruno-app/src/providers/ReduxStore/slices/global-environments.js b/packages/bruno-app/src/providers/ReduxStore/slices/global-environments.js index 77f469125..def88f2b6 100644 --- a/packages/bruno-app/src/providers/ReduxStore/slices/global-environments.js +++ b/packages/bruno-app/src/providers/ReduxStore/slices/global-environments.js @@ -191,7 +191,7 @@ export const globalEnvironmentsUpdateEvent = ({ globalEnvironmentVariables }) => // update existing values variables = variables?.map?.(variable => ({ ...variable, - value: stringifyIfNot(globalEnvironmentVariables?.[variable?.name]) + value: globalEnvironmentVariables?.[variable?.name] })); // add new env values @@ -201,7 +201,7 @@ export const globalEnvironmentsUpdateEvent = ({ globalEnvironmentVariables }) => variables.push({ uid: uuid(), name: key, - value: stringifyIfNot(value), + value, type: 'text', secret: false, enabled: true From e44dcad01ae1e70e16529c768e67372ff144178a Mon Sep 17 00:00:00 2001 From: lohxt1 Date: Mon, 16 Dec 2024 22:13:26 +0530 Subject: [PATCH 4/5] fix: updates --- packages/bruno-app/src/utils/collections/index.js | 2 +- packages/bruno-app/src/utils/common/index.js | 2 +- packages/bruno-electron/src/store/global-environments.js | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/bruno-app/src/utils/collections/index.js b/packages/bruno-app/src/utils/collections/index.js index e28bc0d13..d770c60a3 100644 --- a/packages/bruno-app/src/utils/collections/index.js +++ b/packages/bruno-app/src/utils/collections/index.js @@ -798,7 +798,7 @@ export const getGlobalEnvironmentVariables = ({ globalEnvironments, activeGlobal if (environment) { each(environment.variables, (variable) => { if (variable.name && variable.enabled) { - variables[variable.name] = variable.value || ''; + variables[variable.name] = variable.value; } }); } diff --git a/packages/bruno-app/src/utils/common/index.js b/packages/bruno-app/src/utils/common/index.js index 10ca09e50..1244966b7 100644 --- a/packages/bruno-app/src/utils/common/index.js +++ b/packages/bruno-app/src/utils/common/index.js @@ -173,4 +173,4 @@ export const generateUidBasedOnHash = (str) => { return `${hash}`.padEnd(21, '0'); }; -export const stringifyIfNot = v => typeof v === 'string' ? v : ''; +export const stringifyIfNot = v => typeof v === 'string' ? v : String(v); diff --git a/packages/bruno-electron/src/store/global-environments.js b/packages/bruno-electron/src/store/global-environments.js index 2f9c1b309..e8c03c434 100644 --- a/packages/bruno-electron/src/store/global-environments.js +++ b/packages/bruno-electron/src/store/global-environments.js @@ -18,7 +18,7 @@ class GlobalEnvironmentsStore { return globalEnvironments?.map(env => { const variables = env.variables?.map(v => ({ ...v, - value: v?.secret ? (this.isValidValue(v.value) ? encryptString(v.value) : '') : (v?.value || '') + value: v?.secret ? (this.isValidValue(v.value) ? encryptString(v.value) : '') : v?.value })) || []; return { @@ -32,7 +32,7 @@ class GlobalEnvironmentsStore { return globalEnvironments?.map(env => { const variables = env.variables?.map(v => ({ ...v, - value: v?.secret ? (this.isValidValue(v.value) ? decryptString(v.value) : '') : (v?.value || '') + value: v?.secret ? (this.isValidValue(v.value) ? decryptString(v.value) : '') : v?.value })) || []; return { From f871bc0fa28d0a1219ef3d078209eff18fdc854f Mon Sep 17 00:00:00 2001 From: Anoop M D Date: Tue, 17 Dec 2024 13:46:48 +0530 Subject: [PATCH 5/5] feat: setup script --- package.json | 3 +- scripts/setup.js | 95 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 97 insertions(+), 1 deletion(-) create mode 100644 scripts/setup.js diff --git a/package.json b/package.json index ebe1af53f..2c46fdd2c 100644 --- a/package.json +++ b/package.json @@ -30,6 +30,7 @@ "ts-jest": "^29.0.5" }, "scripts": { + "setup": "node ./scripts/setup.js", "dev": "concurrently --kill-others \"npm run dev:web\" \"npm run dev:electron\"", "dev:web": "npm run dev --workspace=packages/bruno-app", "build:web": "npm run build --workspace=packages/bruno-app", @@ -51,6 +52,6 @@ "prepare": "husky install" }, "overrides": { - "rollup":"3.29.5" + "rollup": "3.29.5" } } diff --git a/scripts/setup.js b/scripts/setup.js new file mode 100644 index 000000000..47d679098 --- /dev/null +++ b/scripts/setup.js @@ -0,0 +1,95 @@ +const { execSync } = require('child_process'); +const fs = require('fs'); +const path = require('path'); + +const icons = { + clean: '๐Ÿงน', + delete: '๐Ÿ—‘๏ธ', + install: '๐Ÿ“ฆ', + build: '๐Ÿ”จ', + success: 'โœ…', + error: 'โŒ', + working: 'โšก' +}; + +const execCommand = (command, description) => { + try { + console.log(`\n${icons.working} ${description}...`); + execSync(command, { stdio: 'inherit' }); + console.log(`${icons.success} ${description} completed`); + } catch (error) { + console.error(`${icons.error} ${description} failed`); + throw error; + } +}; + +const glob = function (startPath, pattern) { + let results = []; + + // Ensure start path exists + if (!fs.existsSync(startPath)) { + return results; + } + + const files = fs.readdirSync(startPath); + for (const file of files) { + const filename = path.join(startPath, file); + const stat = fs.lstatSync(filename); + + // If directory, recurse into it + if (stat.isDirectory()) { + // Skip node_modules recursion to avoid unnecessary deep scanning + if (file === 'node_modules') { + if (file === pattern) { + results.push(filename); + } + continue; + } + results = results.concat(glob(filename, pattern)); + } + + // If file matches pattern, add to results + if (file === pattern) { + results.push(filename); + } + } + + return results; +}; + +async function setup() { + try { + // Clean up node_modules (if exists) + console.log(`\n${icons.clean} Cleaning up node_modules directories...`); + const nodeModulesPaths = glob('.', 'node_modules'); + for (const dir of nodeModulesPaths) { + console.log(`${icons.delete} Removing ${dir}`); + fs.rmSync(dir, { recursive: true, force: true }); + } + + // Install dependencies + execCommand('npm i --legacy-peer-deps', 'Installing dependencies'); + + // Build packages + execCommand('npm run build:graphql-docs', 'Building graphql-docs'); + execCommand('npm run build:bruno-query', 'Building bruno-query'); + execCommand('npm run build:bruno-common', 'Building bruno-common'); + + // Bundle JS sandbox libraries + execCommand( + 'npm run sandbox:bundle-libraries --workspace=packages/bruno-js', + 'Bundling JS sandbox libraries' + ); + + console.log(`\n${icons.success} Setup completed successfully!\n`); + } catch (error) { + console.error(`\n${icons.error} Setup failed:`); + console.error(error); + process.exit(1); + } +} + +setup().catch(error => { + console.error(error); + process.exit(1); +});