summaryrefslogtreecommitdiffstats
path: root/api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@gmail.com>2020-08-21 02:40:19 +0200
committerPetr Mrázek <peterix@gmail.com>2020-08-21 02:40:19 +0200
commitc6c9feb3a2006f0b37736799f003a0fb87f68b18 (patch)
tree23f7b58f2dfc7e9d3a3d15f171c02d6f7ffbd813 /api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp
parentb0f5f4cb13d7d0f983b7813377405298de718b2e (diff)
downloadMultiMC-c6c9feb3a2006f0b37736799f003a0fb87f68b18.tar
MultiMC-c6c9feb3a2006f0b37736799f003a0fb87f68b18.tar.gz
MultiMC-c6c9feb3a2006f0b37736799f003a0fb87f68b18.tar.lz
MultiMC-c6c9feb3a2006f0b37736799f003a0fb87f68b18.tar.xz
MultiMC-c6c9feb3a2006f0b37736799f003a0fb87f68b18.zip
NOISSUE attempt to fix build on macOS
Diffstat (limited to 'api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp')
-rw-r--r--api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp150
1 files changed, 150 insertions, 0 deletions
diff --git a/api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp b/api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp
new file mode 100644
index 00000000..fdfe560a
--- /dev/null
+++ b/api/logic/modplatform/modpacksch/FTBPackInstallTask.cpp
@@ -0,0 +1,150 @@
+#include "FTBPackInstallTask.h"
+
+#include "BuildConfig.h"
+#include "FileSystem.h"
+#include "Json.h"
+#include "minecraft/MinecraftInstance.h"
+#include "minecraft/PackProfile.h"
+#include "settings/INISettingsObject.h"
+
+namespace ModpacksCH {
+
+PackInstallTask::PackInstallTask(Modpack pack, QString version)
+{
+ m_pack = pack;
+ m_version_name = version;
+}
+
+bool PackInstallTask::abort()
+{
+ return true;
+}
+
+void PackInstallTask::executeTask()
+{
+ // Find pack version
+ bool found = false;
+ VersionInfo version;
+
+ for(auto vInfo : m_pack.versions) {
+ if (vInfo.name == m_version_name) {
+ found = true;
+ version = vInfo;
+ continue;
+ }
+ }
+
+ if(!found) {
+ emitFailed("failed to find pack version " + m_version_name);
+ return;
+ }
+
+ auto *netJob = new NetJob("ModpacksCH::VersionFetch");
+ auto searchUrl = QString(BuildConfig.MODPACKSCH_API_BASE_URL + "public/modpack/%1/%2")
+ .arg(m_pack.id).arg(version.id);
+ netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response));
+ jobPtr = netJob;
+ jobPtr->start();
+
+ QObject::connect(netJob, &NetJob::succeeded, this, &PackInstallTask::onDownloadSucceeded);
+ QObject::connect(netJob, &NetJob::failed, this, &PackInstallTask::onDownloadFailed);
+}
+
+void PackInstallTask::onDownloadSucceeded()
+{
+ jobPtr.reset();
+
+ QJsonParseError parse_error;
+ QJsonDocument doc = QJsonDocument::fromJson(response, &parse_error);
+ if(parse_error.error != QJsonParseError::NoError) {
+ qWarning() << "Error while parsing JSON response from FTB at " << parse_error.offset << " reason: " << parse_error.errorString();
+ qWarning() << response;
+ return;
+ }
+
+ auto obj = doc.object();
+
+ ModpacksCH::Version version;
+ try
+ {
+ ModpacksCH::loadVersion(version, obj);
+ }
+ catch (const JSONValidationError &e)
+ {
+ emitFailed(tr("Could not understand pack manifest:\n") + e.cause());
+ return;
+ }
+ m_version = version;
+
+ install();
+}
+
+void PackInstallTask::onDownloadFailed(QString reason)
+{
+ jobPtr.reset();
+ emitFailed(reason);
+}
+
+void PackInstallTask::install()
+{
+ setStatus(tr("Installing modpack"));
+
+ auto instanceConfigPath = FS::PathCombine(m_stagingPath, "instance.cfg");
+ auto instanceSettings = std::make_shared<INISettingsObject>(instanceConfigPath);
+ instanceSettings->registerSetting("InstanceType", "Legacy");
+ instanceSettings->set("InstanceType", "OneSix");
+
+ MinecraftInstance instance(m_globalSettings, instanceSettings, m_stagingPath);
+ auto components = instance.getPackProfile();
+ components->buildingFromScratch();
+
+ for(auto target : m_version.targets) {
+ if(target.type == "game" && target.name == "minecraft") {
+ components->setComponentVersion("net.minecraft", target.version, true);
+ continue;
+ }
+ }
+
+ for(auto target : m_version.targets) {
+ if(target.type == "modloader" && target.name == "forge") {
+ components->setComponentVersion("net.minecraftforge", target.version, true);
+ }
+ }
+ components->saveNow();
+
+ jobPtr.reset(new NetJob(tr("Mod download")));
+ for(auto file : m_version.files) {
+ if(file.serverOnly) continue;
+
+ auto relpath = FS::PathCombine("minecraft", file.path, file.name);
+ auto path = FS::PathCombine(m_stagingPath , relpath);
+
+ qDebug() << "Will download" << file.url << "to" << path;
+ auto dl = Net::Download::makeFile(file.url, path);
+ jobPtr->addNetAction(dl);
+ }
+ connect(jobPtr.get(), &NetJob::succeeded, this, [&]()
+ {
+ jobPtr.reset();
+ emitSucceeded();
+ });
+
+ connect(jobPtr.get(), &NetJob::failed, [&](QString reason)
+ {
+ jobPtr.reset();
+ emitFailed(reason);
+ });
+ connect(jobPtr.get(), &NetJob::progress, [&](qint64 current, qint64 total)
+ {
+ setProgress(current, total);
+ });
+
+ setStatus(tr("Downloading mods..."));
+ jobPtr->start();
+
+ instance.setName(m_instName);
+ instance.setIconKey(m_instIcon);
+ instanceSettings->resumeSave();
+}
+
+}