From 35c5b24bb6b6bc2b3267f507c7e8fa2f9e6ea8f1 Mon Sep 17 00:00:00 2001 From: Kamesuta Date: Sun, 1 Oct 2023 19:20:08 +0900 Subject: [PATCH 1/2] Execute Forge Installer locally --- app/assets/js/processbuilder.js | 7 +++++++ app/assets/js/scripts/landing.js | 27 +++++++++++++++++++++++++++ libraries/java/ForgeInstallerCLI.jar | Bin 0 -> 7880 bytes 3 files changed, 34 insertions(+) create mode 100644 libraries/java/ForgeInstallerCLI.jar diff --git a/app/assets/js/processbuilder.js b/app/assets/js/processbuilder.js index b86698c4..5b30dfe8 100644 --- a/app/assets/js/processbuilder.js +++ b/app/assets/js/processbuilder.js @@ -836,6 +836,13 @@ class ProcessBuilder { libs = {...libs, ...res} } } + } else if(type === Type.Forge){ + // Forge installer generated libraries + const forgeLibs = [] + for (const library of this.forgeData.libraries) { + forgeLibs.push(path.join(ConfigManager.getCommonDirectory(), 'libraries', library.downloads.artifact.path)) + } + libs = {...libs, ...forgeLibs} } } diff --git a/app/assets/js/scripts/landing.js b/app/assets/js/scripts/landing.js index 94d311a0..d2c2c89a 100644 --- a/app/assets/js/scripts/landing.js +++ b/app/assets/js/scripts/landing.js @@ -5,6 +5,7 @@ const cp = require('child_process') const crypto = require('crypto') const { URL } = require('url') +const { join } = require('path') const { MojangRestAPI, getServerStatus @@ -552,6 +553,32 @@ async function dlAsync(login = true) { serv.rawServer.id ) + // Install Forge + let wrapperPath + if(isDev) { + wrapperPath = join(process.cwd(), 'libraries', 'java', 'ForgeInstallerCLI.jar') + } else { + if(process.platform === 'darwin'){ + wrapperPath = join(process.cwd(), 'Contents', 'Resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') + } else { + wrapperPath = join(process.cwd(), 'resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') + } + } + + // Launch Forge Installer + loggerLaunchSuite.info('Installing Forge.') + setLaunchDetails('Installing Forge..') + setLaunchPercentage(0) + const jExe = ConfigManager.getJavaExecutable(ConfigManager.getSelectedServer()) + await distributionIndexProcessor.installForge(jExe, wrapperPath, percent => { + setDownloadPercentage(percent) + }) + setDownloadPercentage(100) + + // Remove download bar. + remote.getCurrentWindow().setProgressBar(-1) + + // After Forge installed, we can get the Forge version data. const forgeData = await distributionIndexProcessor.loadForgeVersionJson(serv) const versionData = await mojangIndexProcessor.getVersionJson() diff --git a/libraries/java/ForgeInstallerCLI.jar b/libraries/java/ForgeInstallerCLI.jar new file mode 100644 index 0000000000000000000000000000000000000000..759ca92747e8d33593c410fd6ff0a4eda36b09a7 GIT binary patch literal 7880 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 Date: Sat, 14 Oct 2023 13:29:15 +0900 Subject: [PATCH 2/2] Fix ForgeInstallerCLI path for cross-platform. --- app/assets/js/scripts/landing.js | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/app/assets/js/scripts/landing.js b/app/assets/js/scripts/landing.js index d2c2c89a..bf3690ad 100644 --- a/app/assets/js/scripts/landing.js +++ b/app/assets/js/scripts/landing.js @@ -558,10 +558,11 @@ async function dlAsync(login = true) { if(isDev) { wrapperPath = join(process.cwd(), 'libraries', 'java', 'ForgeInstallerCLI.jar') } else { + const exePath = remote.app.getPath('exe') if(process.platform === 'darwin'){ - wrapperPath = join(process.cwd(), 'Contents', 'Resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') + wrapperPath = join(exePath, '..', '..', 'Contents', 'Resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') } else { - wrapperPath = join(process.cwd(), 'resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') + wrapperPath = join(exePath, '..', 'resources', 'libraries', 'java', 'ForgeInstallerCLI.jar') } }