feat: add links for curseforge mods
NOT DOWNLOAD LINKS! (someone would ask it i'm sure :p)
This commit is contained in:
parent
ae2ef324f2
commit
c5eb6fe6fb
@ -41,7 +41,10 @@ class FlameAPI : public NetworkModAPI {
|
|||||||
.arg(gameVersionStr);
|
.arg(gameVersionStr);
|
||||||
};
|
};
|
||||||
|
|
||||||
inline auto getModInfoURL(QString& id) const -> QString override { return {}; };
|
inline auto getModInfoURL(QString& id) const -> QString override
|
||||||
|
{
|
||||||
|
return QString("https://api.curseforge.com/v1/mods/%1").arg(id);
|
||||||
|
};
|
||||||
|
|
||||||
inline auto getVersionsURL(VersionSearchArgs& args) const -> QString override
|
inline auto getVersionsURL(VersionSearchArgs& args) const -> QString override
|
||||||
{
|
{
|
||||||
|
@ -25,6 +25,27 @@ void FlameMod::loadIndexedPack(ModPlatform::IndexedPack& pack, QJsonObject& obj)
|
|||||||
packAuthor.url = Json::requireString(author, "url");
|
packAuthor.url = Json::requireString(author, "url");
|
||||||
pack.authors.append(packAuthor);
|
pack.authors.append(packAuthor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
loadExtraPackData(pack, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FlameMod::loadExtraPackData(ModPlatform::IndexedPack& pack, QJsonObject& obj)
|
||||||
|
{
|
||||||
|
auto links_obj = Json::ensureObject(obj, "links");
|
||||||
|
|
||||||
|
pack.extraData.issuesUrl = Json::ensureString(links_obj, "issuesUrl");
|
||||||
|
if(pack.extraData.issuesUrl.endsWith('/'))
|
||||||
|
pack.extraData.issuesUrl.chop(1);
|
||||||
|
|
||||||
|
pack.extraData.sourceUrl = Json::ensureString(links_obj, "sourceUrl");
|
||||||
|
if(pack.extraData.sourceUrl.endsWith('/'))
|
||||||
|
pack.extraData.sourceUrl.chop(1);
|
||||||
|
|
||||||
|
pack.extraData.wikiUrl = Json::ensureString(links_obj, "wikiUrl");
|
||||||
|
if(pack.extraData.wikiUrl.endsWith('/'))
|
||||||
|
pack.extraData.wikiUrl.chop(1);
|
||||||
|
|
||||||
|
pack.extraDataLoaded = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FlameMod::loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
void FlameMod::loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
namespace FlameMod {
|
namespace FlameMod {
|
||||||
|
|
||||||
void loadIndexedPack(ModPlatform::IndexedPack& m, QJsonObject& obj);
|
void loadIndexedPack(ModPlatform::IndexedPack& m, QJsonObject& obj);
|
||||||
|
void loadExtraPackData(ModPlatform::IndexedPack& m, QJsonObject& obj);
|
||||||
void loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
void loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
||||||
QJsonArray& arr,
|
QJsonArray& arr,
|
||||||
const shared_qobject_ptr<QNetworkAccessManager>& network,
|
const shared_qobject_ptr<QNetworkAccessManager>& network,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user