summaryrefslogtreecommitdiffstats
path: root/api/logic/minecraft/curse/FileResolvingTask.cpp
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@gmail.com>2017-04-20 05:22:04 +0200
committerPetr Mrázek <peterix@gmail.com>2017-04-20 05:22:04 +0200
commit6bd2605a79bec9267740f223c87d56d2263d98b8 (patch)
tree9ded863e6f84b52fd2c003e2dd1c22f19427658c /api/logic/minecraft/curse/FileResolvingTask.cpp
parente9a61995077eb15027cf3d044aa15a8cb67c13ae (diff)
downloadMultiMC-6bd2605a79bec9267740f223c87d56d2263d98b8.tar
MultiMC-6bd2605a79bec9267740f223c87d56d2263d98b8.tar.gz
MultiMC-6bd2605a79bec9267740f223c87d56d2263d98b8.tar.lz
MultiMC-6bd2605a79bec9267740f223c87d56d2263d98b8.tar.xz
MultiMC-6bd2605a79bec9267740f223c87d56d2263d98b8.zip
NOISSUE add import from curse zip packs
Does not actually grab mods, but resolves them and prints the results in logs.
Diffstat (limited to 'api/logic/minecraft/curse/FileResolvingTask.cpp')
-rw-r--r--api/logic/minecraft/curse/FileResolvingTask.cpp64
1 files changed, 64 insertions, 0 deletions
diff --git a/api/logic/minecraft/curse/FileResolvingTask.cpp b/api/logic/minecraft/curse/FileResolvingTask.cpp
new file mode 100644
index 00000000..13308202
--- /dev/null
+++ b/api/logic/minecraft/curse/FileResolvingTask.cpp
@@ -0,0 +1,64 @@
+#include "FileResolvingTask.h"
+#include "Json.h"
+
+const char * metabase = "https://cursemeta.dries007.net";
+
+Curse::FileResolvingTask::FileResolvingTask(QVector<Curse::File>& toProcess)
+ : m_toProcess(toProcess)
+{
+}
+
+void Curse::FileResolvingTask::executeTask()
+{
+ m_dljob.reset(new NetJob("Curse file resolver"));
+ results.resize(m_toProcess.size());
+ int index = 0;
+ for(auto & file: m_toProcess)
+ {
+ auto projectIdStr = QString::number(file.projectId);
+ auto fileIdStr = QString::number(file.fileId);
+ QString metaurl = QString("%1/%2/%3.json").arg(metabase, projectIdStr, fileIdStr);
+ auto dl = Net::Download::makeByteArray(QUrl(metaurl), &results[index]);
+ m_dljob->addNetAction(dl);
+ index ++;
+ }
+ connect(m_dljob.get(), &NetJob::finished, this, &Curse::FileResolvingTask::netJobFinished);
+ m_dljob->start();
+}
+
+void Curse::FileResolvingTask::netJobFinished()
+{
+ bool failed = false;
+ int index = 0;
+ for(auto & bytes: results)
+ {
+ try
+ {
+ auto doc = Json::requireDocument(bytes);
+ auto obj = Json::requireObject(doc);
+ // result code signifies true failure.
+ if(obj.contains("code"))
+ {
+ failed = true;
+ continue;
+ }
+ auto & out = m_toProcess[index];
+ out.fileName = Json::requireString(obj, "FileNameOnDisk");
+ out.url = Json::requireString(obj, "DownloadURL");
+ out.resolved = true;
+ }
+ catch(JSONValidationError & e)
+ {
+ failed = true;
+ }
+ index++;
+ }
+ if(!failed)
+ {
+ emitSucceeded();
+ }
+ else
+ {
+ emitFailed(tr("Some curse ID resolving tasks failed."));
+ }
+}