From 8c5217f9f2ac527ae9c2c53543bf5b958e1aa325 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sun, 21 Jul 2024 00:54:41 +0200 Subject: [PATCH 1/3] require node>=20 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index a3724a6e..6345e4a0 100644 --- a/package.json +++ b/package.json @@ -105,7 +105,7 @@ "sourceDir": "./dist/firefox-unpacked" }, "engines": { - "node": ">=18", + "node": ">=20", "pnpm": ">=9" } } From f9fb3bbba713613d156d1b7150f9551b373397e3 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sun, 21 Jul 2024 01:29:46 +0200 Subject: [PATCH 2/3] fix watch erroring when clean building --- scripts/build/common.mts | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/scripts/build/common.mts b/scripts/build/common.mts index 054a5667..3bc3dc39 100644 --- a/scripts/build/common.mts +++ b/scripts/build/common.mts @@ -261,6 +261,20 @@ export const stylePlugin: Plugin = { } }; +let buildsFinished = Promise.resolve(); +const buildsFinishedPlugin: Plugin = { + name: "builds-finished-plugin", + setup({ onEnd }) { + if (!watch) return; + + let resolve: () => void; + const done = new Promise(r => resolve = r); + buildsFinished = buildsFinished.then(() => done); + + onEnd(() => resolve()); + }, +}; + export const commonOpts = { logLevel: "info", bundle: true, @@ -268,7 +282,7 @@ export const commonOpts = { sourcemap: watch ? "inline" : "external", legalComments: "linked", banner, - plugins: [fileUrlPlugin, gitHashPlugin, gitRemotePlugin, stylePlugin], + plugins: [fileUrlPlugin, gitHashPlugin, gitRemotePlugin, stylePlugin, buildsFinishedPlugin], external: ["~plugins", "~git-hash", "~git-remote", "/assets/*"], inject: ["./scripts/build/inject/react.mjs"], jsxFactory: "VencordCreateElement", @@ -286,6 +300,8 @@ export async function buildOrWatchAll() { if (watch) { const contexts = await Promise.all(builds.map(context)); await Promise.all(contexts.map(ctx => ctx.watch())); + + await buildsFinished; } else { try { await Promise.all(builds.map(build)); From 7781dface9b0ea448d191a718beaabf14c6dfbc5 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sun, 21 Jul 2024 02:52:28 +0200 Subject: [PATCH 3/3] fix: apply update only on quit --- src/main/patcher.ts | 6 +----- src/main/updater/http.ts | 37 ++++++++++++++++++++++++++++++++++--- 2 files changed, 35 insertions(+), 8 deletions(-) diff --git a/src/main/patcher.ts b/src/main/patcher.ts index 6ab4162d..2c274028 100644 --- a/src/main/patcher.ts +++ b/src/main/patcher.ts @@ -27,11 +27,7 @@ import { IS_VANILLA } from "./utils/constants"; console.log("[Vencord] Starting up..."); // FIXME: remove at some point -const isLegacyNonAsarVencord = IS_STANDALONE && !__dirname.endsWith(".asar"); -if (isLegacyNonAsarVencord) { - console.warn("This is a legacy non asar install! Migrating to asar and restarting..."); - require("./updater/http").migrateLegacyToAsar(); -} +export const isLegacyNonAsarVencord = IS_STANDALONE && !__dirname.endsWith(".asar"); // Our injector file at app/index.js const injectorPath = require.main!.filename; diff --git a/src/main/updater/http.ts b/src/main/updater/http.ts index bd70b51d..70670a03 100644 --- a/src/main/updater/http.ts +++ b/src/main/updater/http.ts @@ -16,10 +16,15 @@ * along with this program. If not, see . */ +import { isLegacyNonAsarVencord } from "@main/patcher"; import { IpcEvents } from "@shared/IpcEvents"; import { VENCORD_USER_AGENT } from "@shared/vencordUserAgent"; import { app, dialog, ipcMain } from "electron"; -import { writeFileSync as originalWriteFileSync } from "original-fs"; +import { + existsSync as originalExistsSync, + renameSync as originalRenameSync, + writeFileSync as originalWriteFileSync, +} from "original-fs"; import { join } from "path"; import gitHash from "~git-hash"; @@ -31,6 +36,8 @@ import { ASAR_FILE, serializeErrors } from "./common"; const API_BASE = `https://api.github.com/repos/${gitRemote}`; let PendingUpdate: string | null = null; +let hasUpdateToApplyOnQuit = false; + async function githubGet(endpoint: string) { return get(API_BASE + endpoint, { headers: { @@ -76,7 +83,8 @@ async function applyUpdates() { if (!PendingUpdate) return true; const data = await get(PendingUpdate); - originalWriteFileSync(__dirname, data); + originalWriteFileSync(__dirname + ".new", data); + hasUpdateToApplyOnQuit = true; PendingUpdate = null; @@ -88,7 +96,7 @@ ipcMain.handle(IpcEvents.GET_UPDATES, serializeErrors(calculateGitChanges)); ipcMain.handle(IpcEvents.UPDATE, serializeErrors(fetchUpdates)); ipcMain.handle(IpcEvents.BUILD, serializeErrors(applyUpdates)); -export async function migrateLegacyToAsar() { +async function migrateLegacyToAsar() { try { const isFlatpak = process.platform === "linux" && !!process.env.FLATPAK_ID; if (isFlatpak) throw "Flatpak Discord can't automatically be migrated."; @@ -112,3 +120,26 @@ export async function migrateLegacyToAsar() { }); } } + +function applyPreviousUpdate() { + originalRenameSync(__dirname + ".new", __dirname); + + app.relaunch(); + app.exit(); +} + + +app.on("will-quit", () => { + if (hasUpdateToApplyOnQuit) + originalRenameSync(__dirname + ".new", __dirname); +}); + +if (isLegacyNonAsarVencord) { + console.warn("This is a legacy non asar install! Migrating to asar and restarting..."); + migrateLegacyToAsar(); +} + +if (originalExistsSync(__dirname + ".new")) { + console.warn("Found previous not applied update, applying now and restarting..."); + applyPreviousUpdate(); +}