From 68a055681e278a3dc8d5d254e91cae85bbe43c21 Mon Sep 17 00:00:00 2001 From: Zack Rauen Date: Thu, 21 Oct 2021 17:03:24 -0400 Subject: [PATCH 1/6] Change sorting to descending Select the first of the array and not worry about size by using descending sort --- src/renderer/actions/paths.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/renderer/actions/paths.js b/src/renderer/actions/paths.js index 9850fc50..cdccdb70 100644 --- a/src/renderer/actions/paths.js +++ b/src/renderer/actions/paths.js @@ -10,7 +10,7 @@ const getDiscordPath = function(releaseChannel) { if (process.platform === "win32") { const basedir = path.join(process.env.LOCALAPPDATA, releaseChannel.replace(/ /g, "")); if (!fs.existsSync(basedir)) return ""; - const version = fs.readdirSync(basedir).filter(f => fs.lstatSync(path.join(basedir, f)).isDirectory() && f.split(".").length > 1).sort()[0]; + const version = fs.readdirSync(basedir).filter(f => fs.lstatSync(path.join(basedir, f)).isDirectory() && f.split(".").length > 1).sort().reverse()[0]; if (!version) return ""; resourcePath = path.join(basedir, version, "resources"); } @@ -20,7 +20,7 @@ const getDiscordPath = function(releaseChannel) { else { const basedir = path.join(remote.app.getPath("userData"), "..", releaseChannel.toLowerCase().replace(" ", "")); if (!fs.existsSync(basedir)) return ""; - const version = fs.readdirSync(basedir).filter(f => fs.lstatSync(path.join(basedir, f)).isDirectory() && f.split(".").length > 1).sort()[0]; + const version = fs.readdirSync(basedir).filter(f => fs.lstatSync(path.join(basedir, f)).isDirectory() && f.split(".").length > 1).sort().reverse()[0]; if (!version) return ""; resourcePath = path.join(basedir, version, "modules", "discord_desktop_core"); } @@ -55,7 +55,7 @@ const validateWindows = function(channel, proposedPath) { const selected = path.basename(proposedPath); const isBaseDir = selected === channelName; if (isBaseDir) { - const version = fs.readdirSync(proposedPath).filter(f => fs.lstatSync(path.join(proposedPath, f)).isDirectory() && f.split(".").length > 1).sort()[0]; + const version = fs.readdirSync(proposedPath).filter(f => fs.lstatSync(path.join(proposedPath, f)).isDirectory() && f.split(".").length > 1).sort().reverse()[0]; if (!version) return ""; resourcePath = path.join(proposedPath, version, "resources"); } @@ -90,7 +90,7 @@ const validateLinux = function(channel, proposedPath) { let resourcePath = ""; const selected = path.basename(proposedPath); if (selected === channelName) { - const version = fs.readdirSync(proposedPath).filter(f => fs.lstatSync(path.join(proposedPath, f)).isDirectory() && f.split(".").length > 1).sort()[0]; + const version = fs.readdirSync(proposedPath).filter(f => fs.lstatSync(path.join(proposedPath, f)).isDirectory() && f.split(".").length > 1).sort().reverse()[0]; if (!version) return ""; resourcePath = path.join(proposedPath, version, "modules", "discord_desktop_core"); } From 566c50096767b2f1f92746c0ce4864b7a1ddb9e2 Mon Sep 17 00:00:00 2001 From: Zack Rauen Date: Thu, 21 Oct 2021 17:13:48 -0400 Subject: [PATCH 2/6] Detect installs in ProgramData Fixes #149 --- src/renderer/actions/paths.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/renderer/actions/paths.js b/src/renderer/actions/paths.js index cdccdb70..da4b2738 100644 --- a/src/renderer/actions/paths.js +++ b/src/renderer/actions/paths.js @@ -8,7 +8,8 @@ export const locations = {stable: "", ptb: "", canary: ""}; const getDiscordPath = function(releaseChannel) { let resourcePath = ""; if (process.platform === "win32") { - const basedir = path.join(process.env.LOCALAPPDATA, releaseChannel.replace(/ /g, "")); + let basedir = path.join(process.env.LOCALAPPDATA, releaseChannel.replace(/ /g, "")); // Normal install path in AppData\Local + if (!fs.existsSync(basedir)) basedir = path.join(process.env.PROGRAMDATA, process.env.USERNAME, releaseChannel.replace(/ /g, "")); // Atypical location in ProgramData\%username% if (!fs.existsSync(basedir)) return ""; const version = fs.readdirSync(basedir).filter(f => fs.lstatSync(path.join(basedir, f)).isDirectory() && f.split(".").length > 1).sort().reverse()[0]; if (!version) return ""; From bae48bcd83ab53f12b4683ba7ecd4f7c0c11779b Mon Sep 17 00:00:00 2001 From: Zack Rauen Date: Thu, 21 Oct 2021 20:49:26 -0400 Subject: [PATCH 3/6] Swap from del to rimraf - Fixes #219 - Fixes duplicate "Deleted Shims" on repair action --- package.json | 4 +- src/renderer/actions/repair.js | 34 ++++--- src/renderer/actions/uninstall.js | 8 +- yarn.lock | 141 ++---------------------------- 4 files changed, 36 insertions(+), 151 deletions(-) diff --git a/package.json b/package.json index 71b7b503..6febfa66 100644 --- a/package.json +++ b/package.json @@ -15,11 +15,9 @@ "dist:dir": "yarn dist --dir -c.compression=store -c.mac.identity=null" }, "dependencies": { - "semver": "^7.3.5", "source-map-support": "^0.5.16" }, "devDependencies": { - "del": "^6.0.0", "electron": "^9.4.0", "electron-builder": "^22.4.1", "electron-webpack": "^2.8.2", @@ -28,6 +26,8 @@ "find-process": "^1.4.4", "focus-visible": "^5.2.0", "phin": "^3.6.0", + "rimraf": "^3.0.2", + "semver": "^7.3.5", "svelte": "^3.38.2", "svelte-loader": "^3.0.0", "svelte-spa-router": "^3.1.0", diff --git a/src/renderer/actions/repair.js b/src/renderer/actions/repair.js index a2802a5c..1f687139 100644 --- a/src/renderer/actions/repair.js +++ b/src/renderer/actions/repair.js @@ -2,7 +2,8 @@ import {progress, status} from "../stores/installation"; import {remote} from "electron"; import {promises as fs} from "fs"; -import del from "del"; +import originalFs from "original-fs"; +import rimraf from "rimraf"; import path from "path"; import install from "./install.js"; import {log, lognewline} from "./utils/log"; @@ -23,16 +24,16 @@ async function deleteAppDirs(paths) { for (const discordPath of paths) { log("Removing " + discordPath); const appPath = path.join(discordPath, "app"); - try { - if (await exists(appPath)) await del(appPath, {force: true}); - log("✅ Deletion successful"); - progress.set(progress.value + progressPerLoop); - } - catch (err) { - log(` Could not delete folder ${appPath}`); - log(`❌ ${err.message}`); - return err; + if (await exists(appPath)) { + const error = await new Promise(resolve => rimraf(appPath, originalFs, resolve)); + if (error) { + log(` Could not delete folder ${appPath}`); + log(`❌ ${error.message}`); + return error; + } } + log("✅ Deletion successful"); + progress.set(progress.value + progressPerLoop); } } @@ -44,7 +45,16 @@ async function deleteModuleDirs(config) { const roaming = path.join(remote.app.getPath("userData"), "..", platforms[channel].replace(" ", "").toLowerCase()); try { const versionDir = (await fs.readdir(roaming)).find(d => d.split(".").length > 2); - if (await exists(path.join(versionDir, "modules"))) await del(versionDir, {force: true}); + const modulesPath = path.join(roaming, versionDir, "modules"); + log("Removing " + modulesPath); + if (await exists(modulesPath)) { + const error = await new Promise(resolve => rimraf(path.join(modulesPath), originalFs, resolve)); + if (error) { + log(`❌ Could not delete modules in ${roaming}`); + log(`❌ ${error.message}`); + return error; + } + } log("✅ Deletion successful"); progress.set(progress.value + progressPerLoop); } @@ -110,7 +120,7 @@ export default async function(config) { lognewline("Deleting discord modules..."); const deleteModulesErr = await deleteModuleDirs(config); if (deleteModulesErr) return fail(); - log("✅ Shims deleted"); + log("✅ Modules deleted"); progress.set(DELETE_MODULE_DIRS_PROGRESS); diff --git a/src/renderer/actions/uninstall.js b/src/renderer/actions/uninstall.js index 1e430ad3..ac3b6347 100644 --- a/src/renderer/actions/uninstall.js +++ b/src/renderer/actions/uninstall.js @@ -1,5 +1,6 @@ import {promises as fs} from "fs"; -import del from "del"; +import originalFs from "original-fs"; +import rimraf from "rimraf"; import path from "path"; import {progress} from "../stores/installation"; @@ -26,7 +27,10 @@ async function deleteShims(paths) { const indexFile = path.join(discordPath, "index.js"); try { if (process.platform === "win32" || process.platform === "darwin") { - if (await exists(appPath)) await del(appPath, {force: true}); + if (await exists(appPath)) { + const error = await new Promise(r => rimraf(appPath, originalFs, r)); + if (error) throw error; // Throw instead because there are multiple throw points + } } else { if (await exists(indexFile)) await fs.writeFile(indexFile, `module.exports = require("./core.asar");`); diff --git a/yarn.lock b/yarn.lock index 43584ba2..1996669c 100644 --- a/yarn.lock +++ b/yarn.lock @@ -941,27 +941,6 @@ minimatch "^3.0.4" strip-json-comments "^3.1.1" -"@nodelib/fs.scandir@2.1.5": - version "2.1.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" - integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== - dependencies: - "@nodelib/fs.stat" "2.0.5" - run-parallel "^1.1.9" - -"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" - integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== - -"@nodelib/fs.walk@^1.2.3": - version "1.2.8" - resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" - integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== - dependencies: - "@nodelib/fs.scandir" "2.1.5" - fastq "^1.6.0" - "@polka/url@^1.0.0-next.20": version "1.0.0-next.21" resolved "https://registry.yarnpkg.com/@polka/url/-/url-1.0.0-next.21.tgz#5de5a2385a35309427f6011992b544514d559aa1" @@ -1451,11 +1430,6 @@ array-union@^1.0.1: dependencies: array-uniq "^1.0.1" -array-union@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" - integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== - array-uniq@^1.0.1: version "1.0.3" resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" @@ -1727,7 +1701,7 @@ braces@^2.3.1, braces@^2.3.2: split-string "^3.0.2" to-regex "^3.0.1" -braces@^3.0.1, braces@~3.0.2: +braces@~3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== @@ -2581,20 +2555,6 @@ del@^4.1.1: pify "^4.0.1" rimraf "^2.6.3" -del@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/del/-/del-6.0.0.tgz#0b40d0332cea743f1614f818be4feb717714c952" - integrity sha512-1shh9DQ23L16oXSZKB2JxpL7iMy2E0S9d517ptA1P8iw0alkPtQcrKH7ru31rYtKwF499HkTu+DRzq3TCKDFRQ== - dependencies: - globby "^11.0.1" - graceful-fs "^4.2.4" - is-glob "^4.0.1" - is-path-cwd "^2.2.0" - is-path-inside "^3.0.2" - p-map "^4.0.0" - rimraf "^3.0.2" - slash "^3.0.0" - depd@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" @@ -2632,13 +2592,6 @@ diffie-hellman@^5.0.0: miller-rabin "^4.0.0" randombytes "^2.0.0" -dir-glob@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" - integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== - dependencies: - path-type "^4.0.0" - dmg-builder@22.4.1: version "22.4.1" resolved "https://registry.yarnpkg.com/dmg-builder/-/dmg-builder-22.4.1.tgz#ab80d3d6e4ed8a1d38beddbfe97c8f7a794dd932" @@ -3294,17 +3247,6 @@ fast-deep-equal@^3.1.1: resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.1.1: - version "3.2.7" - resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.7.tgz#fd6cb7a2d7e9aa7a7846111e85a196d6b2f766a1" - integrity sha512-rYGMRwip6lUMvYD3BTScMwT1HtAs2d71SMv66Vrxs0IekGZEjhM0pcMfjQPnknBt2zeCwQMEupiN02ZP4DiT1Q== - dependencies: - "@nodelib/fs.stat" "^2.0.2" - "@nodelib/fs.walk" "^1.2.3" - glob-parent "^5.1.2" - merge2 "^1.3.0" - micromatch "^4.0.4" - fast-json-stable-stringify@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" @@ -3315,13 +3257,6 @@ fast-levenshtein@^2.0.6: resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= -fastq@^1.6.0: - version "1.13.0" - resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.13.0.tgz#616760f88a7526bdfc596b7cab8c18938c36b98c" - integrity sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw== - dependencies: - reusify "^1.0.4" - faye-websocket@^0.11.3: version "0.11.4" resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.4.tgz#7f0d9275cfdd86a1c963dc8b65fcc451edcbb1da" @@ -3638,7 +3573,7 @@ glob-parent@^3.1.0: is-glob "^3.1.0" path-dirname "^1.0.0" -glob-parent@^5.0.0, glob-parent@^5.1.2, glob-parent@~5.1.2: +glob-parent@^5.0.0, glob-parent@~5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== @@ -3749,18 +3684,6 @@ globalthis@^1.0.1: dependencies: define-properties "^1.1.3" -globby@^11.0.1: - version "11.0.4" - resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.4.tgz#2cbaff77c2f2a62e71e9b2813a67b97a3a3001a5" - integrity sha512-9O4MVG9ioZJ08ffbcyVYyLOJLk5JQ688pJ4eMGLpdWLHq/Wr1D9BlriLQyL0E+jbkuePVZXYFj47QM/v093wHg== - dependencies: - array-union "^2.1.0" - dir-glob "^3.0.1" - fast-glob "^3.1.1" - ignore "^5.1.4" - merge2 "^1.3.0" - slash "^3.0.0" - globby@^6.1.0: version "6.1.0" resolved "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz#f5a6d70e8395e21c858fb0489d64df02424d506c" @@ -3789,7 +3712,7 @@ got@^9.6.0: to-readable-stream "^1.0.0" url-parse-lax "^3.0.0" -graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.2, graceful-fs@^4.2.4: +graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.2: version "4.2.8" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.8.tgz#e412b8d33f5e006593cbd3cee6df9f2cebbe802a" integrity sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg== @@ -4095,11 +4018,6 @@ ignore@^4.0.6: resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== -ignore@^5.1.4: - version "5.1.8" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.8.tgz#f150a8b50a34289b33e22f5889abd4d8016f0e57" - integrity sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw== - import-fresh@^3.0.0, import-fresh@^3.2.1: version "3.3.0" resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" @@ -4408,7 +4326,7 @@ is-obj@^2.0.0: resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== -is-path-cwd@^2.0.0, is-path-cwd@^2.2.0: +is-path-cwd@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-2.2.0.tgz#67d43b82664a7b5191fd9119127eb300048a9fdb" integrity sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ== @@ -4427,7 +4345,7 @@ is-path-inside@^2.1.0: dependencies: path-is-inside "^1.0.2" -is-path-inside@^3.0.1, is-path-inside@^3.0.2: +is-path-inside@^3.0.1: version "3.0.3" resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== @@ -4860,11 +4778,6 @@ merge-stream@^2.0.0: resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== -merge2@^1.3.0: - version "1.4.1" - resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" - integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== - methods@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" @@ -4889,14 +4802,6 @@ micromatch@^3.0.4, micromatch@^3.1.10, micromatch@^3.1.4: snapdragon "^0.8.1" to-regex "^3.0.2" -micromatch@^4.0.4: - version "4.0.4" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.4.tgz#896d519dfe9db25fce94ceb7a500919bf881ebf9" - integrity sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg== - dependencies: - braces "^3.0.1" - picomatch "^2.2.3" - miller-rabin@^4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" @@ -5384,13 +5289,6 @@ p-map@^3.0.0: dependencies: aggregate-error "^3.0.0" -p-map@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" - integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== - dependencies: - aggregate-error "^3.0.0" - p-retry@^3.0.1: version "3.0.1" resolved "https://registry.yarnpkg.com/p-retry/-/p-retry-3.0.1.tgz#316b4c8893e2c8dc1cfa891f406c4b422bebf328" @@ -5526,11 +5424,6 @@ path-to-regexp@0.1.7: resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= -path-type@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" - integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== - pbkdf2@^3.0.3: version "3.1.2" resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.2.tgz#dd822aa0887580e52f1a039dc3eda108efae3075" @@ -5564,7 +5457,7 @@ picocolors@^1.0.0: resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== -picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3: +picomatch@^2.0.4, picomatch@^2.2.1: version "2.3.0" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.0.tgz#f1f061de8f6a4bf022892e2d128234fb98302972" integrity sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw== @@ -5826,11 +5719,6 @@ querystringify@^2.1.1: resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== -queue-microtask@^1.2.2: - version "1.2.3" - resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" - integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== - randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5, randombytes@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" @@ -6129,11 +6017,6 @@ retry@^0.12.0: resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" integrity sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs= -reusify@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" - integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== - rimraf@^2.5.2, rimraf@^2.5.4, rimraf@^2.6.3, rimraf@^2.7.1: version "2.7.1" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" @@ -6168,13 +6051,6 @@ roarr@^2.15.3: semver-compare "^1.0.0" sprintf-js "^1.1.2" -run-parallel@^1.1.9: - version "1.2.0" - resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" - integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== - dependencies: - queue-microtask "^1.2.2" - run-queue@^1.0.0, run-queue@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/run-queue/-/run-queue-1.0.3.tgz#e848396f057d223f24386924618e25694161ec47" @@ -6430,11 +6306,6 @@ sirv@^1.0.7: mime "^2.3.1" totalist "^1.0.0" -slash@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" - integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== - slice-ansi@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b" From 0bacc1cb481c1f0b133a66b941e11e314cc2812e Mon Sep 17 00:00:00 2001 From: Zack Rauen Date: Fri, 22 Oct 2021 02:16:05 -0400 Subject: [PATCH 4/6] Prompt to transfer old addons Fixes #27 --- src/renderer/actions/install.js | 52 +++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/src/renderer/actions/install.js b/src/renderer/actions/install.js index 161b26f8..c1b75ee4 100644 --- a/src/renderer/actions/install.js +++ b/src/renderer/actions/install.js @@ -15,15 +15,44 @@ import {showRestartNotice} from "./utils/notices"; import doSanityCheck from "./utils/sanity"; const MAKE_DIR_PROGRESS = 30; +const CHECK_OLD_INSTALL = 40; +const TRANSFER_OLD_ADDONS = 50; const DOWNLOAD_PACKAGE_PROGRESS = 60; const INJECT_SHIM_PROGRESS = 90; const RESTART_DISCORD_PROGRESS = 100; +const oldBDFolder = path.join(remote.app.getPath("home"), "Preferences", "betterdiscord"); // MacOS const bdFolder = path.join(remote.app.getPath("appData"), "BetterDiscord"); const bdDataFolder = path.join(bdFolder, "data"); const bdPluginsFolder = path.join(bdFolder, "plugins"); const bdThemesFolder = path.join(bdFolder, "themes"); +async function checkOldMacOS(folder) { + if (await exists(folder)) { + log(`⚠️ Found old BD installation: ${folder}`); + return true; + } + return false; +} + +async function transferOldAddons(oldFolder, newFolder) { + if (await exists(oldFolder)) { + const addons = await fs.readdir(oldFolder); + for (let a = 0; a < addons.length; a++) { + const oldName = path.join(oldFolder, addons[a]); + const newName = path.join(newFolder, addons[a]); + const stats = await fs.stat(); + if (!stats.isFile()) continue; + try { + await fs.rename(oldName, newName); + } + catch (err) { + log(`❌ Failed to transfer: ${addons[a]}`); + } + } + } +} + async function makeDirectories(...folders) { const progressPerLoop = (MAKE_DIR_PROGRESS - progress.value) / folders.length; for (const folder of folders) { @@ -110,6 +139,29 @@ export default async function(config) { if (makeDirErr) return fail(); log("✅ Directories created"); progress.set(MAKE_DIR_PROGRESS); + + + if (process.platform === "darwin") { + lognewline("Checking for old MacOS installation..."); + const found = await checkOldMacOS(oldBDFolder); + progress.set(CHECK_OLD_INSTALL); + if (found) { + const confirmation = await remote.dialog.showMessageBox(remote.BrowserWindow.getFocusedWindow(), { + type: "question", + title: "Old Install Found", + message: "Found an old BD installation, do you want to transfer your plugins and themes?", + noLink: true, + cancelId: 1, + buttons: ["Yes", "No"] + }); + + if (confirmation.response === 0) { + await transferOldAddons(path.join(oldBDFolder, "plugins"), path.join(bdFolder, "plugins")); + await transferOldAddons(path.join(oldBDFolder, "themes"), path.join(bdFolder, "themes")); + progress.set(TRANSFER_OLD_ADDONS); + } + } + } lognewline("Downloading asar file"); From ee0e1bdab7db41967281872113001cea28ff9db2 Mon Sep 17 00:00:00 2001 From: Zack Date: Fri, 22 Oct 2021 17:51:51 -0400 Subject: [PATCH 5/6] Finalize old macos transfer --- src/renderer/actions/install.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/renderer/actions/install.js b/src/renderer/actions/install.js index c1b75ee4..e917da2b 100644 --- a/src/renderer/actions/install.js +++ b/src/renderer/actions/install.js @@ -21,7 +21,7 @@ const DOWNLOAD_PACKAGE_PROGRESS = 60; const INJECT_SHIM_PROGRESS = 90; const RESTART_DISCORD_PROGRESS = 100; -const oldBDFolder = path.join(remote.app.getPath("home"), "Preferences", "betterdiscord"); // MacOS +const oldBDFolder = path.join(remote.app.getPath("home"), "Library", "Preferences", "betterdiscord"); // Old MacOS const bdFolder = path.join(remote.app.getPath("appData"), "BetterDiscord"); const bdDataFolder = path.join(bdFolder, "data"); const bdPluginsFolder = path.join(bdFolder, "plugins"); @@ -41,7 +41,7 @@ async function transferOldAddons(oldFolder, newFolder) { for (let a = 0; a < addons.length; a++) { const oldName = path.join(oldFolder, addons[a]); const newName = path.join(newFolder, addons[a]); - const stats = await fs.stat(); + const stats = await fs.stat(oldName); if (!stats.isFile()) continue; try { await fs.rename(oldName, newName); From fa31f1a177ee41067666470dba2f8d4aa8a8a33b Mon Sep 17 00:00:00 2001 From: Zack Rauen Date: Sat, 23 Oct 2021 14:13:49 -0400 Subject: [PATCH 6/6] Increment version for release --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 6febfa66..a1a2f014 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,7 @@ "productName": "BetterDiscord Installer", "description": "A simple standalone program which automates the installation, removal and maintenance of BetterDiscord.", "author": "BetterDiscord", - "version": "1.1.0", + "version": "1.1.1", "license": "MIT", "scripts": { "dev": "electron-webpack dev",