2022-01-14 09:43:42 +01:00
|
|
|
#include <QObject>
|
|
|
|
#include "ModrinthPackIndex.h"
|
|
|
|
|
|
|
|
#include "Json.h"
|
|
|
|
#include "net/NetJob.h"
|
2022-01-15 10:25:24 +01:00
|
|
|
#include "BaseInstance.h"
|
|
|
|
#include "minecraft/MinecraftInstance.h"
|
|
|
|
#include "minecraft/PackProfile.h"
|
|
|
|
|
2022-01-14 09:43:42 +01:00
|
|
|
|
|
|
|
void Modrinth::loadIndexedPack(Modrinth::IndexedPack & pack, QJsonObject & obj)
|
|
|
|
{
|
2022-01-31 17:18:11 +01:00
|
|
|
pack.addonId = Json::requireString(obj, "project_id");
|
2022-01-14 09:43:42 +01:00
|
|
|
pack.name = Json::requireString(obj, "title");
|
|
|
|
pack.websiteUrl = Json::ensureString(obj, "page_url", "");
|
|
|
|
pack.description = Json::ensureString(obj, "description", "");
|
|
|
|
|
|
|
|
pack.logoUrl = Json::requireString(obj, "icon_url");
|
2022-01-14 20:22:15 +01:00
|
|
|
pack.logoName = pack.addonId;
|
2022-01-14 09:43:42 +01:00
|
|
|
|
2022-01-24 07:23:01 +01:00
|
|
|
Modrinth::ModpackAuthor modAuthor;
|
|
|
|
modAuthor.name = Json::requireString(obj, "author");
|
2022-01-31 17:18:11 +01:00
|
|
|
modAuthor.url = "https://modrinth.com/user/"+modAuthor.name;
|
2022-01-24 07:23:01 +01:00
|
|
|
pack.author = modAuthor;
|
2022-01-14 09:43:42 +01:00
|
|
|
}
|
|
|
|
|
2022-01-15 10:25:24 +01:00
|
|
|
void Modrinth::loadIndexedPackVersions(Modrinth::IndexedPack & pack, QJsonArray & arr, const shared_qobject_ptr<QNetworkAccessManager>& network, BaseInstance * inst)
|
2022-01-14 09:43:42 +01:00
|
|
|
{
|
|
|
|
QVector<Modrinth::IndexedVersion> unsortedVersions;
|
2022-01-15 10:25:24 +01:00
|
|
|
bool hasFabric = !((MinecraftInstance *)inst)->getPackProfile()->getComponentVersion("net.fabricmc.fabric-loader").isEmpty();
|
|
|
|
QString mcVersion = ((MinecraftInstance *)inst)->getPackProfile()->getComponentVersion("net.minecraft");
|
|
|
|
|
2022-01-14 09:43:42 +01:00
|
|
|
for(auto versionIter: arr) {
|
|
|
|
auto obj = versionIter.toObject();
|
|
|
|
Modrinth::IndexedVersion file;
|
2022-01-31 17:18:11 +01:00
|
|
|
file.addonId = Json::requireString(obj,"project_id") ;
|
2022-01-14 09:43:42 +01:00
|
|
|
file.fileId = Json::requireString(obj, "id");
|
|
|
|
file.date = Json::requireString(obj, "date_published");
|
|
|
|
auto versionArray = Json::requireArray(obj, "game_versions");
|
|
|
|
if (versionArray.empty()) {
|
|
|
|
continue;
|
|
|
|
}
|
2022-01-15 08:51:47 +01:00
|
|
|
for(auto mcVer : versionArray){
|
|
|
|
file.mcVersion.append(mcVer.toString());
|
|
|
|
}
|
|
|
|
auto loaders = Json::requireArray(obj,"loaders");
|
|
|
|
for(auto loader : loaders){
|
|
|
|
file.loaders.append(loader.toString());
|
|
|
|
}
|
2022-01-14 09:43:42 +01:00
|
|
|
file.version = Json::requireString(obj, "name");
|
2022-01-15 10:25:24 +01:00
|
|
|
|
|
|
|
auto files = Json::requireArray(obj, "files");
|
|
|
|
int i = 0;
|
2022-03-19 11:41:36 +11:00
|
|
|
|
|
|
|
// Find correct file (needed in cases where one version may have multiple files)
|
|
|
|
// Will default to the last one if there's no primary (though I think Modrinth requires that
|
|
|
|
// at least one file is primary, idk)
|
|
|
|
while (i < files.count()){
|
2022-01-15 10:25:24 +01:00
|
|
|
auto parent = files[i].toObject();
|
|
|
|
auto fileName = Json::requireString(parent, "filename");
|
2022-03-19 11:41:36 +11:00
|
|
|
|
|
|
|
// Grab the correct mod loader
|
|
|
|
if(hasFabric){
|
|
|
|
if(fileName.contains("forge",Qt::CaseInsensitive)){
|
|
|
|
i++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
} else if(fileName.contains("fabric", Qt::CaseInsensitive)){
|
2022-01-15 10:25:24 +01:00
|
|
|
i++;
|
|
|
|
continue;
|
|
|
|
}
|
2022-03-19 11:41:36 +11:00
|
|
|
|
|
|
|
// Grab the primary file, if available
|
|
|
|
if(Json::requireBoolean(parent, "primary"))
|
|
|
|
break;
|
|
|
|
|
|
|
|
i++;
|
2022-01-15 10:25:24 +01:00
|
|
|
}
|
2022-03-19 11:41:36 +11:00
|
|
|
|
2022-01-15 10:25:24 +01:00
|
|
|
auto parent = files[i].toObject();
|
2022-02-01 21:56:52 +01:00
|
|
|
if(parent.contains("url")) {
|
|
|
|
file.downloadUrl = Json::requireString(parent, "url");
|
|
|
|
file.fileName = Json::requireString(parent, "filename");
|
2022-01-15 08:51:47 +01:00
|
|
|
|
2022-02-01 21:56:52 +01:00
|
|
|
unsortedVersions.append(file);
|
|
|
|
}
|
2022-01-14 09:43:42 +01:00
|
|
|
}
|
|
|
|
auto orderSortPredicate = [](const IndexedVersion & a, const IndexedVersion & b) -> bool
|
|
|
|
{
|
|
|
|
//dates are in RFC 3339 format
|
|
|
|
return a.date > b.date;
|
|
|
|
};
|
|
|
|
std::sort(unsortedVersions.begin(), unsortedVersions.end(), orderSortPredicate);
|
|
|
|
pack.versions = unsortedVersions;
|
|
|
|
pack.versionsLoaded = true;
|
|
|
|
}
|