aboutsummaryrefslogtreecommitdiff
path: root/launcher/modplatform
diff options
context:
space:
mode:
Diffstat (limited to 'launcher/modplatform')
-rw-r--r--launcher/modplatform/modrinth/ModrinthAPI.h49
1 files changed, 35 insertions, 14 deletions
diff --git a/launcher/modplatform/modrinth/ModrinthAPI.h b/launcher/modplatform/modrinth/ModrinthAPI.h
index 84dd7d03..86852c94 100644
--- a/launcher/modplatform/modrinth/ModrinthAPI.h
+++ b/launcher/modplatform/modrinth/ModrinthAPI.h
@@ -1,5 +1,6 @@
#pragma once
+#include "modplatform/ModAPI.h"
#include "modplatform/helpers/NetworkModAPI.h"
#include <QDebug>
@@ -8,6 +9,36 @@ class ModrinthAPI : public NetworkModAPI {
public:
inline auto getAuthorURL(const QString& name) const -> QString { return "https://modrinth.com/user/" + name; };
+ static auto getModLoaderStrings(ModLoaderType type) -> const QStringList
+ {
+ QStringList l;
+ switch (type)
+ {
+ case Unspecified:
+ for (auto loader : {Forge, Fabric, Quilt})
+ {
+ l << ModAPI::getModLoaderString(loader);
+ }
+ break;
+
+ case Quilt:
+ l << ModAPI::getModLoaderString(Fabric);
+ default:
+ l << ModAPI::getModLoaderString(type);
+ }
+ return l;
+ }
+
+ static auto getModLoaderFilters(ModLoaderType type) -> const QString
+ {
+ QStringList l;
+ for (auto loader : getModLoaderStrings(type))
+ {
+ l << QString("\"categories:%1\"").arg(loader);
+ }
+ return l.join(',');
+ }
+
private:
inline auto getModSearchURL(SearchArgs& args) const -> QString override
{
@@ -22,11 +53,11 @@ class ModrinthAPI : public NetworkModAPI {
"limit=25&"
"query=%2&"
"index=%3&"
- "facets=[[\"categories:%4\"],%5[\"project_type:mod\"]]")
+ "facets=[[%4],%5[\"project_type:mod\"]]")
.arg(args.offset)
.arg(args.search)
.arg(args.sorting)
- .arg(getModLoaderString(args.mod_loader))
+ .arg(getModLoaderFilters(args.mod_loader))
.arg(getGameVersionsArray(args.versions));
};
@@ -34,10 +65,10 @@ class ModrinthAPI : public NetworkModAPI {
{
return QString("https://api.modrinth.com/v2/project/%1/version?"
"game_versions=[%2]"
- "loaders=[%3]")
+ "loaders=[\"%3\"]")
.arg(args.addonId)
.arg(getGameVersionsString(args.mcVersions))
- .arg(getModLoaderString(args.loader));
+ .arg(getModLoaderStrings(args.loader).join("\",\""));
};
auto getGameVersionsArray(std::list<Version> mcVersions) const -> QString
@@ -50,16 +81,6 @@ class ModrinthAPI : public NetworkModAPI {
return s.isEmpty() ? QString() : QString("[%1],").arg(s);
}
- static auto getModLoaderString(ModLoaderType type) -> const QString
- {
- if (type == Unspecified)
- return "fabric, forge, quilt";
- // TODO: remove this once Quilt drops official Fabric support
- if (type == Quilt) // NOTE: Most if not all Fabric mods should work *currently*
- return "fabric, quilt";
- return ModAPI::getModLoaderString(type);
- }
-
inline auto validateModLoader(ModLoaderType modLoader) const -> bool
{
return modLoader == Unspecified || modLoader == Forge || modLoader == Fabric || modLoader == Quilt;