mirror of
https://github.com/dscalzi/HeliosLauncher.git
synced 2024-12-22 03:32:12 -08:00
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.
This commit is contained in:
parent
e8e7f85c64
commit
81367bc619
@ -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": ""
|
||||
}
|
||||
}
|
||||
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
@ -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})
|
||||
|
@ -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()
|
||||
try {
|
||||
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)
|
||||
|
||||
return {
|
||||
versionData,
|
||||
forgeData
|
||||
}
|
||||
|
||||
} catch (err){
|
||||
return {
|
||||
versionData: null,
|
||||
forgeData: null,
|
||||
error: err
|
||||
}
|
||||
}
|
||||
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)
|
||||
|
||||
return {
|
||||
versionData,
|
||||
forgeData
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
@ -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
|
||||
|
@ -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.<string>} 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.<Object>} 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.<string>} 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.<Object>} 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.<string>} 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<args.length; i++){
|
||||
if(typeof args[i] === 'object' && args[i].rules != null){
|
||||
|
||||
let checksum = 0
|
||||
for(let rule of args[i].rules){
|
||||
if(rule.os != null){
|
||||
if(rule.os.name === Library.mojangFriendlyOS()
|
||||
&& (rule.os.version == null || new RegExp(rule.os.version).test(os.release))){
|
||||
if(rule.action === 'allow'){
|
||||
checksum++
|
||||
}
|
||||
} else {
|
||||
if(rule.action === 'disallow'){
|
||||
checksum++
|
||||
}
|
||||
}
|
||||
} else if(rule.features != null){
|
||||
// We don't have many 'features' in the index at the moment.
|
||||
// This should be fine for a while.
|
||||
if(rule.features.has_custom_resolution != null && rule.features.has_custom_resolution === true){
|
||||
if(ConfigManager.getFullscreen()){
|
||||
rule.values = [
|
||||
'--fullscreen',
|
||||
'true'
|
||||
]
|
||||
}
|
||||
checksum++
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// TODO splice not push
|
||||
if(checksum === args[i].rules.length){
|
||||
if(typeof args[i].value === 'string'){
|
||||
args[i] = args[i].value
|
||||
} else if(typeof args[i].value === 'object'){
|
||||
//args = args.concat(args[i].value)
|
||||
args.splice(i, 1, ...args[i].value)
|
||||
}
|
||||
|
||||
// Decrement i to reprocess the resolved value
|
||||
i--
|
||||
} else {
|
||||
args[i] = null
|
||||
}
|
||||
|
||||
} else if(typeof args[i] === 'string'){
|
||||
if(argDiscovery.test(args[i])){
|
||||
const identifier = args[i].match(argDiscovery)[1]
|
||||
let val = null
|
||||
switch(identifier){
|
||||
case 'auth_player_name':
|
||||
val = this.authUser.displayName.trim()
|
||||
break
|
||||
case 'version_name':
|
||||
//val = versionData.id
|
||||
val = this.server.getID()
|
||||
break
|
||||
case 'game_directory':
|
||||
val = this.gameDir
|
||||
break
|
||||
case 'assets_root':
|
||||
val = path.join(this.commonDir, 'assets')
|
||||
break
|
||||
case 'assets_index_name':
|
||||
val = this.versionData.assets
|
||||
break
|
||||
case 'auth_uuid':
|
||||
val = this.authUser.uuid.trim()
|
||||
break
|
||||
case 'auth_access_token':
|
||||
val = this.authUser.accessToken
|
||||
break
|
||||
case 'user_type':
|
||||
val = 'mojang'
|
||||
break
|
||||
case 'version_type':
|
||||
val = this.versionData.type
|
||||
break
|
||||
case 'resolution_width':
|
||||
val = ConfigManager.getGameWidth()
|
||||
break
|
||||
case 'resolution_height':
|
||||
val = ConfigManager.getGameHeight()
|
||||
break
|
||||
case 'natives_directory':
|
||||
val = args[i].replace(argDiscovery, tempNativePath)
|
||||
break
|
||||
case 'launcher_name':
|
||||
val = args[i].replace(argDiscovery, 'WesterosCraft-Launcher')
|
||||
break
|
||||
case 'launcher_version':
|
||||
val = args[i].replace(argDiscovery, this.launcherVersion)
|
||||
break
|
||||
case 'classpath':
|
||||
val = this.classpathArg(mods, tempNativePath).join(process.platform === 'win32' ? ';' : ':')
|
||||
break
|
||||
}
|
||||
if(val != null){
|
||||
args[i] = val
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Forge Specific Arguments
|
||||
args = args.concat(this.forgeData.arguments.game)
|
||||
|
||||
// Filter null values
|
||||
args = args.filter(arg => {
|
||||
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.
|
||||
|
@ -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.
|
||||
|
Loading…
Reference in New Issue
Block a user