From 81367bc6198f6cc4b0ef39824f1d2112ca40d3c3 Mon Sep 17 00:00:00 2001 From: Daniel Scalzi Date: Mon, 18 Feb 2019 06:31:01 -0500 Subject: [PATCH] 1.13 Update Phase 1 Mojang has changed its manifest format for 1.13. Forge is no longer a universal jar, it requires more hosted files, all of which are generated by the installer. We can no longer extract the version manifest from forge's jar and have to include it in the distribution. This commit adds support for launching forge only, mods are currently not supported from the distribution. Handling of 1.13 launches are subject to change as we move forward. --- app/assets/distribution.json | 414 ++++++++++++++++++++++++++----- app/assets/js/assetexec.js | 2 +- app/assets/js/assetguard.js | 90 ++++--- app/assets/js/distromanager.js | 20 +- app/assets/js/processbuilder.js | 180 +++++++++++++- app/assets/js/scripts/landing.js | 11 +- 6 files changed, 614 insertions(+), 103 deletions(-) diff --git a/app/assets/distribution.json b/app/assets/distribution.json index 734dca47..8d5c6788 100644 --- a/app/assets/distribution.json +++ b/app/assets/distribution.json @@ -15,7 +15,7 @@ "name": "WesterosCraft Production Server", "description": "Main WesterosCraft server. Connect to enter the Realm.", "icon": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/server-prod.png", - "version": "3.9.0", + "version": "3.9.4", "address": "mc.westeroscraft.com", "minecraftVersion": "1.11.2", "discord": { @@ -219,22 +219,22 @@ ] }, { - "id": "com.westeroscraft:westerosblocks:3.1.0-alpha-2-138", + "id": "com.westeroscraft:westerosblocks:3.2.0-beta-1-190", "name": "WesterosBlocks", "type": "ForgeMod", "artifact": { - "size": 17352677, - "MD5": "b5409aa925a47f67158c8141e71f723f", + "size": 17376788, + "MD5": "370f4f1804c93f498f31af8dac509605", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/prod-1.11.2/mods/WesterosBlocks.jar" } }, { - "id": "com.westeroscraft:westeroscraftrp:2018-07-21", + "id": "com.westeroscraft:westeroscraftrp:2019-01-21", "name": "WesterosCraft Resource Pack", "type": "File", "artifact": { - "size": 46942221, - "MD5": "26e3e63a5778691eb3a9db11f449fdf1", + "size": 46999843, + "MD5": "309eb9e5296e9f55cfecb7d4058245a4", "path": "resourcepacks/WesterosCraft.zip", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/prod-1.11.2/resourcepacks/WesterosCraft.zip" } @@ -260,15 +260,15 @@ } }, { - "id": "org.blockartistry:dynsurround:1.11.2-3.4.6.2", + "id": "org.blockartistry:dynsurround:1.11.2-3.4.9.3", "name": "DynamicSurroundings", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 21853035, - "MD5": "82a6aac5420151960b8dd709deee5423", + "size": 22291385, + "MD5": "65403c66d8b3655b372f58047941d206", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/prod-1.11.2/mods/DynamicSurroundings.jar" }, "subModules": [ @@ -278,7 +278,6 @@ "type": "File", "artifact": { "size": 20258, - "MD5": "3df81248db151750b7d0a0193b327b47", "path": "/config/dsurround/dsurround.cfg", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/prod-1.11.2/config/dsurround/dsurround.cfg" } @@ -297,15 +296,15 @@ ] }, { - "id": "octarine-noise:betterfoliage:1.11.2-2.1.8", + "id": "octarine-noise:betterfoliage:1.11.2-2.1.10", "name": "BetterFoliage", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 4676029, - "MD5": "b2dd47e42da56fb49a07a0d38df91bc4", + "size": 4675903, + "MD5": "522fdf73b6e4343cb6243872fb7b4b6c", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/prod-1.11.2/mods/BetterFoliage.jar" }, "subModules": [ @@ -430,7 +429,7 @@ "name": "WesterosCraft Test Server", "description": "Main testing server. Experimental changes are live here.", "icon": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/server-test.png", - "version": "3.8.3", + "version": "3.9.4", "address": "mc.westeroscraft.com:4444", "minecraftVersion": "1.11.2", "discord": { @@ -634,22 +633,22 @@ ] }, { - "id": "com.westeroscraft:westerosblocks:3.1.0-alpha-2-138", + "id": "com.westeroscraft:westerosblocks:3.2.0-beta-1-190", "name": "WesterosBlocks", "type": "ForgeMod", "artifact": { - "size": 17352677, - "MD5": "b5409aa925a47f67158c8141e71f723f", + "size": 17376788, + "MD5": "370f4f1804c93f498f31af8dac509605", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.11.2/mods/WesterosBlocks.jar" } }, { - "id": "com.westeroscraft:westeroscraftrp:2018-07-21", + "id": "com.westeroscraft:westeroscraftrp:2019-01-21", "name": "WesterosCraft Resource Pack", "type": "File", "artifact": { - "size": 46942221, - "MD5": "26e3e63a5778691eb3a9db11f449fdf1", + "size": 46999843, + "MD5": "309eb9e5296e9f55cfecb7d4058245a4", "path": "resourcepacks/WesterosCraft.zip", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.11.2/resourcepacks/WesterosCraft.zip" } @@ -693,7 +692,6 @@ "type": "File", "artifact": { "size": 20849, - "MD5": "8d6c08c158aa846162e2a179d6228181", "path": "/config/dsurround/dsurround.cfg", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.11.2/config/dsurround/dsurround.cfg" } @@ -857,13 +855,13 @@ "autoconnect": true, "modules": [ { - "id": "net.minecraftforge:forge:1.12.2-14.23.2.2651", + "id": "net.minecraftforge:forge:1.12.2-14.23.5.2797", "name": "Minecraft Forge", "type": "ForgeHosted", "artifact": { - "size": 4823957, - "MD5": "42d3aec7cdd6e4e49b4ff77a1db7c3a9", - "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/1.12.2/forge-1.12.2-14.23.2.2651-universal.jar" + "size": 4937218, + "MD5": "5320593704af58b3906e7106d27e41c8", + "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/1.12.2/forge-1.12.2-14.23.5.2797-universal.jar" }, "subModules": [ { @@ -1046,6 +1044,16 @@ "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/1.12.2/jopt-simple-5.0.3.jar" } }, + { + "id": "org.apache.maven:maven-artifact:3.5.3", + "name": "maven-artifact", + "type": "Library", + "artifact": { + "size": 54961, + "MD5": "7741ebf29690ee7d9dde9cf4376347fc", + "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/1.12.2/maven-artifact-3.5.3.jar" + } + }, { "id": "net.minecraftforge:MercuriusUpdater:1.12.2", "name": "MercuriusUpdater", @@ -1059,56 +1067,56 @@ ] }, { - "id": "com.westeroscraft:westerosblocks:3.1.0-alpha-2-10", + "id": "com.westeroscraft:westerosblocks:4.0.0-beta-1-66", "name": "WesterosBlocks", "type": "ForgeMod", "artifact": { - "size": 17261877, - "MD5": "f23568619e6fc2bf0cdbdcc05b6a8af9", + "size": 17286330, + "MD5": "e5c38ef42e9cc4b957122207dcf95f4f", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/WesterosBlocks.jar" } }, { - "id": "com.westeroscraft:westeroscraftrp:2018-07-21", + "id": "com.westeroscraft:westeroscraftrp:2019-01-21", "name": "WesterosCraft Resource Pack", "type": "File", "artifact": { - "size": 46944689, - "MD5": "caa806fb84e56c6c230e56b17670f2bc", + "size": 47002312, + "MD5": "86b169611ca0e51fdc47384d8423c402", "path": "resourcepacks/WesterosCraft.zip", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/resourcepacks/WesterosCraft.zip" } }, { - "id": "net.optifine:optifine:1.12.2_HD_U_D1", + "id": "net.optifine:optifine:1.12.2_HD_U_E3", "name": "Optifine", "type": "ForgeMod", "artifact": { - "size": 2372821, - "MD5": "4bfc1c95dde8ec08568e01bfaa61e7c5", + "size": 2444057, + "MD5": "7ec95c57ac1a224d6eb93bd370e4ac37", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/OptiFine.jar" } }, { - "id": "mezz:jei:1.12.2-4.8.5.151", + "id": "mezz:jei:1.12.2-4.14.3.242", "name": "JustEnoughItems", "type": "ForgeMod", "artifact": { - "size": 545366, - "MD5": "7194b7b1f1ea6ad20013c596319db5b0", + "size": 620682, + "MD5": "ae6d0e6e873ef6c20f41097dc7fee8c6", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/jei.jar" } }, { - "id": "org.blockartistry:dynsurround:1.12.2-3.4.9.3", + "id": "org.blockartistry:dynsurround:1.12.2-3.4.10.5", "name": "DynamicSurroundings", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 22298474, - "MD5": "115baf8e5f4e7d9757a2a85fb3507789", + "size": 22507134, + "MD5": "3d75602c66b7ccfc23c342e8d5e07469", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/DynamicSurroundings.jar" }, "subModules": [ @@ -1117,8 +1125,7 @@ "name": "DynamicSurroundings General Configuration File", "type": "File", "artifact": { - "size": 21195, - "MD5": "850f1103765f45698954b4e3b0b0369d", + "size": 22179, "path": "/config/dsurround/dsurround.cfg", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/config/dsurround/dsurround.cfg" } @@ -1137,15 +1144,15 @@ ] }, { - "id": "octarine-noise:betterfoliage:1.12-2.1.10", + "id": "octarine-noise:betterfoliage:1.12-2.2.0", "name": "BetterFoliage", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 4671397, - "MD5": "06714eb2c13f59df5e3c92cec7370e11", + "size": 926081, + "MD5": "e05a720c5900b9bac4e01179abe8eef6", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/BetterFoliage.jar" }, "subModules": [ @@ -1163,28 +1170,38 @@ ] }, { - "id": "techbrew:journeymap:1.12.2-5.5.2", + "id": "forgelin:forgelin:1.8.2", + "name": "Forgelin", + "type": "ForgeMod", + "artifact": { + "size": 5124663, + "MD5": "59035365f7af35f599d1c4baade64d8b", + "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/Forgelin.jar" + } + }, + { + "id": "techbrew:journeymap:1.12.2-5.5.3", "name": "JourneyMap", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 1822850, - "MD5": "b743562dac1b5334c20ac87b54c0b518", + "size": 1831161, + "MD5": "d3b5a672d2393f9fe63903598d50c769", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/journeymap.jar" } }, { - "id": "com.github.hexomod:worldeditcuife2:2.1.2-mf-1.12.2-14.23.0.2487", + "id": "com.github.hexomod:worldeditcuife2:2.2.0-mf-1.12.2-14.23.5.2768", "name": "WorldEditCUI", "type": "ForgeMod", "required": { "value": false }, "artifact": { - "size": 461808, - "MD5": "44b1b1031c25f04955bfd7ed734bd467", + "size": 459294, + "MD5": "2b8c1c3bc48c2d80b71daa658f656edb", "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/mods/worldeditcuife.jar" } }, @@ -1219,14 +1236,14 @@ ] }, { - "id": "com.sonicether:seus:11.0", - "name": "Sonic Ether's Unbelievable Shaders", + "id": "com.sonicether:seus-renewed:1.0.0", + "name": "Sonic Ether's Unbelievable Shaders Renewed", "type": "File", "artifact": { - "size": 175159, - "MD5": "bfa8c31d1da8131b59917bb2460205b1", - "path": "shaderpacks/SEUS v11.0.zip", - "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/shaderpacks/SEUS.zip" + "size": 7062491, + "MD5": "e68cc9f8ffc8fad66583b9b2cc05356f", + "path": "shaderpacks/SEUS-Renewed.zip", + "url": "http://mc.westeroscraft.com/WesterosCraftLauncher/test-1.12.2/shaderpacks/SEUS-Renewed.zip" } }, { @@ -1251,6 +1268,287 @@ } } ] + }, + { + "id": "WesterosCraftTest-1.13.2", + "name": "WesterosCraft 1.13.2 Test Server", + "description": "Tests for our version change to 1.13.2 are live here.", + "icon": "http://mc.westeroscraft.com/WesterosCraftLauncher/files/server-test.png", + "version": "5.0.0", + "address": "mc.westeroscraft.com:4445", + "minecraftVersion": "1.13.2", + "discord": { + "shortId": "1.13.2 Test Server", + "largeImageText": "WesterosCraft 1.13.2 Test Server", + "largeImageKey": "server-test" + }, + "mainServer": false, + "autoconnect": false, + "modules": [ + { + "id": "net.minecraftforge:forge:1.13.2-25.0.26", + "name": "Minecraft Forge (base jar)", + "type": "ForgeHosted", + "artifact": { + "size": 4937218, + "MD5": "6efa97b23a1a0982fbdb61168f972045", + "url": "" + }, + "subModules": [ + { + "id": "net.minecraftforge:forge:1.13.2-25.0.26:universal", + "name": "Minecraft Forge (universal jar)", + "type": "Library", + "artifact": { + "size": 2234772 , + "MD5": "d35aa9e0a2149682716244373a369ce3", + "url": "" + } + }, + { + "id": "net.minecraftforge:forge:1.13.2-25.0.26:client", + "name": "Minecraft Forge (client jar)", + "type": "Library", + "artifact": { + "size": 2928187, + "MD5": "6454bbb04448b3a1a6adde4f827ce73d", + "url": "" + } + }, + { + "id": "net.minecraft:client:1.13.2:data", + "name": "Minecraft Forge (client data)", + "type": "Library", + "artifact": { + "size": 9622361, + "MD5": "dc66e2219e3de6e7ca05847fd3c7746d", + "url": "" + } + }, + { + "id": "net.minecraft:client:1.13.2:extra", + "name": "Minecraft Forge (client extra)", + "type": "Library", + "artifact": { + "size": 22, + "MD5": "76cdb2bad9582d23c1f6f4d868218d6c", + "url": "" + } + }, + { + "id": "net.minecraft:client:1.13.2-20190213.203750:srg", + "name": "Minecraft Forge (client srg)", + "type": "Library", + "artifact": { + "size": 8198877, + "MD5": "9cb4b80fe6949e74b6f6c11d640747ae", + "url": "" + } + }, + { + "id": "1.13.2-forge-25.0.26", + "name": "Minecraft Forge (version.jar)", + "type": "VersionJar", + "artifact": { + "size": 16089640, + "MD5": "0d20673fc03f9c6a60279146ee1b1a14", + "url": "" + } + }, + { + "id": "1.13.2-forge-25.0.26", + "name": "Minecraft Forge (version.json)", + "type": "VersionManifest", + "artifact": { + "size": 10466, + "MD5": "bc27fba2e3551d77bfbb06614398cf33", + "url": "" + } + }, + { + "id": "com.paulscode:soundsystem:201809301515", + "name": "Minecraft Forge (Paul's Code Soundsystem)", + "type": "Library", + "artifact": { + "size": 66607, + "MD5": "bf43e7b9f628534614b3fc5e4e69d209", + "url": "" + } + }, + { + "id": "org.ow2.asm:asm:6.2", + "name": "Minecraft Forge (asm)", + "type": "Library", + "artifact": { + "size": 111214, + "MD5": "7abdce94068615d690495f45eb6eb980", + "url": "" + } + }, + { + "id": "org.ow2.asm:asm-commons:6.2", + "name": "Minecraft Forge (asm-commons)", + "type": "Library", + "artifact": { + "size": 78919, + "MD5": "a031c9a32770c02c2f91d2bcbeceabcd", + "url": "" + } + }, + { + "id": "org.ow2.asm:asm-tree:6.2", + "name": "Minecraft Forge (asm-tree)", + "type": "Library", + "artifact": { + "size": 50370, + "MD5": "e7279981c6764dcd73a99705acf5c9a6", + "url": "" + } + }, + { + "id": "cpw.mods:modlauncher:0.9.5", + "name": "Minecraft Forge (modlauncher)", + "type": "Library", + "artifact": { + "size": 78880, + "MD5": "13e299c5af2eb3707108fda0e09307d4", + "url": "" + } + }, + { + "id": "net.minecraftforge:accesstransformers:0.14.4-shadowed", + "name": "Minecraft Forge (Access Transformers)", + "type": "Library", + "artifact": { + "size": 441002, + "MD5": "b56c2d2faeef20dd870d47c442e73a35", + "url": "" + } + }, + { + "id": "net.minecraftforge:eventbus:0.7.1-service", + "name": "Minecraft Forge (EventBus)", + "type": "Library", + "artifact": { + "size": 36617, + "MD5": "a23071862888fee2b36882546c53dc98", + "url": "" + } + }, + { + "id": "net.minecraftforge:forgespi:0.6.0", + "name": "Minecraft Forge (Forge SPI)", + "type": "Library", + "artifact": { + "size": 15429, + "MD5": "3a9ac484bde11412cb8112f67ed91b97", + "url": "" + } + }, + { + "id": "net.minecraftforge:coremods:0.3.0", + "name": "Minecraft Forge (coremods)", + "type": "Library", + "artifact": { + "size": 10598, + "MD5": "2f16029f918a74f9d550417cfc35a287", + "url": "" + } + }, + { + "id": "com.electronwill.night-config:core:3.4.2", + "name": "Minecraft Forge (night-config core)", + "type": "Library", + "artifact": { + "size": 189896, + "MD5": "a96945eb67f63c9014b950c037d7a605", + "url": "" + } + }, + { + "id": "com.electronwill.night-config:toml:3.4.2", + "name": "Minecraft Forge (night-config toml)", + "type": "Library", + "artifact": { + "size": 30619, + "MD5": "b0030fa6166179c0a971fd53e8fcfbfc", + "url": "" + } + }, + { + "id": "org.jline:jline:3.9.0", + "name": "Minecraft Forge (jline)", + "type": "Library", + "artifact": { + "size": 707273, + "MD5": "2db9aae140f810a72fc4a5cb5aa5cf9b", + "url": "" + } + }, + { + "id": "org.apache.maven:maven-artifact:3.6.0", + "name": "Minecraft Forge (maven-artifact)", + "type": "Library", + "artifact": { + "size": 55051, + "MD5": "89e95013b11f347e48c0525965600404", + "url": "" + } + }, + { + "id": "net.jodah:typetools:0.6.0", + "name": "Minecraft Forge (typetools)", + "type": "Library", + "artifact": { + "size": 14734, + "MD5": "9f65b6e90eb986fe25afc39b8ed3f43b", + "url": "" + } + }, + { + "id": "java3d:vecmath:1.5.2", + "name": "Minecraft Forge (vecmath)", + "type": "Library", + "artifact": { + "size": 318956, + "MD5": "e5d2b7f46c4800a32f62ce75676a5710", + "url": "" + } + }, + { + "id": "org.apache.logging.log4j:log4j-api:2.11.1", + "name": "Minecraft Forge (log4j-api)", + "type": "Library", + "artifact": { + "size": 264060, + "MD5": "fc110208241ce5b48bd07464ecc7e137", + "url": "" + } + }, + { + "id": "org.apache.logging.log4j:log4j-core:2.11.1", + "name": "Minecraft Forge (log4j-core)", + "type": "Library", + "artifact": { + "size": 1607947, + "MD5": "b2242de0677be6515d6cefbf48e7e5d5", + "url": "" + } + }, + { + "id": "net.minecrell:terminalconsoleappender:1.1.1", + "name": "Minecraft Forge (terminalconsoleappender)", + "type": "Library", + "artifact": { + "size": 15240, + "MD5": "a190e88073a41dfa1b1d47854c41230b", + "url": "" + } + } + + ] + } + ] } ] } \ No newline at end of file diff --git a/app/assets/js/assetexec.js b/app/assets/js/assetexec.js index d6951f8d..fe5074b4 100644 --- a/app/assets/js/assetexec.js +++ b/app/assets/js/assetexec.js @@ -33,7 +33,7 @@ process.on('message', (msg) => { res.then((v) => { process.send({result: v, context: func}) }).catch((err) => { - process.send({result: err.message, context: func}) + process.send({result: err.message || err, context: func}) }) } else { process.send({result: res, context: func}) diff --git a/app/assets/js/assetguard.js b/app/assets/js/assetguard.js index 9d348356..009df502 100644 --- a/app/assets/js/assetguard.js +++ b/app/assets/js/assetguard.js @@ -1401,12 +1401,28 @@ class AssetGuard extends EventEmitter { for(let ob of modules){ const type = ob.getType() if(type === DistroManager.Types.ForgeHosted || type === DistroManager.Types.Forge){ - let obArtifact = ob.getArtifact() - let obPath = obArtifact.getPath() - let asset = new DistroModule(ob.getIdentifier(), obArtifact.getHash(), obArtifact.getSize(), obArtifact.getURL(), obPath, type) - let forgeData = await AssetGuard._finalizeForgeAsset(asset, self.commonPath) - resolve(forgeData) - return + if(AssetGuard.mcVersionAtLeast('1.13', server.getMinecraftVersion())){ + for(let sub of ob.getSubModules()){ + if(sub.getType() === DistroManager.Types.VersionManifest){ + const versionFile = path.join(self.commonPath, 'versions', sub.getIdentifier(), `${sub.getIdentifier()}.json`) + resolve(JSON.parse(fs.readFileSync(versionFile, 'utf-8'))) + return + } + } + reject('No forge version manifest found!') + return + } else { + let obArtifact = ob.getArtifact() + let obPath = obArtifact.getPath() + let asset = new DistroModule(ob.getIdentifier(), obArtifact.getHash(), obArtifact.getSize(), obArtifact.getURL(), obPath, type) + try { + let forgeData = await AssetGuard._finalizeForgeAsset(asset, self.commonPath) + resolve(forgeData) + } catch (err){ + reject(err) + } + return + } } } reject('No forge module found!') @@ -1686,34 +1702,44 @@ class AssetGuard extends EventEmitter { async validateEverything(serverid, dev = false){ - if(!ConfigManager.isLoaded()){ - ConfigManager.load() - } - DistroManager.setDevMode(dev) - const dI = await DistroManager.pullLocal() - - const server = dI.getServer(serverid) - - // Validate Everything - - await this.validateDistribution(server) - this.emit('validate', 'distribution') - const versionData = await this.loadVersionData(server.getMinecraftVersion()) - this.emit('validate', 'version') - await this.validateAssets(versionData) - this.emit('validate', 'assets') - await this.validateLibraries(versionData) - this.emit('validate', 'libraries') - await this.validateMiscellaneous(versionData) - this.emit('validate', 'files') - await this.processDlQueues() - //this.emit('complete', 'download') - const forgeData = await this.loadForgeData(server) + try { + if(!ConfigManager.isLoaded()){ + ConfigManager.load() + } + DistroManager.setDevMode(dev) + const dI = await DistroManager.pullLocal() - return { - versionData, - forgeData + const server = dI.getServer(serverid) + + // Validate Everything + + await this.validateDistribution(server) + this.emit('validate', 'distribution') + const versionData = await this.loadVersionData(server.getMinecraftVersion()) + this.emit('validate', 'version') + await this.validateAssets(versionData) + this.emit('validate', 'assets') + await this.validateLibraries(versionData) + this.emit('validate', 'libraries') + await this.validateMiscellaneous(versionData) + this.emit('validate', 'files') + await this.processDlQueues() + //this.emit('complete', 'download') + const forgeData = await this.loadForgeData(server) + + return { + versionData, + forgeData + } + + } catch (err){ + return { + versionData: null, + forgeData: null, + error: err + } } + } diff --git a/app/assets/js/distromanager.js b/app/assets/js/distromanager.js index b6adefde..6b812ab5 100644 --- a/app/assets/js/distromanager.js +++ b/app/assets/js/distromanager.js @@ -163,6 +163,7 @@ class Module { const m1 = m0[0].split(':') + this.artifactClassifier = m1[3] || undefined this.artifactVersion = m1[2] || '???' this.artifactID = m1[1] || '???' this.artifactGroup = m1[0] || '???' @@ -174,7 +175,7 @@ class Module { } _resolveArtifactPath(artifactPath, serverid){ - const pth = artifactPath == null ? path.join(...this.getGroup().split('.'), this.getID(), this.getVersion(), `${this.getID()}-${this.getVersion()}.${this.getExtension()}`) : artifactPath + const pth = artifactPath == null ? path.join(...this.getGroup().split('.'), this.getID(), this.getVersion(), `${this.getID()}-${this.getVersion()}${this.artifactClassifier != undefined ? `-${this.artifactClassifier}` : ''}.${this.getExtension()}`) : artifactPath switch (this.type){ case exports.Types.Library: @@ -186,6 +187,12 @@ class Module { case exports.Types.LiteMod: this.artifact.path = path.join(ConfigManager.getCommonDirectory(), 'modstore', pth) break + case exports.Types.VersionManifest: + this.artifact.path = path.join(ConfigManager.getCommonDirectory(), 'versions', this.getIdentifier(), `${this.getIdentifier()}.json`) + break + case exports.Types.VersionJar: + this.artifact.path = path.join(ConfigManager.getCommonDirectory(), 'versions', this.getIdentifier(), `${this.getIdentifier()}.jar`) + break case exports.Types.File: default: this.artifact.path = path.join(ConfigManager.getInstanceDirectory(), serverid, pth) @@ -267,6 +274,13 @@ class Module { return this.artifactVersion } + /** + * @returns {string} The classifier of this module's artifact + */ + getClassifier(){ + return this.artifactClassifier + } + /** * @returns {string} The extension of this module's artifact. */ @@ -507,7 +521,9 @@ exports.Types = { LiteLoader: 'LiteLoader', ForgeMod: 'ForgeMod', LiteMod: 'LiteMod', - File: 'File' + File: 'File', + VersionManifest: 'VersionManifest', + VersionJar: 'VersionJar' } let DEV_MODE = false diff --git a/app/assets/js/processbuilder.js b/app/assets/js/processbuilder.js index 6e255700..f6b9b56c 100644 --- a/app/assets/js/processbuilder.js +++ b/app/assets/js/processbuilder.js @@ -4,24 +4,25 @@ const crypto = require('crypto') const fs = require('fs-extra') const os = require('os') const path = require('path') -const {URL} = require('url') +const { URL } = require('url') -const { Library } = require('./assetguard') -const ConfigManager = require('./configmanager') -const DistroManager = require('./distromanager') -const LoggerUtil = require('./loggerutil') +const { AssetGuard, Library } = require('./assetguard') +const ConfigManager = require('./configmanager') +const DistroManager = require('./distromanager') +const LoggerUtil = require('./loggerutil') const logger = LoggerUtil('%c[ProcessBuilder]', 'color: #003996; font-weight: bold') class ProcessBuilder { - constructor(distroServer, versionData, forgeData, authUser){ + constructor(distroServer, versionData, forgeData, authUser, launcherVersion){ this.gameDir = path.join(ConfigManager.getInstanceDirectory(), distroServer.getID()) this.commonDir = ConfigManager.getCommonDirectory() this.server = distroServer this.versionData = versionData this.forgeData = forgeData this.authUser = authUser + this.launcherVersion = launcherVersion this.fmlDir = path.join(this.gameDir, 'forgeModList.json') this.llDir = path.join(this.gameDir, 'liteloaderModList.json') this.libPath = path.join(this.commonDir, 'libraries') @@ -240,6 +241,22 @@ class ProcessBuilder { * @returns {Array.} An array containing the full JVM arguments for this process. */ constructJVMArguments(mods, tempNativePath){ + if(AssetGuard.mcVersionAtLeast('1.13', this.server.getMinecraftVersion())){ + return this._constructJVMArguments113(mods, tempNativePath) + } else { + return this._constructJVMArguments112(mods, tempNativePath) + } + } + + /** + * Construct the argument array that will be passed to the JVM process. + * This function is for 1.12 and below. + * + * @param {Array.} mods An array of enabled mods which will be launched with this process. + * @param {string} tempNativePath The path to store the native libraries. + * @returns {Array.} An array containing the full JVM arguments for this process. + */ + _constructJVMArguments112(mods, tempNativePath){ let args = [] @@ -266,6 +283,154 @@ class ProcessBuilder { return args } + /** + * Construct the argument array that will be passed to the JVM process. + * This function is for 1.13+ + * + * Note: Required Libs https://github.com/MinecraftForge/MinecraftForge/blob/af98088d04186452cb364280340124dfd4766a5c/src/fmllauncher/java/net/minecraftforge/fml/loading/LibraryFinder.java#L82 + * + * @param {Array.} mods An array of enabled mods which will be launched with this process. + * @param {string} tempNativePath The path to store the native libraries. + * @returns {Array.} An array containing the full JVM arguments for this process. + */ + _constructJVMArguments113(mods, tempNativePath){ + + const argDiscovery = /\${*(.*)}/ + + // JVM Arguments First + let args = this.versionData.arguments.jvm + + // Java Arguments + if(process.platform === 'darwin'){ + args.push('-Xdock:name=WesterosCraft') + args.push('-Xdock:icon=' + path.join(__dirname, '..', 'images', 'minecraft.icns')) + } + args.push('-Xmx' + ConfigManager.getMaxRAM()) + args.push('-Xms' + ConfigManager.getMinRAM()) + args = args.concat(ConfigManager.getJVMOptions()) + + // Main Java Class + args.push(this.forgeData.mainClass) + + // Vanilla Arguments + args = args.concat(this.versionData.arguments.game) + + for(let i=0; i { + return arg != null + }) + + return args + } + /** * Resolve the arguments required by forge. * @@ -410,8 +575,7 @@ class ProcessBuilder { libs.push(to) } else { // Extract the native library. - const extractInst = lib.extract - const exclusionArr = extractInst.exclude + const exclusionArr = lib.extract != null ? lib.extract.exclude : ['META-INF/'] const artifact = lib.downloads.classifiers[lib.natives[Library.mojangFriendlyOS()].replace('${arch}', process.arch.replace('x', ''))] // Location of native zip. diff --git a/app/assets/js/scripts/landing.js b/app/assets/js/scripts/landing.js index d3588ed1..67547fc1 100644 --- a/app/assets/js/scripts/landing.js +++ b/app/assets/js/scripts/landing.js @@ -621,18 +621,25 @@ function dlAsync(login = true){ } } else if(m.context === 'validateEverything'){ + let allGood = true + // If these properties are not defined it's likely an error. if(m.result.forgeData == null || m.result.versionData == null){ loggerLaunchSuite.error('Error during validation:', m.result) + + loggerLaunchSuite.error('Error during launch', m.result.error) + showLaunchFailure('Error During Launch', 'Please check the console (CTRL + Shift + i) for more details.') + + allGood = false } forgeData = m.result.forgeData versionData = m.result.versionData - if(login) { + if(login && allGood) { const authUser = ConfigManager.getSelectedAccount() loggerLaunchSuite.log(`Sending selected account (${authUser.displayName}) to ProcessBuilder.`) - let pb = new ProcessBuilder(serv, versionData, forgeData, authUser) + let pb = new ProcessBuilder(serv, versionData, forgeData, authUser, remote.app.getVersion()) setLaunchDetails('Launching game..') // Attach a temporary listener to the client output.