2016-08-14 02:33:31 +02:00
|
|
|
#include "AssetUpdateTask.h"
|
2021-11-21 23:21:12 +01:00
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
#include "minecraft/AssetsUtils.h"
|
2017-07-24 09:01:37 +02:00
|
|
|
#include "minecraft/MinecraftInstance.h"
|
2020-06-27 12:02:31 +02:00
|
|
|
#include "minecraft/PackProfile.h"
|
2016-08-14 02:33:31 +02:00
|
|
|
#include "net/ChecksumValidator.h"
|
|
|
|
|
2021-11-21 23:21:12 +01:00
|
|
|
#include "Application.h"
|
|
|
|
|
2023-06-01 16:39:04 -07:00
|
|
|
#include "net/ApiDownload.h"
|
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
AssetUpdateTask::AssetUpdateTask(MinecraftInstance* inst)
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
|
|
|
m_inst = inst;
|
|
|
|
}
|
2018-06-28 21:34:56 +02:00
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
AssetUpdateTask::~AssetUpdateTask() {}
|
2018-06-28 21:34:56 +02:00
|
|
|
|
2016-08-14 02:33:31 +02:00
|
|
|
void AssetUpdateTask::executeTask()
|
|
|
|
{
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Updating assets index..."));
|
2020-06-27 12:02:31 +02:00
|
|
|
auto components = m_inst->getPackProfile();
|
2017-11-04 22:55:25 +01:00
|
|
|
auto profile = components->getProfile();
|
2016-08-14 02:33:31 +02:00
|
|
|
auto assets = profile->getMinecraftAssets();
|
|
|
|
QUrl indexUrl = assets->url;
|
|
|
|
QString localPath = assets->id + ".json";
|
2023-08-14 18:16:53 +02:00
|
|
|
auto job = makeShared<NetJob>(tr("Asset index for %1").arg(m_inst->name()), APPLICATION->network());
|
2016-08-14 02:33:31 +02:00
|
|
|
|
2021-11-21 23:21:12 +01:00
|
|
|
auto metacache = APPLICATION->metacache();
|
2016-08-14 02:33:31 +02:00
|
|
|
auto entry = metacache->resolveEntry("asset_indexes", localPath);
|
|
|
|
entry->setStale(true);
|
|
|
|
auto hexSha1 = assets->sha1.toLatin1();
|
|
|
|
qDebug() << "Asset index SHA1:" << hexSha1;
|
2023-06-01 16:39:04 -07:00
|
|
|
auto dl = Net::ApiDownload::makeCached(indexUrl, entry);
|
2016-08-14 02:33:31 +02:00
|
|
|
auto rawSha1 = QByteArray::fromHex(assets->sha1.toLatin1());
|
|
|
|
dl->addValidator(new Net::ChecksumValidator(QCryptographicHash::Sha1, rawSha1));
|
|
|
|
job->addNetAction(dl);
|
|
|
|
|
|
|
|
downloadJob.reset(job);
|
|
|
|
|
|
|
|
connect(downloadJob.get(), &NetJob::succeeded, this, &AssetUpdateTask::assetIndexFinished);
|
|
|
|
connect(downloadJob.get(), &NetJob::failed, this, &AssetUpdateTask::assetIndexFailed);
|
2023-08-14 18:16:53 +02:00
|
|
|
connect(downloadJob.get(), &NetJob::aborted, this, [this] { emitFailed(tr("Aborted")); });
|
2016-08-14 02:33:31 +02:00
|
|
|
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
2023-07-26 16:20:30 -04:00
|
|
|
connect(downloadJob.get(), &NetJob::stepProgress, this, &AssetUpdateTask::propagateStepProgress);
|
2016-08-14 02:33:31 +02:00
|
|
|
|
|
|
|
qDebug() << m_inst->name() << ": Starting asset index download";
|
2021-12-31 05:27:59 +01:00
|
|
|
downloadJob->start();
|
2016-08-14 02:33:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool AssetUpdateTask::canAbort() const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void AssetUpdateTask::assetIndexFinished()
|
|
|
|
{
|
|
|
|
AssetsIndex index;
|
|
|
|
qDebug() << m_inst->name() << ": Finished asset index download";
|
|
|
|
|
2020-06-27 12:02:31 +02:00
|
|
|
auto components = m_inst->getPackProfile();
|
2017-11-04 22:55:25 +01:00
|
|
|
auto profile = components->getProfile();
|
2016-08-14 02:33:31 +02:00
|
|
|
auto assets = profile->getMinecraftAssets();
|
|
|
|
|
|
|
|
QString asset_fname = "assets/indexes/" + assets->id + ".json";
|
|
|
|
// FIXME: this looks like a job for a generic validator based on json schema?
|
2023-08-14 18:16:53 +02:00
|
|
|
if (!AssetsUtils::loadAssetsIndexJson(assets->id, asset_fname, index)) {
|
2021-11-21 23:21:12 +01:00
|
|
|
auto metacache = APPLICATION->metacache();
|
2016-08-14 02:33:31 +02:00
|
|
|
auto entry = metacache->resolveEntry("asset_indexes", assets->id + ".json");
|
|
|
|
metacache->evictEntry(entry);
|
|
|
|
emitFailed(tr("Failed to read the assets index!"));
|
|
|
|
}
|
|
|
|
|
|
|
|
auto job = index.getDownloadJob();
|
2023-08-14 18:16:53 +02:00
|
|
|
if (job) {
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Getting the assets files from Mojang..."));
|
2016-08-14 02:33:31 +02:00
|
|
|
downloadJob = job;
|
|
|
|
connect(downloadJob.get(), &NetJob::succeeded, this, &AssetUpdateTask::emitSucceeded);
|
|
|
|
connect(downloadJob.get(), &NetJob::failed, this, &AssetUpdateTask::assetsFailed);
|
2023-08-14 18:16:53 +02:00
|
|
|
connect(downloadJob.get(), &NetJob::aborted, this, [this] { emitFailed(tr("Aborted")); });
|
2016-08-14 02:33:31 +02:00
|
|
|
connect(downloadJob.get(), &NetJob::progress, this, &AssetUpdateTask::progress);
|
2023-07-26 16:20:30 -04:00
|
|
|
connect(downloadJob.get(), &NetJob::stepProgress, this, &AssetUpdateTask::propagateStepProgress);
|
2021-12-31 05:27:59 +01:00
|
|
|
downloadJob->start();
|
2016-08-14 02:33:31 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
|
|
|
|
void AssetUpdateTask::assetIndexFailed(QString reason)
|
|
|
|
{
|
|
|
|
qDebug() << m_inst->name() << ": Failed asset index download";
|
|
|
|
emitFailed(tr("Failed to download the assets index:\n%1").arg(reason));
|
|
|
|
}
|
|
|
|
|
|
|
|
void AssetUpdateTask::assetsFailed(QString reason)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Failed to download assets:\n%1").arg(reason));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool AssetUpdateTask::abort()
|
|
|
|
{
|
2023-08-14 18:16:53 +02:00
|
|
|
if (downloadJob) {
|
2016-08-14 02:33:31 +02:00
|
|
|
return downloadJob->abort();
|
2023-08-14 18:16:53 +02:00
|
|
|
} else {
|
2019-02-19 01:00:03 +01:00
|
|
|
qWarning() << "Prematurely aborted AssetUpdateTask";
|
2016-08-14 02:33:31 +02:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|