2023-01-23 11:03:55 -03:00
|
|
|
// SPDX-FileCopyrightText: 2023 flowln <flowlnlnln@gmail.com>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
|
2022-11-25 09:23:46 -03:00
|
|
|
#include "FlameResourceModels.h"
|
2022-12-16 19:03:52 -03:00
|
|
|
|
2022-05-08 15:22:50 +08:00
|
|
|
#include "Json.h"
|
2022-12-16 19:03:52 -03:00
|
|
|
|
2022-12-18 15:41:46 -03:00
|
|
|
#include "modplatform/flame/FlameAPI.h"
|
2022-03-07 19:29:59 -03:00
|
|
|
#include "modplatform/flame/FlameModIndex.h"
|
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
namespace ResourceDownload {
|
2022-01-16 11:20:21 +01:00
|
|
|
|
2022-12-18 15:41:46 -03:00
|
|
|
FlameModModel::FlameModModel(BaseInstance const& base) : ModModel(base, new FlameAPI) {}
|
2022-03-02 23:01:23 -03:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
void FlameModModel::loadIndexedPack(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
2022-03-07 19:29:59 -03:00
|
|
|
{
|
|
|
|
FlameMod::loadIndexedPack(m, obj);
|
2022-03-07 19:55:20 -03:00
|
|
|
}
|
2022-03-07 19:29:59 -03:00
|
|
|
|
2022-07-19 12:29:31 -03:00
|
|
|
// We already deal with the URLs when initializing the pack, due to the API response's structure
|
2022-12-16 19:03:52 -03:00
|
|
|
void FlameModModel::loadExtraPackInfo(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
2022-07-19 12:29:31 -03:00
|
|
|
{
|
|
|
|
FlameMod::loadBody(m, obj);
|
|
|
|
}
|
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
void FlameModModel::loadIndexedPackVersions(ModPlatform::IndexedPack& m, QJsonArray& arr)
|
2022-03-07 19:29:59 -03:00
|
|
|
{
|
2022-12-18 15:41:46 -03:00
|
|
|
FlameMod::loadIndexedPackVersions(m, arr, APPLICATION->network(), &m_base_instance);
|
2022-03-07 19:55:20 -03:00
|
|
|
}
|
2022-03-07 19:29:59 -03:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
auto FlameModModel::documentToArray(QJsonDocument& obj) const -> QJsonArray
|
2022-03-07 19:29:59 -03:00
|
|
|
{
|
2022-05-08 15:22:50 +08:00
|
|
|
return Json::ensureArray(obj.object(), "data");
|
2022-03-07 19:29:59 -03:00
|
|
|
}
|
|
|
|
|
2022-12-16 20:26:10 -03:00
|
|
|
FlameResourcePackModel::FlameResourcePackModel(const BaseInstance& base) : ResourcePackResourceModel(base, new FlameAPI) {}
|
|
|
|
|
|
|
|
void FlameResourcePackModel::loadIndexedPack(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
|
|
|
{
|
|
|
|
FlameMod::loadIndexedPack(m, obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
// We already deal with the URLs when initializing the pack, due to the API response's structure
|
|
|
|
void FlameResourcePackModel::loadExtraPackInfo(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
|
|
|
{
|
|
|
|
FlameMod::loadBody(m, obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FlameResourcePackModel::loadIndexedPackVersions(ModPlatform::IndexedPack& m, QJsonArray& arr)
|
|
|
|
{
|
|
|
|
FlameMod::loadIndexedPackVersions(m, arr, APPLICATION->network(), &m_base_instance);
|
|
|
|
}
|
|
|
|
|
|
|
|
auto FlameResourcePackModel::documentToArray(QJsonDocument& obj) const -> QJsonArray
|
|
|
|
{
|
|
|
|
return Json::ensureArray(obj.object(), "data");
|
|
|
|
}
|
|
|
|
|
2023-01-29 18:07:49 -03:00
|
|
|
FlameTexturePackModel::FlameTexturePackModel(const BaseInstance& base) : TexturePackResourceModel(base, new FlameAPI) {}
|
|
|
|
|
|
|
|
void FlameTexturePackModel::loadIndexedPack(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
|
|
|
{
|
|
|
|
FlameMod::loadIndexedPack(m, obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
// We already deal with the URLs when initializing the pack, due to the API response's structure
|
|
|
|
void FlameTexturePackModel::loadExtraPackInfo(ModPlatform::IndexedPack& m, QJsonObject& obj)
|
|
|
|
{
|
|
|
|
FlameMod::loadBody(m, obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FlameTexturePackModel::loadIndexedPackVersions(ModPlatform::IndexedPack& m, QJsonArray& arr)
|
|
|
|
{
|
|
|
|
FlameMod::loadIndexedPackVersions(m, arr, APPLICATION->network(), &m_base_instance);
|
|
|
|
|
|
|
|
QVector<ModPlatform::IndexedVersion> filtered_versions(m.versions.size());
|
|
|
|
|
|
|
|
// FIXME: Client-side version filtering. This won't take into account any user-selected filtering.
|
|
|
|
for (auto const& version : m.versions) {
|
|
|
|
auto const& mc_versions = version.mcVersion;
|
|
|
|
|
|
|
|
if (std::any_of(mc_versions.constBegin(), mc_versions.constEnd(),
|
|
|
|
[this](auto const& mc_version){ return Version(mc_version) <= maximumTexturePackVersion(); }))
|
|
|
|
filtered_versions.push_back(version);
|
|
|
|
}
|
|
|
|
|
|
|
|
m.versions = filtered_versions;
|
|
|
|
}
|
|
|
|
|
|
|
|
ResourceAPI::SearchArgs FlameTexturePackModel::createSearchArguments()
|
|
|
|
{
|
|
|
|
auto args = TexturePackResourceModel::createSearchArguments();
|
|
|
|
|
|
|
|
auto profile = static_cast<const MinecraftInstance&>(m_base_instance).getPackProfile();
|
|
|
|
QString instance_minecraft_version = profile->getComponentVersion("net.minecraft");
|
|
|
|
|
|
|
|
// Bypass the texture pack logic, because we can't do multiple versions in the API query
|
|
|
|
args.versions = { instance_minecraft_version };
|
|
|
|
|
|
|
|
return args;
|
|
|
|
}
|
|
|
|
|
|
|
|
ResourceAPI::VersionSearchArgs FlameTexturePackModel::createVersionsArguments(QModelIndex& entry)
|
|
|
|
{
|
|
|
|
auto args = TexturePackResourceModel::createVersionsArguments(entry);
|
|
|
|
|
|
|
|
// Bypass the texture pack logic, because we can't do multiple versions in the API query
|
|
|
|
args.mcVersions = {};
|
|
|
|
|
|
|
|
return args;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto FlameTexturePackModel::documentToArray(QJsonDocument& obj) const -> QJsonArray
|
|
|
|
{
|
|
|
|
return Json::ensureArray(obj.object(), "data");
|
|
|
|
}
|
2022-12-16 20:26:10 -03:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
} // namespace ResourceDownload
|