2017-04-20 08:52:04 +05:30
|
|
|
#include "FileResolvingTask.h"
|
|
|
|
#include "Json.h"
|
|
|
|
|
|
|
|
const char * metabase = "https://cursemeta.dries007.net";
|
|
|
|
|
2017-04-22 22:21:04 +05:30
|
|
|
Flame::FileResolvingTask::FileResolvingTask(Flame::Manifest& toProcess)
|
2017-04-20 08:52:04 +05:30
|
|
|
: m_toProcess(toProcess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-04-22 22:21:04 +05:30
|
|
|
void Flame::FileResolvingTask::executeTask()
|
2017-04-20 08:52:04 +05:30
|
|
|
{
|
2017-05-04 02:41:52 +05:30
|
|
|
setStatus(tr("Resolving mod IDs..."));
|
2017-04-22 01:53:31 +05:30
|
|
|
setProgress(0, m_toProcess.files.size());
|
2017-04-22 22:21:04 +05:30
|
|
|
m_dljob.reset(new NetJob("Mod id resolver"));
|
2017-04-22 01:53:31 +05:30
|
|
|
results.resize(m_toProcess.files.size());
|
2017-04-20 08:52:04 +05:30
|
|
|
int index = 0;
|
2017-04-22 01:53:31 +05:30
|
|
|
for(auto & file: m_toProcess.files)
|
2017-04-20 08:52:04 +05:30
|
|
|
{
|
|
|
|
auto projectIdStr = QString::number(file.projectId);
|
|
|
|
auto fileIdStr = QString::number(file.fileId);
|
|
|
|
QString metaurl = QString("%1/%2/%3.json").arg(metabase, projectIdStr, fileIdStr);
|
|
|
|
auto dl = Net::Download::makeByteArray(QUrl(metaurl), &results[index]);
|
|
|
|
m_dljob->addNetAction(dl);
|
|
|
|
index ++;
|
|
|
|
}
|
2017-04-22 22:21:04 +05:30
|
|
|
connect(m_dljob.get(), &NetJob::finished, this, &Flame::FileResolvingTask::netJobFinished);
|
2017-04-20 08:52:04 +05:30
|
|
|
m_dljob->start();
|
|
|
|
}
|
|
|
|
|
2017-04-22 22:21:04 +05:30
|
|
|
void Flame::FileResolvingTask::netJobFinished()
|
2017-04-20 08:52:04 +05:30
|
|
|
{
|
|
|
|
bool failed = false;
|
|
|
|
int index = 0;
|
|
|
|
for(auto & bytes: results)
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
auto doc = Json::requireDocument(bytes);
|
|
|
|
auto obj = Json::requireObject(doc);
|
2017-05-10 01:26:33 +05:30
|
|
|
auto & out = m_toProcess.files[index];
|
2017-04-20 08:52:04 +05:30
|
|
|
// result code signifies true failure.
|
|
|
|
if(obj.contains("code"))
|
|
|
|
{
|
2017-05-10 01:26:33 +05:30
|
|
|
qCritical() << "Resolving of" << out.projectId << out.fileId << "failed because of a negative result:";
|
|
|
|
qCritical() << bytes;
|
2017-04-20 08:52:04 +05:30
|
|
|
failed = true;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
out.fileName = Json::requireString(obj, "FileNameOnDisk");
|
|
|
|
out.url = Json::requireString(obj, "DownloadURL");
|
|
|
|
out.resolved = true;
|
|
|
|
}
|
|
|
|
catch(JSONValidationError & e)
|
|
|
|
{
|
2017-05-10 01:26:33 +05:30
|
|
|
auto & out = m_toProcess.files[index];
|
|
|
|
qCritical() << "Resolving of" << out.projectId << out.fileId << "failed because of a parsing error:";
|
2017-05-10 01:19:36 +05:30
|
|
|
qCritical() << e.cause();
|
|
|
|
qCritical() << "JSON:";
|
|
|
|
qCritical() << bytes;
|
2017-04-20 08:52:04 +05:30
|
|
|
failed = true;
|
|
|
|
}
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
if(!failed)
|
|
|
|
{
|
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-04-22 22:21:04 +05:30
|
|
|
emitFailed(tr("Some mod ID resolving tasks failed."));
|
2017-04-20 08:52:04 +05:30
|
|
|
}
|
|
|
|
}
|