diff options
author | Petr Mrázek <peterix@gmail.com> | 2018-01-21 03:49:54 +0100 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2018-01-21 03:49:54 +0100 |
commit | c33b4e252f8bf37bc716adc7789926185c3e384c (patch) | |
tree | f37b58054385874f9dd079faa7809f19a21d5d1e /api/logic/minecraft | |
parent | 0942867ecc3d437cab8a859e2307c40b69d05297 (diff) | |
download | MultiMC-c33b4e252f8bf37bc716adc7789926185c3e384c.tar MultiMC-c33b4e252f8bf37bc716adc7789926185c3e384c.tar.gz MultiMC-c33b4e252f8bf37bc716adc7789926185c3e384c.tar.lz MultiMC-c33b4e252f8bf37bc716adc7789926185c3e384c.tar.xz MultiMC-c33b4e252f8bf37bc716adc7789926185c3e384c.zip |
NOISSUE fix bad redirect URLs provided by the curse CDN
MultiMC now parses the HTTP Location header in a (more) tolerant mode.
Diffstat (limited to 'api/logic/minecraft')
-rw-r--r-- | api/logic/minecraft/flame/FileResolvingTask.cpp | 8 | ||||
-rw-r--r-- | api/logic/minecraft/flame/PackManifest.h | 3 |
2 files changed, 9 insertions, 2 deletions
diff --git a/api/logic/minecraft/flame/FileResolvingTask.cpp b/api/logic/minecraft/flame/FileResolvingTask.cpp index af8ef7aa..980b8c3a 100644 --- a/api/logic/minecraft/flame/FileResolvingTask.cpp +++ b/api/logic/minecraft/flame/FileResolvingTask.cpp @@ -48,7 +48,13 @@ void Flame::FileResolvingTask::netJobFinished() continue; } out.fileName = Json::requireString(obj, "FileNameOnDisk"); - out.url = Json::requireString(obj, "DownloadURL"); + auto urlString = Json::requireString(obj, "DownloadURL"); + urlString.replace(' ', "%20"); + out.url = QUrl(urlString, QUrl::StrictMode); + if(!out.url.isValid()) + { + throw "Perkele!"; + } // This is a piece of a Flame project JSON pulled out into the file metadata (here) for convenience // It is also optional QJsonObject projObj = Json::ensureObject(obj, "_Project", {}); diff --git a/api/logic/minecraft/flame/PackManifest.h b/api/logic/minecraft/flame/PackManifest.h index 07bf92b6..1a5254a8 100644 --- a/api/logic/minecraft/flame/PackManifest.h +++ b/api/logic/minecraft/flame/PackManifest.h @@ -2,6 +2,7 @@ #include <QString> #include <QVector> +#include <QUrl> namespace Flame { @@ -15,7 +16,7 @@ struct File // our bool resolved = false; QString fileName; - QString url; + QUrl url; QString targetFolder = QLatin1Literal("mods"); enum class Type { |