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 "NetworkResourceAPI.h"
|
2023-06-15 22:59:41 +03:00
|
|
|
#include <memory>
|
2022-11-25 09:23:46 -03:00
|
|
|
|
|
|
|
#include "Application.h"
|
|
|
|
#include "net/NetJob.h"
|
|
|
|
|
|
|
|
#include "modplatform/ModIndex.h"
|
|
|
|
|
2023-06-01 16:39:04 -07:00
|
|
|
#include "net/ApiDownload.h"
|
|
|
|
|
2023-01-03 13:58:27 -03:00
|
|
|
Task::Ptr NetworkResourceAPI::searchProjects(SearchArgs&& args, SearchCallbacks&& callbacks) const
|
2022-11-25 09:23:46 -03:00
|
|
|
{
|
|
|
|
auto search_url_optional = getSearchURL(args);
|
|
|
|
if (!search_url_optional.has_value()) {
|
|
|
|
callbacks.on_fail("Failed to create search URL", -1);
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto search_url = search_url_optional.value();
|
|
|
|
|
2023-06-15 22:59:41 +03:00
|
|
|
auto response = std::make_shared<QByteArray>();
|
2023-01-24 16:52:09 -03:00
|
|
|
auto netJob = makeShared<NetJob>(QString("%1::Search").arg(debugName()), APPLICATION->network());
|
2022-11-25 09:23:46 -03:00
|
|
|
|
2023-06-01 16:39:04 -07:00
|
|
|
netJob->addNetAction(Net::ApiDownload::makeByteArray(QUrl(search_url), response));
|
2022-11-25 09:23:46 -03:00
|
|
|
|
2023-05-28 18:01:39 +03:00
|
|
|
QObject::connect(netJob.get(), &NetJob::succeeded, [this, response, callbacks] {
|
2022-11-25 09:23:46 -03:00
|
|
|
QJsonParseError parse_error{};
|
|
|
|
QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error);
|
|
|
|
if (parse_error.error != QJsonParseError::NoError) {
|
|
|
|
qWarning() << "Error while parsing JSON response from " << debugName() << " at " << parse_error.offset
|
|
|
|
<< " reason: " << parse_error.errorString();
|
|
|
|
qWarning() << *response;
|
|
|
|
|
|
|
|
callbacks.on_fail(parse_error.errorString(), -1);
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
callbacks.on_succeed(doc);
|
|
|
|
});
|
|
|
|
|
2023-05-28 18:01:39 +03:00
|
|
|
QObject::connect(netJob.get(), &NetJob::failed, [&netJob, callbacks](QString reason) {
|
2022-11-25 09:23:46 -03:00
|
|
|
int network_error_code = -1;
|
|
|
|
if (auto* failed_action = netJob->getFailedActions().at(0); failed_action && failed_action->m_reply)
|
|
|
|
network_error_code = failed_action->m_reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
|
|
|
|
|
2023-04-14 18:59:31 +03:00
|
|
|
callbacks.on_fail(reason, network_error_code);
|
2022-11-25 09:23:46 -03:00
|
|
|
});
|
2023-05-28 18:01:39 +03:00
|
|
|
QObject::connect(netJob.get(), &NetJob::aborted, [callbacks] { callbacks.on_abort(); });
|
2022-11-25 09:23:46 -03:00
|
|
|
|
|
|
|
return netJob;
|
|
|
|
}
|
|
|
|
|
2023-01-03 13:58:27 -03:00
|
|
|
Task::Ptr NetworkResourceAPI::getProjectInfo(ProjectInfoArgs&& args, ProjectInfoCallbacks&& callbacks) const
|
2022-11-25 09:23:46 -03:00
|
|
|
{
|
2023-06-15 22:59:41 +03:00
|
|
|
auto response = std::make_shared<QByteArray>();
|
2022-11-25 09:23:46 -03:00
|
|
|
auto job = getProject(args.pack.addonId.toString(), response);
|
|
|
|
|
|
|
|
QObject::connect(job.get(), &NetJob::succeeded, [response, callbacks, args] {
|
|
|
|
QJsonParseError parse_error{};
|
|
|
|
QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error);
|
|
|
|
if (parse_error.error != QJsonParseError::NoError) {
|
|
|
|
qWarning() << "Error while parsing JSON response for mod info at " << parse_error.offset
|
|
|
|
<< " reason: " << parse_error.errorString();
|
|
|
|
qWarning() << *response;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
callbacks.on_succeed(doc, args.pack);
|
|
|
|
});
|
|
|
|
|
|
|
|
return job;
|
|
|
|
}
|
|
|
|
|
2023-01-03 13:58:27 -03:00
|
|
|
Task::Ptr NetworkResourceAPI::getProjectVersions(VersionSearchArgs&& args, VersionSearchCallbacks&& callbacks) const
|
2022-11-25 09:23:46 -03:00
|
|
|
{
|
|
|
|
auto versions_url_optional = getVersionsURL(args);
|
|
|
|
if (!versions_url_optional.has_value())
|
|
|
|
return nullptr;
|
|
|
|
|
|
|
|
auto versions_url = versions_url_optional.value();
|
|
|
|
|
2023-01-24 16:52:09 -03:00
|
|
|
auto netJob = makeShared<NetJob>(QString("%1::Versions").arg(args.pack.name), APPLICATION->network());
|
2023-06-15 22:59:41 +03:00
|
|
|
auto response = std::make_shared<QByteArray>();
|
2022-11-25 09:23:46 -03:00
|
|
|
|
2023-06-01 16:39:04 -07:00
|
|
|
netJob->addNetAction(Net::ApiDownload::makeByteArray(versions_url, response));
|
2022-11-25 09:23:46 -03:00
|
|
|
|
2023-05-26 21:21:10 -07:00
|
|
|
QObject::connect(netJob.get(), &NetJob::succeeded, [response, callbacks, args] {
|
2022-11-25 09:23:46 -03:00
|
|
|
QJsonParseError parse_error{};
|
|
|
|
QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error);
|
|
|
|
if (parse_error.error != QJsonParseError::NoError) {
|
|
|
|
qWarning() << "Error while parsing JSON response for getting versions at " << parse_error.offset
|
|
|
|
<< " reason: " << parse_error.errorString();
|
|
|
|
qWarning() << *response;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-12-18 15:41:46 -03:00
|
|
|
callbacks.on_succeed(doc, args.pack);
|
2022-11-25 09:23:46 -03:00
|
|
|
});
|
|
|
|
|
|
|
|
return netJob;
|
|
|
|
}
|
|
|
|
|
2023-06-15 22:59:41 +03:00
|
|
|
Task::Ptr NetworkResourceAPI::getProject(QString addonId, std::shared_ptr<QByteArray> response) const
|
2022-11-25 09:23:46 -03:00
|
|
|
{
|
|
|
|
auto project_url_optional = getInfoURL(addonId);
|
|
|
|
if (!project_url_optional.has_value())
|
|
|
|
return nullptr;
|
|
|
|
|
|
|
|
auto project_url = project_url_optional.value();
|
|
|
|
|
2023-01-24 16:52:09 -03:00
|
|
|
auto netJob = makeShared<NetJob>(QString("%1::GetProject").arg(addonId), APPLICATION->network());
|
2022-11-25 09:23:46 -03:00
|
|
|
|
2023-06-01 16:39:04 -07:00
|
|
|
netJob->addNetAction(Net::ApiDownload::makeByteArray(QUrl(project_url), response));
|
2022-11-25 09:23:46 -03:00
|
|
|
|
|
|
|
return netJob;
|
|
|
|
}
|
2023-04-14 18:59:31 +03:00
|
|
|
|
|
|
|
Task::Ptr NetworkResourceAPI::getDependencyVersion(DependencySearchArgs&& args, DependencySearchCallbacks&& callbacks) const
|
|
|
|
{
|
2023-04-21 18:41:40 +03:00
|
|
|
auto versions_url_optional = getDependencyURL(args);
|
2023-04-14 18:59:31 +03:00
|
|
|
if (!versions_url_optional.has_value())
|
|
|
|
return nullptr;
|
|
|
|
|
|
|
|
auto versions_url = versions_url_optional.value();
|
|
|
|
|
2023-04-21 18:41:40 +03:00
|
|
|
auto netJob = makeShared<NetJob>(QString("%1::Dependency").arg(args.dependency.addonId.toString()), APPLICATION->network());
|
2023-06-23 20:01:17 +03:00
|
|
|
auto response = std::make_shared<QByteArray>();
|
2023-04-14 18:59:31 +03:00
|
|
|
|
|
|
|
netJob->addNetAction(Net::Download::makeByteArray(versions_url, response));
|
|
|
|
|
|
|
|
QObject::connect(netJob.get(), &NetJob::succeeded, [=] {
|
|
|
|
QJsonParseError parse_error{};
|
|
|
|
QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error);
|
|
|
|
if (parse_error.error != QJsonParseError::NoError) {
|
|
|
|
qWarning() << "Error while parsing JSON response for getting versions at " << parse_error.offset
|
|
|
|
<< " reason: " << parse_error.errorString();
|
|
|
|
qWarning() << *response;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
callbacks.on_succeed(doc, args.dependency);
|
|
|
|
});
|
|
|
|
|
|
|
|
return netJob;
|
2023-06-30 23:51:15 -07:00
|
|
|
}
|
|
|
|
|