refactor: Remove Outcome from network requests (#4959)

This commit is contained in:
nerix 2023-11-12 14:51:51 +01:00 committed by GitHub
parent 95620e6e10
commit 6faf63c5c4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
22 changed files with 122 additions and 228 deletions

View file

@ -60,6 +60,7 @@
- Dev: Refactor `ChannelView`, removing a bunch of clang-tidy warnings. (#4926) - Dev: Refactor `ChannelView`, removing a bunch of clang-tidy warnings. (#4926)
- Dev: Refactor `IrcMessageHandler`, removing a bunch of clang-tidy warnings & changing its public API. (#4927) - Dev: Refactor `IrcMessageHandler`, removing a bunch of clang-tidy warnings & changing its public API. (#4927)
- Dev: `Details` file properties tab is now populated on Windows. (#4912) - Dev: `Details` file properties tab is now populated on Windows. (#4912)
- Dev: Removed `Outcome` from network requests. (#4959)
## 2.4.6 ## 2.4.6

View file

@ -9,10 +9,9 @@ class QNetworkReply;
namespace chatterino { namespace chatterino {
class Outcome;
class NetworkResult; class NetworkResult;
using NetworkSuccessCallback = std::function<Outcome(NetworkResult)>; using NetworkSuccessCallback = std::function<void(NetworkResult)>;
using NetworkErrorCallback = std::function<void(NetworkResult)>; using NetworkErrorCallback = std::function<void(NetworkResult)>;
using NetworkReplyCreatedCallback = std::function<void(QNetworkReply *)>; using NetworkReplyCreatedCallback = std::function<void(QNetworkReply *)>;
using NetworkFinallyCallback = std::function<void()>; using NetworkFinallyCallback = std::function<void()>;

View file

@ -2,7 +2,6 @@
#include "common/NetworkManager.hpp" #include "common/NetworkManager.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "debug/AssertInGuiThread.hpp" #include "debug/AssertInGuiThread.hpp"
#include "singletons/Paths.hpp" #include "singletons/Paths.hpp"

View file

@ -1,8 +1,6 @@
#include "controllers/notifications/NotificationController.hpp" #include "controllers/notifications/NotificationController.hpp"
#include "Application.hpp" #include "Application.hpp"
#include "common/NetworkRequest.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "controllers/notifications/NotificationModel.hpp" #include "controllers/notifications/NotificationModel.hpp"
#include "controllers/sound/SoundController.hpp" #include "controllers/sound/SoundController.hpp"

View file

@ -4,7 +4,6 @@
#include "common/Common.hpp" #include "common/Common.hpp"
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "debug/AssertInGuiThread.hpp" #include "debug/AssertInGuiThread.hpp"
#include "debug/Benchmark.hpp" #include "debug/Benchmark.hpp"
@ -502,11 +501,11 @@ void Image::actuallyLoad()
NetworkRequest(this->url().string) NetworkRequest(this->url().string)
.concurrent() .concurrent()
.cache() .cache()
.onSuccess([weak](auto result) -> Outcome { .onSuccess([weak](auto result) {
auto shared = weak.lock(); auto shared = weak.lock();
if (!shared) if (!shared)
{ {
return Failure; return;
} }
auto data = result.getData(); auto data = result.getData();
@ -521,14 +520,14 @@ void Image::actuallyLoad()
qCDebug(chatterinoImage) qCDebug(chatterinoImage)
<< "Error: image cant be read " << shared->url().string; << "Error: image cant be read " << shared->url().string;
shared->empty_ = true; shared->empty_ = true;
return Failure; return;
} }
const auto size = reader.size(); const auto size = reader.size();
if (size.isEmpty()) if (size.isEmpty())
{ {
shared->empty_ = true; shared->empty_ = true;
return Failure; return;
} }
// returns 1 for non-animated formats // returns 1 for non-animated formats
@ -538,7 +537,7 @@ void Image::actuallyLoad()
<< "Error: image has less than 1 frame " << "Error: image has less than 1 frame "
<< shared->url().string << ": " << reader.errorString(); << shared->url().string << ": " << reader.errorString();
shared->empty_ = true; shared->empty_ = true;
return Failure; return;
} }
// use "double" to prevent int overflows // use "double" to prevent int overflows
@ -549,7 +548,7 @@ void Image::actuallyLoad()
qCDebug(chatterinoImage) << "image too large in RAM"; qCDebug(chatterinoImage) << "image too large in RAM";
shared->empty_ = true; shared->empty_ = true;
return Failure; return;
} }
auto parsed = detail::readFrames(reader, shared->url()); auto parsed = detail::readFrames(reader, shared->url());
@ -562,8 +561,6 @@ void Image::actuallyLoad()
std::forward<decltype(frames)>(frames)); std::forward<decltype(frames)>(frames));
} }
})); }));
return Success;
}) })
.onError([weak](auto /*result*/) { .onError([weak](auto /*result*/) {
auto shared = weak.lock(); auto shared = weak.lock();

View file

@ -1,7 +1,6 @@
#include "IvrApi.hpp" #include "IvrApi.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include <QUrlQuery> #include <QUrlQuery>
@ -18,12 +17,10 @@ void IvrApi::getSubage(QString userName, QString channelName,
this->makeRequest( this->makeRequest(
QString("twitch/subage/%1/%2").arg(userName).arg(channelName), {}) QString("twitch/subage/%1/%2").arg(userName).arg(channelName), {})
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
successCallback(root); successCallback(root);
return Success;
}) })
.onError([failureCallback](auto result) { .onError([failureCallback](auto result) {
qCWarning(chatterinoIvr) qCWarning(chatterinoIvr)
@ -42,12 +39,10 @@ void IvrApi::getBulkEmoteSets(QString emoteSetList,
urlQuery.addQueryItem("set_id", emoteSetList); urlQuery.addQueryItem("set_id", emoteSetList);
this->makeRequest("twitch/emotes/sets", urlQuery) this->makeRequest("twitch/emotes/sets", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJsonArray(); auto root = result.parseJsonArray();
successCallback(root); successCallback(root);
return Success;
}) })
.onError([failureCallback](auto result) { .onError([failureCallback](auto result) {
qCWarning(chatterinoIvr) qCWarning(chatterinoIvr)

View file

@ -3,7 +3,6 @@
#include "common/Env.hpp" #include "common/Env.hpp"
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "messages/Image.hpp" #include "messages/Image.hpp"
#include "messages/Link.hpp" #include "messages/Link.hpp"
#include "singletons/Settings.hpp" #include "singletons/Settings.hpp"
@ -27,8 +26,7 @@ void LinkResolver::getLinkInfo(
QUrl::toPercentEncoding(url, "", "/:")))) QUrl::toPercentEncoding(url, "", "/:"))))
.caller(caller) .caller(caller)
.timeout(30000) .timeout(30000)
.onSuccess([successCallback, .onSuccess([successCallback, url](NetworkResult result) mutable {
url](NetworkResult result) mutable -> Outcome {
auto root = result.parseJson(); auto root = result.parseJson();
auto statusCode = root.value("status").toInt(); auto statusCode = root.value("status").toInt();
QString response; QString response;
@ -54,8 +52,6 @@ void LinkResolver::getLinkInfo(
} }
successCallback(QUrl::fromPercentEncoding(response.toUtf8()), successCallback(QUrl::fromPercentEncoding(response.toUtf8()),
Link(Link::Url, linkString), thumbnail); Link(Link::Url, linkString), thumbnail);
return Success;
}) })
.onError([successCallback, url](auto /*result*/) { .onError([successCallback, url](auto /*result*/) {
successCallback("No link info found", Link(Link::Url, url), successCallback("No link info found", Link(Link::Url, url),

View file

@ -2,6 +2,7 @@
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "messages/Emote.hpp" #include "messages/Emote.hpp"
#include "messages/Image.hpp" #include "messages/Image.hpp"
@ -202,7 +203,7 @@ void BttvEmotes::loadEmotes()
NetworkRequest(QString(globalEmoteApiUrl)) NetworkRequest(QString(globalEmoteApiUrl))
.timeout(30000) .timeout(30000)
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
auto emotes = this->global_.get(); auto emotes = this->global_.get();
auto pair = parseGlobalEmotes(result.parseJsonArray(), *emotes); auto pair = parseGlobalEmotes(result.parseJsonArray(), *emotes);
if (pair.first) if (pair.first)
@ -210,7 +211,6 @@ void BttvEmotes::loadEmotes()
this->setEmotes( this->setEmotes(
std::make_shared<EmoteMap>(std::move(pair.second))); std::make_shared<EmoteMap>(std::move(pair.second)));
} }
return pair.first;
}) })
.execute(); .execute();
} }
@ -229,7 +229,7 @@ void BttvEmotes::loadChannel(std::weak_ptr<Channel> channel,
NetworkRequest(QString(bttvChannelEmoteApiUrl) + channelId) NetworkRequest(QString(bttvChannelEmoteApiUrl) + channelId)
.timeout(20000) .timeout(20000)
.onSuccess([callback = std::move(callback), channel, channelDisplayName, .onSuccess([callback = std::move(callback), channel, channelDisplayName,
manualRefresh](auto result) -> Outcome { manualRefresh](auto result) {
auto pair = auto pair =
parseChannelEmotes(result.parseJson(), channelDisplayName); parseChannelEmotes(result.parseJson(), channelDisplayName);
bool hasEmotes = false; bool hasEmotes = false;
@ -251,7 +251,6 @@ void BttvEmotes::loadChannel(std::weak_ptr<Channel> channel,
makeSystemMessage(CHANNEL_HAS_NO_EMOTES)); makeSystemMessage(CHANNEL_HAS_NO_EMOTES));
} }
} }
return pair.first;
}) })
.onError([channelId, channel, manualRefresh](auto result) { .onError([channelId, channel, manualRefresh](auto result) {
auto shared = channel.lock(); auto shared = channel.lock();

View file

@ -2,7 +2,6 @@
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "messages/Emote.hpp" #include "messages/Emote.hpp"
#include <QJsonArray> #include <QJsonArray>
@ -39,7 +38,7 @@ void ChatterinoBadges::loadChatterinoBadges()
NetworkRequest(url) NetworkRequest(url)
.concurrent() .concurrent()
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
auto jsonRoot = result.parseJson(); auto jsonRoot = result.parseJson();
std::unique_lock lock(this->mutex_); std::unique_lock lock(this->mutex_);
@ -64,8 +63,6 @@ void ChatterinoBadges::loadChatterinoBadges()
} }
++index; ++index;
} }
return Success;
}) })
.execute(); .execute();
} }

View file

@ -2,7 +2,6 @@
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "messages/Emote.hpp" #include "messages/Emote.hpp"
#include "providers/ffz/FfzUtil.hpp" #include "providers/ffz/FfzUtil.hpp"
@ -59,7 +58,7 @@ void FfzBadges::load()
static QUrl url("https://api.frankerfacez.com/v1/badges/ids"); static QUrl url("https://api.frankerfacez.com/v1/badges/ids");
NetworkRequest(url) NetworkRequest(url)
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
std::unique_lock lock(this->mutex_); std::unique_lock lock(this->mutex_);
auto jsonRoot = result.parseJson(); auto jsonRoot = result.parseJson();
@ -103,8 +102,6 @@ void FfzBadges::load()
} }
} }
} }
return Success;
}) })
.execute(); .execute();
} }

View file

@ -2,7 +2,6 @@
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "messages/Emote.hpp" #include "messages/Emote.hpp"
#include "messages/Image.hpp" #include "messages/Image.hpp"
@ -197,11 +196,9 @@ void FfzEmotes::loadEmotes()
NetworkRequest(url) NetworkRequest(url)
.timeout(30000) .timeout(30000)
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
auto parsedSet = parseGlobalEmotes(result.parseJson()); auto parsedSet = parseGlobalEmotes(result.parseJson());
this->setEmotes(std::make_shared<EmoteMap>(std::move(parsedSet))); this->setEmotes(std::make_shared<EmoteMap>(std::move(parsedSet)));
return Success;
}) })
.execute(); .execute();
} }
@ -227,7 +224,7 @@ void FfzEmotes::loadChannel(
.onSuccess([emoteCallback = std::move(emoteCallback), .onSuccess([emoteCallback = std::move(emoteCallback),
modBadgeCallback = std::move(modBadgeCallback), modBadgeCallback = std::move(modBadgeCallback),
vipBadgeCallback = std::move(vipBadgeCallback), channel, vipBadgeCallback = std::move(vipBadgeCallback), channel,
manualRefresh](const auto &result) -> Outcome { manualRefresh](const auto &result) {
const auto json = result.parseJson(); const auto json = result.parseJson();
auto emoteMap = parseChannelEmotes(json); auto emoteMap = parseChannelEmotes(json);
@ -254,8 +251,6 @@ void FfzEmotes::loadChannel(
makeSystemMessage(CHANNEL_HAS_NO_EMOTES)); makeSystemMessage(CHANNEL_HAS_NO_EMOTES));
} }
} }
return Success;
}) })
.onError([channelID, channel, manualRefresh](const auto &result) { .onError([channelID, channel, manualRefresh](const auto &result) {
auto shared = channel.lock(); auto shared = channel.lock();

View file

@ -26,11 +26,11 @@ void load(const QString &channelName, std::weak_ptr<Channel> channelPtr,
const auto url = constructRecentMessagesUrl(channelName); const auto url = constructRecentMessagesUrl(channelName);
NetworkRequest(url) NetworkRequest(url)
.onSuccess([channelPtr, onLoaded](const auto &result) -> Outcome { .onSuccess([channelPtr, onLoaded](const auto &result) {
auto shared = channelPtr.lock(); auto shared = channelPtr.lock();
if (!shared) if (!shared)
{ {
return Failure; return;
} }
qCDebug(LOG) << "Successfully loaded recent messages for" qCDebug(LOG) << "Successfully loaded recent messages for"
@ -65,8 +65,6 @@ void load(const QString &channelName, std::weak_ptr<Channel> channelPtr,
onLoaded(messages); onLoaded(messages);
}); });
return Success;
}) })
.onError([channelPtr, onError](const NetworkResult &result) { .onError([channelPtr, onError](const NetworkResult &result) {
auto shared = channelPtr.lock(); auto shared = channelPtr.lock();

View file

@ -3,7 +3,6 @@
#include "common/Literals.hpp" #include "common/Literals.hpp"
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
namespace { namespace {
@ -24,12 +23,11 @@ void SeventvAPI::getUserByTwitchID(
{ {
NetworkRequest(API_URL_USER.arg(twitchID), NetworkRequestType::Get) NetworkRequest(API_URL_USER.arg(twitchID), NetworkRequestType::Get)
.timeout(20000) .timeout(20000)
.onSuccess([callback = std::move(onSuccess)]( .onSuccess(
const NetworkResult &result) -> Outcome { [callback = std::move(onSuccess)](const NetworkResult &result) {
auto json = result.parseJson(); auto json = result.parseJson();
callback(json); callback(json);
return Success; })
})
.onError([callback = std::move(onError)](const NetworkResult &result) { .onError([callback = std::move(onError)](const NetworkResult &result) {
callback(result); callback(result);
}) })
@ -42,12 +40,11 @@ void SeventvAPI::getEmoteSet(const QString &emoteSet,
{ {
NetworkRequest(API_URL_EMOTE_SET.arg(emoteSet), NetworkRequestType::Get) NetworkRequest(API_URL_EMOTE_SET.arg(emoteSet), NetworkRequestType::Get)
.timeout(25000) .timeout(25000)
.onSuccess([callback = std::move(onSuccess)]( .onSuccess(
const NetworkResult &result) -> Outcome { [callback = std::move(onSuccess)](const NetworkResult &result) {
auto json = result.parseJson(); auto json = result.parseJson();
callback(json); callback(json);
return Success; })
})
.onError([callback = std::move(onError)](const NetworkResult &result) { .onError([callback = std::move(onError)](const NetworkResult &result) {
callback(result); callback(result);
}) })
@ -72,9 +69,8 @@ void SeventvAPI::updatePresence(const QString &twitchChannelID,
NetworkRequestType::Post) NetworkRequestType::Post)
.json(payload) .json(payload)
.timeout(10000) .timeout(10000)
.onSuccess([callback = std::move(onSuccess)](const auto &) -> Outcome { .onSuccess([callback = std::move(onSuccess)](const auto &) {
callback(); callback();
return Success;
}) })
.onError([callback = std::move(onError)](const NetworkResult &result) { .onError([callback = std::move(onError)](const NetworkResult &result) {
callback(result); callback(result);

View file

@ -4,7 +4,6 @@
#include "common/Channel.hpp" #include "common/Channel.hpp"
#include "common/Env.hpp" #include "common/Env.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "controllers/accounts/AccountController.hpp" #include "controllers/accounts/AccountController.hpp"
#include "debug/AssertInGuiThread.hpp" #include "debug/AssertInGuiThread.hpp"
@ -500,7 +499,6 @@ void TwitchAccount::loadSeventvUserID()
{ {
this->seventvUserID_ = id; this->seventvUserID_ = id;
} }
return Success;
}, },
[](const auto &result) { [](const auto &result) {
qCDebug(chatterinoSeventv) qCDebug(chatterinoSeventv)

View file

@ -2,7 +2,6 @@
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "messages/Emote.hpp" #include "messages/Emote.hpp"
#include "messages/Image.hpp" #include "messages/Image.hpp"
@ -238,7 +237,7 @@ void TwitchBadges::loadEmoteImage(const QString &name, ImagePtr image,
NetworkRequest(image->url().string) NetworkRequest(image->url().string)
.concurrent() .concurrent()
.cache() .cache()
.onSuccess([this, name, callback](auto result) -> Outcome { .onSuccess([this, name, callback](auto result) {
auto data = result.getData(); auto data = result.getData();
// const cast since we are only reading from it // const cast since we are only reading from it
@ -248,18 +247,18 @@ void TwitchBadges::loadEmoteImage(const QString &name, ImagePtr image,
if (!reader.canRead() || reader.size().isEmpty()) if (!reader.canRead() || reader.size().isEmpty())
{ {
return Failure; return;
} }
QImage image = reader.read(); QImage image = reader.read();
if (image.isNull()) if (image.isNull())
{ {
return Failure; return;
} }
if (reader.imageCount() <= 0) if (reader.imageCount() <= 0)
{ {
return Failure; return;
} }
auto icon = std::make_shared<QIcon>(QPixmap::fromImage(image)); auto icon = std::make_shared<QIcon>(QPixmap::fromImage(image));
@ -270,8 +269,6 @@ void TwitchBadges::loadEmoteImage(const QString &name, ImagePtr image,
} }
callback(name, icon); callback(name, icon);
return Success;
}) })
.execute(); .execute();
} }

View file

@ -1381,11 +1381,11 @@ void TwitchChannel::refreshCheerEmotes()
getHelix()->getCheermotes( getHelix()->getCheermotes(
this->roomId(), this->roomId(),
[this, weak = weakOf<Channel>(this)]( [this, weak = weakOf<Channel>(this)](
const std::vector<HelixCheermoteSet> &cheermoteSets) -> Outcome { const std::vector<HelixCheermoteSet> &cheermoteSets) {
auto shared = weak.lock(); auto shared = weak.lock();
if (!shared) if (!shared)
{ {
return Failure; return;
} }
std::vector<CheerEmoteSet> emoteSets; std::vector<CheerEmoteSet> emoteSets;
@ -1444,12 +1444,9 @@ void TwitchChannel::refreshCheerEmotes()
} }
*this->cheerEmoteSets_.access() = std::move(emoteSets); *this->cheerEmoteSets_.access() = std::move(emoteSets);
return Success;
}, },
[] { [] {
// Failure // Failure
return Failure;
}); });
} }
@ -1656,11 +1653,10 @@ void TwitchChannel::updateSevenTVActivity()
std::dynamic_pointer_cast<TwitchChannel>(chan.lock()); std::dynamic_pointer_cast<TwitchChannel>(chan.lock());
if (!self) if (!self)
{ {
return Success; return;
} }
self->nextSeventvActivity_ = self->nextSeventvActivity_ =
QDateTime::currentDateTimeUtc().addSecs(60); QDateTime::currentDateTimeUtc().addSecs(60);
return Success;
}, },
[](const auto &result) { [](const auto &result) {
qCDebug(chatterinoSeventv) qCDebug(chatterinoSeventv)

View file

@ -5,7 +5,6 @@
#include "common/Channel.hpp" #include "common/Channel.hpp"
#include "common/ChannelChatters.hpp" #include "common/ChannelChatters.hpp"
#include "common/Common.hpp" #include "common/Common.hpp"
#include "common/Outcome.hpp"
#include "common/UniqueAccess.hpp" #include "common/UniqueAccess.hpp"
#include "providers/twitch/TwitchEmotes.hpp" #include "providers/twitch/TwitchEmotes.hpp"
#include "util/QStringHash.hpp" #include "util/QStringHash.hpp"

View file

@ -3,7 +3,6 @@
#include "common/Literals.hpp" #include "common/Literals.hpp"
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "util/CancellationToken.hpp" #include "util/CancellationToken.hpp"
@ -57,14 +56,14 @@ void Helix::fetchUsers(QStringList userIds, QStringList userLogins,
// TODO: set on success and on error // TODO: set on success and on error
this->makeGet("users", urlQuery) this->makeGet("users", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixUser> users; std::vector<HelixUser> users;
@ -75,8 +74,6 @@ void Helix::fetchUsers(QStringList userIds, QStringList userLogins,
} }
successCallback(users); successCallback(users);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -138,15 +135,14 @@ void Helix::getChannelFollowers(
// TODO: set on success and on error // TODO: set on success and on error
this->makeGet("channels/followers", urlQuery) this->makeGet("channels/followers", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
if (root.empty()) if (root.empty())
{ {
failureCallback("Bad JSON response"); failureCallback("Bad JSON response");
return Failure; return;
} }
successCallback(HelixGetChannelFollowersResponse(root)); successCallback(HelixGetChannelFollowersResponse(root));
return Success;
}) })
.onError([failureCallback](auto result) { .onError([failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
@ -182,14 +178,14 @@ void Helix::fetchStreams(
// TODO: set on success and on error // TODO: set on success and on error
this->makeGet("streams", urlQuery) this->makeGet("streams", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixStream> streams; std::vector<HelixStream> streams;
@ -200,8 +196,6 @@ void Helix::fetchStreams(
} }
successCallback(streams); successCallback(streams);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -275,14 +269,14 @@ void Helix::fetchGames(QStringList gameIds, QStringList gameNames,
// TODO: set on success and on error // TODO: set on success and on error
this->makeGet("games", urlQuery) this->makeGet("games", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixGame> games; std::vector<HelixGame> games;
@ -293,8 +287,6 @@ void Helix::fetchGames(QStringList gameIds, QStringList gameNames,
} }
successCallback(games); successCallback(games);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -311,14 +303,14 @@ void Helix::searchGames(QString gameName,
urlQuery.addQueryItem("query", gameName); urlQuery.addQueryItem("query", gameName);
this->makeGet("search/categories", urlQuery) this->makeGet("search/categories", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixGame> games; std::vector<HelixGame> games;
@ -329,8 +321,6 @@ void Helix::searchGames(QString gameName,
} }
successCallback(games); successCallback(games);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -369,20 +359,19 @@ void Helix::createClip(QString channelId,
this->makePost("clips", urlQuery) this->makePost("clips", urlQuery)
.header("Content-Type", "application/json") .header("Content-Type", "application/json")
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(HelixClipError::Unknown); failureCallback(HelixClipError::Unknown);
return Failure; return;
} }
HelixClip clip(data.toArray()[0].toObject()); HelixClip clip(data.toArray()[0].toObject());
successCallback(clip); successCallback(clip);
return Success;
}) })
.onError([failureCallback](auto result) { .onError([failureCallback](auto result) {
switch (result.status().value_or(0)) switch (result.status().value_or(0))
@ -425,14 +414,14 @@ void Helix::fetchChannels(
} }
this->makeGet("channels", urlQuery) this->makeGet("channels", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixChannel> channels; std::vector<HelixChannel> channels;
@ -443,7 +432,6 @@ void Helix::fetchChannels(
} }
successCallback(channels); successCallback(channels);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
failureCallback(); failureCallback();
@ -459,20 +447,19 @@ void Helix::getChannel(QString broadcasterId,
urlQuery.addQueryItem("broadcaster_id", broadcasterId); urlQuery.addQueryItem("broadcaster_id", broadcasterId);
this->makeGet("channels", urlQuery) this->makeGet("channels", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
HelixChannel channel(data.toArray()[0].toObject()); HelixChannel channel(data.toArray()[0].toObject());
successCallback(channel); successCallback(channel);
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
failureCallback(); failureCallback();
@ -495,20 +482,19 @@ void Helix::createStreamMarker(
this->makePost("streams/markers", QUrlQuery()) this->makePost("streams/markers", QUrlQuery())
.json(payload) .json(payload)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(HelixStreamMarkerError::Unknown); failureCallback(HelixStreamMarkerError::Unknown);
return Failure; return;
} }
HelixStreamMarker streamMarker(data.toArray()[0].toObject()); HelixStreamMarker streamMarker(data.toArray()[0].toObject());
successCallback(streamMarker); successCallback(streamMarker);
return Success;
}) })
.onError([failureCallback](NetworkResult result) { .onError([failureCallback](NetworkResult result) {
switch (result.status().value_or(0)) switch (result.status().value_or(0))
@ -597,9 +583,8 @@ void Helix::blockUser(QString targetUserId, const QObject *caller,
this->makePut("users/blocks", urlQuery) this->makePut("users/blocks", urlQuery)
.caller(caller) .caller(caller)
.onSuccess([successCallback](auto /*result*/) -> Outcome { .onSuccess([successCallback](auto /*result*/) {
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -617,9 +602,8 @@ void Helix::unblockUser(QString targetUserId, const QObject *caller,
this->makeDelete("users/blocks", urlQuery) this->makeDelete("users/blocks", urlQuery)
.caller(caller) .caller(caller)
.onSuccess([successCallback](auto /*result*/) -> Outcome { .onSuccess([successCallback](auto /*result*/) {
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](auto /*result*/) { .onError([failureCallback](auto /*result*/) {
// TODO: make better xd // TODO: make better xd
@ -657,9 +641,8 @@ void Helix::updateChannel(QString broadcasterId, QString gameId,
urlQuery.addQueryItem("broadcaster_id", broadcasterId); urlQuery.addQueryItem("broadcaster_id", broadcasterId);
this->makePatch("channels", urlQuery) this->makePatch("channels", urlQuery)
.json(obj) .json(obj)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
successCallback(result); successCallback(result);
return Success;
}) })
.onError([failureCallback](NetworkResult result) { .onError([failureCallback](NetworkResult result) {
failureCallback(); failureCallback();
@ -680,9 +663,8 @@ void Helix::manageAutoModMessages(
this->makePost("moderation/automod/message", QUrlQuery()) this->makePost("moderation/automod/message", QUrlQuery())
.json(payload) .json(payload)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback, msgID, action](NetworkResult result) { .onError([failureCallback, msgID, action](NetworkResult result) {
switch (result.status().value_or(0)) switch (result.status().value_or(0))
@ -736,14 +718,14 @@ void Helix::getCheermotes(
urlQuery.addQueryItem("broadcaster_id", broadcasterId); urlQuery.addQueryItem("broadcaster_id", broadcasterId);
this->makeGet("bits/cheermotes", urlQuery) this->makeGet("bits/cheermotes", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto root = result.parseJson(); auto root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixCheermoteSet> cheermoteSets; std::vector<HelixCheermoteSet> cheermoteSets;
@ -754,7 +736,6 @@ void Helix::getCheermotes(
} }
successCallback(cheermoteSets); successCallback(cheermoteSets);
return Success;
}) })
.onError([broadcasterId, failureCallback](NetworkResult result) { .onError([broadcasterId, failureCallback](NetworkResult result) {
qCDebug(chatterinoTwitch) qCDebug(chatterinoTwitch)
@ -774,21 +755,19 @@ void Helix::getEmoteSetData(QString emoteSetId,
urlQuery.addQueryItem("emote_set_id", emoteSetId); urlQuery.addQueryItem("emote_set_id", emoteSetId);
this->makeGet("chat/emotes/set", urlQuery) this->makeGet("chat/emotes/set", urlQuery)
.onSuccess([successCallback, failureCallback, .onSuccess([successCallback, failureCallback, emoteSetId](auto result) {
emoteSetId](auto result) -> Outcome {
QJsonObject root = result.parseJson(); QJsonObject root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray() || data.toArray().isEmpty()) if (!data.isArray() || data.toArray().isEmpty())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
HelixEmoteSetData emoteSetData(data.toArray()[0].toObject()); HelixEmoteSetData emoteSetData(data.toArray()[0].toObject());
successCallback(emoteSetData); successCallback(emoteSetData);
return Success;
}) })
.onError([failureCallback](NetworkResult result) { .onError([failureCallback](NetworkResult result) {
// TODO: make better xd // TODO: make better xd
@ -806,15 +785,14 @@ void Helix::getChannelEmotes(
urlQuery.addQueryItem("broadcaster_id", broadcasterId); urlQuery.addQueryItem("broadcaster_id", broadcasterId);
this->makeGet("chat/emotes", urlQuery) this->makeGet("chat/emotes", urlQuery)
.onSuccess([successCallback, .onSuccess([successCallback, failureCallback](NetworkResult result) {
failureCallback](NetworkResult result) -> Outcome {
QJsonObject root = result.parseJson(); QJsonObject root = result.parseJson();
auto data = root.value("data"); auto data = root.value("data");
if (!data.isArray()) if (!data.isArray())
{ {
failureCallback(); failureCallback();
return Failure; return;
} }
std::vector<HelixChannelEmote> channelEmotes; std::vector<HelixChannelEmote> channelEmotes;
@ -825,7 +803,6 @@ void Helix::getChannelEmotes(
} }
successCallback(channelEmotes); successCallback(channelEmotes);
return Success;
}) })
.onError([failureCallback](auto result) { .onError([failureCallback](auto result) {
// TODO: make better xd // TODO: make better xd
@ -847,7 +824,7 @@ void Helix::updateUserChatColor(
this->makePut("chat/color", QUrlQuery()) this->makePut("chat/color", QUrlQuery())
.json(payload) .json(payload)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto obj = result.parseJson(); auto obj = result.parseJson();
if (result.status() != 204) if (result.status() != 204)
{ {
@ -858,7 +835,6 @@ void Helix::updateUserChatColor(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -931,7 +907,7 @@ void Helix::deleteChatMessages(
} }
this->makeDelete("moderation/chat", urlQuery) this->makeDelete("moderation/chat", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -941,7 +917,6 @@ void Helix::deleteChatMessages(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1016,7 +991,7 @@ void Helix::addChannelModerator(
urlQuery.addQueryItem("user_id", userID); urlQuery.addQueryItem("user_id", userID);
this->makePost("moderation/moderators", urlQuery) this->makePost("moderation/moderators", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1026,7 +1001,6 @@ void Helix::addChannelModerator(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1111,7 +1085,7 @@ void Helix::removeChannelModerator(
urlQuery.addQueryItem("user_id", userID); urlQuery.addQueryItem("user_id", userID);
this->makeDelete("moderation/moderators", urlQuery) this->makeDelete("moderation/moderators", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1121,7 +1095,6 @@ void Helix::removeChannelModerator(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1205,7 +1178,7 @@ void Helix::sendChatAnnouncement(
this->makePost("chat/announcements", urlQuery) this->makePost("chat/announcements", urlQuery)
.json(body) .json(body)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1215,7 +1188,6 @@ void Helix::sendChatAnnouncement(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1281,7 +1253,7 @@ void Helix::addChannelVIP(
urlQuery.addQueryItem("user_id", userID); urlQuery.addQueryItem("user_id", userID);
this->makePost("channels/vips", urlQuery) this->makePost("channels/vips", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1291,7 +1263,6 @@ void Helix::addChannelVIP(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1366,7 +1337,7 @@ void Helix::removeChannelVIP(
urlQuery.addQueryItem("user_id", userID); urlQuery.addQueryItem("user_id", userID);
this->makeDelete("channels/vips", urlQuery) this->makeDelete("channels/vips", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1376,7 +1347,6 @@ void Helix::removeChannelVIP(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1462,7 +1432,7 @@ void Helix::unbanUser(
urlQuery.addQueryItem("user_id", userID); urlQuery.addQueryItem("user_id", userID);
this->makeDelete("moderation/bans", urlQuery) this->makeDelete("moderation/bans", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1472,7 +1442,6 @@ void Helix::unbanUser(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1574,11 +1543,9 @@ void Helix::startRaid(
urlQuery.addQueryItem("to_broadcaster_id", toBroadcasterID); urlQuery.addQueryItem("to_broadcaster_id", toBroadcasterID);
this->makePost("raids", urlQuery) this->makePost("raids", urlQuery)
.onSuccess( .onSuccess([successCallback, failureCallback](auto /*result*/) {
[successCallback, failureCallback](auto /*result*/) -> Outcome { successCallback();
successCallback(); })
return Success;
})
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
{ {
@ -1660,7 +1627,7 @@ void Helix::cancelRaid(
urlQuery.addQueryItem("broadcaster_id", broadcasterID); urlQuery.addQueryItem("broadcaster_id", broadcasterID);
this->makeDelete("raids", urlQuery) this->makeDelete("raids", urlQuery)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1670,7 +1637,6 @@ void Helix::cancelRaid(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1828,7 +1794,7 @@ void Helix::updateChatSettings(
this->makePatch("chat/settings", urlQuery) this->makePatch("chat/settings", urlQuery)
.json(payload) .json(payload)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1838,7 +1804,6 @@ void Helix::updateChatSettings(
auto response = result.parseJson(); auto response = result.parseJson();
successCallback(HelixChatSettings( successCallback(HelixChatSettings(
response.value("data").toArray().first().toObject())); response.value("data").toArray().first().toObject()));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -1957,7 +1922,7 @@ void Helix::fetchChatters(
} }
this->makeGet("chat/chatters", urlQuery) this->makeGet("chat/chatters", urlQuery)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -1967,7 +1932,6 @@ void Helix::fetchChatters(
auto response = result.parseJson(); auto response = result.parseJson();
successCallback(HelixChatters(response)); successCallback(HelixChatters(response));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2072,7 +2036,7 @@ void Helix::fetchModerators(
} }
this->makeGet("moderation/moderators", urlQuery) this->makeGet("moderation/moderators", urlQuery)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2082,7 +2046,6 @@ void Helix::fetchModerators(
auto response = result.parseJson(); auto response = result.parseJson();
successCallback(HelixModerators(response)); successCallback(HelixModerators(response));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2164,7 +2127,7 @@ void Helix::banUser(QString broadcasterID, QString moderatorID, QString userID,
this->makePost("moderation/bans", urlQuery) this->makePost("moderation/bans", urlQuery)
.json(payload) .json(payload)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2173,7 +2136,6 @@ void Helix::banUser(QString broadcasterID, QString moderatorID, QString userID,
} }
// we don't care about the response // we don't care about the response
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2267,7 +2229,7 @@ void Helix::sendWhisper(
this->makePost("whispers", urlQuery) this->makePost("whispers", urlQuery)
.json(payload) .json(payload)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2276,7 +2238,6 @@ void Helix::sendWhisper(
} }
// we don't care about the response // we don't care about the response
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2416,7 +2377,7 @@ void Helix::getChannelVIPs(
this->makeGet("channels/vips", urlQuery) this->makeGet("channels/vips", urlQuery)
.header("Content-Type", "application/json") .header("Content-Type", "application/json")
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2433,7 +2394,6 @@ void Helix::getChannelVIPs(
} }
successCallback(channelVips); successCallback(channelVips);
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2509,18 +2469,17 @@ void Helix::startCommercial(
this->makePost("channels/commercial", QUrlQuery()) this->makePost("channels/commercial", QUrlQuery())
.json(payload) .json(payload)
.onSuccess([successCallback, failureCallback](auto result) -> Outcome { .onSuccess([successCallback, failureCallback](auto result) {
auto obj = result.parseJson(); auto obj = result.parseJson();
if (obj.isEmpty()) if (obj.isEmpty())
{ {
failureCallback( failureCallback(
Error::Unknown, Error::Unknown,
"Twitch didn't send any information about this error."); "Twitch didn't send any information about this error.");
return Failure; return;
} }
successCallback(HelixStartCommercialResponse(obj)); successCallback(HelixStartCommercialResponse(obj));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2605,7 +2564,7 @@ void Helix::getGlobalBadges(
using Error = HelixGetGlobalBadgesError; using Error = HelixGetGlobalBadgesError;
this->makeGet("chat/badges/global", QUrlQuery()) this->makeGet("chat/badges/global", QUrlQuery())
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2615,7 +2574,6 @@ void Helix::getGlobalBadges(
auto response = result.parseJson(); auto response = result.parseJson();
successCallback(HelixGlobalBadges(response)); successCallback(HelixGlobalBadges(response));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2658,7 +2616,7 @@ void Helix::getChannelBadges(
urlQuery.addQueryItem("broadcaster_id", broadcasterID); urlQuery.addQueryItem("broadcaster_id", broadcasterID);
this->makeGet("chat/badges", urlQuery) this->makeGet("chat/badges", urlQuery)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2668,7 +2626,6 @@ void Helix::getChannelBadges(
auto response = result.parseJson(); auto response = result.parseJson();
successCallback(HelixChannelBadges(response)); successCallback(HelixChannelBadges(response));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2717,7 +2674,7 @@ void Helix::updateShieldMode(
this->makePut("moderation/shield_mode", urlQuery) this->makePut("moderation/shield_mode", urlQuery)
.json(payload) .json(payload)
.onSuccess([successCallback](auto result) -> Outcome { .onSuccess([successCallback](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2728,7 +2685,6 @@ void Helix::updateShieldMode(
const auto response = result.parseJson(); const auto response = result.parseJson();
successCallback( successCallback(
HelixShieldModeStatus(response["data"][0].toObject())); HelixShieldModeStatus(response["data"][0].toObject()));
return Success;
}) })
.onError([failureCallback](const auto &result) -> void { .onError([failureCallback](const auto &result) -> void {
if (!result.status()) if (!result.status())
@ -2790,7 +2746,7 @@ void Helix::sendShoutout(
this->makePost("chat/shoutouts", urlQuery) this->makePost("chat/shoutouts", urlQuery)
.header("Content-Type", "application/json") .header("Content-Type", "application/json")
.onSuccess([successCallback](NetworkResult result) -> Outcome { .onSuccess([successCallback](NetworkResult result) {
if (result.status() != 204) if (result.status() != 204)
{ {
qCWarning(chatterinoTwitch) qCWarning(chatterinoTwitch)
@ -2799,7 +2755,6 @@ void Helix::sendShoutout(
} }
successCallback(); successCallback();
return Success;
}) })
.onError([failureCallback](const NetworkResult &result) -> void { .onError([failureCallback](const NetworkResult &result) -> void {
if (!result.status()) if (!result.status())
@ -2944,33 +2899,33 @@ void Helix::paginate(const QString &url, const QUrlQuery &baseQuery,
CancellationToken &&cancellationToken) CancellationToken &&cancellationToken)
{ {
auto onSuccess = auto onSuccess =
std::make_shared<std::function<Outcome(NetworkResult)>>(nullptr); std::make_shared<std::function<void(NetworkResult)>>(nullptr);
// This is the actual callback passed to NetworkRequest. // This is the actual callback passed to NetworkRequest.
// It wraps the shared-ptr. // It wraps the shared-ptr.
auto onSuccessCb = [onSuccess](const auto &res) -> Outcome { auto onSuccessCb = [onSuccess](const auto &res) {
return (*onSuccess)(res); return (*onSuccess)(res);
}; };
*onSuccess = [this, onPage = std::move(onPage), onError, onSuccessCb, *onSuccess = [this, onPage = std::move(onPage), onError, onSuccessCb,
url{url}, baseQuery{baseQuery}, url{url}, baseQuery{baseQuery},
cancellationToken = std::move(cancellationToken)]( cancellationToken =
const NetworkResult &res) -> Outcome { std::move(cancellationToken)](const NetworkResult &res) {
if (cancellationToken.isCancelled()) if (cancellationToken.isCancelled())
{ {
return Success; return;
} }
const auto json = res.parseJson(); const auto json = res.parseJson();
if (!onPage(json)) if (!onPage(json))
{ {
// The consumer doesn't want any more pages // The consumer doesn't want any more pages
return Success; return;
} }
auto cursor = json["pagination"_L1]["cursor"_L1].toString(); auto cursor = json["pagination"_L1]["cursor"_L1].toString();
if (cursor.isEmpty()) if (cursor.isEmpty())
{ {
return Success; return;
} }
auto query = baseQuery; auto query = baseQuery;
@ -2981,8 +2936,6 @@ void Helix::paginate(const QString &url, const QUrlQuery &baseQuery,
.onSuccess(onSuccessCb) .onSuccess(onSuccessCb)
.onError(onError) .onError(onError)
.execute(); .execute();
return Success;
}; };
this->makeGet(url, baseQuery) this->makeGet(url, baseQuery)

View file

@ -3,7 +3,6 @@
#include "common/Modes.hpp" #include "common/Modes.hpp"
#include "common/NetworkRequest.hpp" #include "common/NetworkRequest.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "common/Version.hpp" #include "common/Version.hpp"
#include "Settings.hpp" #include "Settings.hpp"
@ -122,7 +121,7 @@ void Updates::installUpdates()
box->raise(); box->raise();
}); });
}) })
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
auto *box = new QMessageBox( auto *box = new QMessageBox(
@ -132,7 +131,7 @@ void Updates::installUpdates()
.arg(result.formatError())); .arg(result.formatError()));
box->setAttribute(Qt::WA_DeleteOnClose); box->setAttribute(Qt::WA_DeleteOnClose);
box->exec(); box->exec();
return Failure; return;
} }
QByteArray object = result.getData(); QByteArray object = result.getData();
@ -145,7 +144,7 @@ void Updates::installUpdates()
if (file.write(object) == -1) if (file.write(object) == -1)
{ {
this->setStatus_(WriteFileFailed); this->setStatus_(WriteFileFailed);
return Failure; return;
} }
file.flush(); file.flush();
file.close(); file.close();
@ -156,7 +155,6 @@ void Updates::installUpdates()
{filename, "restart"}); {filename, "restart"});
QApplication::exit(0); QApplication::exit(0);
return Success;
}) })
.execute(); .execute();
this->setStatus_(Downloading); this->setStatus_(Downloading);
@ -183,7 +181,7 @@ void Updates::installUpdates()
box->setAttribute(Qt::WA_DeleteOnClose); box->setAttribute(Qt::WA_DeleteOnClose);
box->exec(); box->exec();
}) })
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
if (result.status() != 200) if (result.status() != 200)
{ {
auto *box = new QMessageBox( auto *box = new QMessageBox(
@ -193,7 +191,7 @@ void Updates::installUpdates()
.arg(result.formatError())); .arg(result.formatError()));
box->setAttribute(Qt::WA_DeleteOnClose); box->setAttribute(Qt::WA_DeleteOnClose);
box->exec(); box->exec();
return Failure; return;
} }
QByteArray object = result.getData(); QByteArray object = result.getData();
@ -216,7 +214,7 @@ void Updates::installUpdates()
box->exec(); box->exec();
QDesktopServices::openUrl(this->updateExe_); QDesktopServices::openUrl(this->updateExe_);
return Failure; return;
} }
file.flush(); file.flush();
file.close(); file.close();
@ -239,8 +237,6 @@ void Updates::installUpdates()
QDesktopServices::openUrl(this->updateExe_); QDesktopServices::openUrl(this->updateExe_);
} }
return Success;
}) })
.execute(); .execute();
this->setStatus_(Downloading); this->setStatus_(Downloading);
@ -279,7 +275,7 @@ void Updates::checkForUpdates()
NetworkRequest(url) NetworkRequest(url)
.timeout(60000) .timeout(60000)
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
const auto object = result.parseJson(); const auto object = result.parseJson();
/// Version available on every platform /// Version available on every platform
auto version = object["version"]; auto version = object["version"];
@ -289,7 +285,7 @@ void Updates::checkForUpdates()
this->setStatus_(SearchFailed); this->setStatus_(SearchFailed);
qCDebug(chatterinoUpdate) qCDebug(chatterinoUpdate)
<< "error checking version - missing 'version'" << object; << "error checking version - missing 'version'" << object;
return Failure; return;
} }
# if defined Q_OS_WIN || defined Q_OS_MACOS # if defined Q_OS_WIN || defined Q_OS_MACOS
@ -300,7 +296,7 @@ void Updates::checkForUpdates()
this->setStatus_(SearchFailed); this->setStatus_(SearchFailed);
qCDebug(chatterinoUpdate) qCDebug(chatterinoUpdate)
<< "error checking version - missing 'updateexe'" << object; << "error checking version - missing 'updateexe'" << object;
return Failure; return;
} }
this->updateExe_ = updateExeUrl.toString(); this->updateExe_ = updateExeUrl.toString();
@ -313,7 +309,7 @@ void Updates::checkForUpdates()
qCDebug(chatterinoUpdate) qCDebug(chatterinoUpdate)
<< "error checking version - missing 'portable_download'" << "error checking version - missing 'portable_download'"
<< object; << object;
return Failure; return;
} }
this->updatePortable_ = portableUrl.toString(); this->updatePortable_ = portableUrl.toString();
# endif # endif
@ -325,7 +321,7 @@ void Updates::checkForUpdates()
this->updateGuideLink_ = updateGuide.toString(); this->updateGuideLink_ = updateGuide.toString();
} }
# else # else
return Failure; return;
# endif # endif
/// Current version /// Current version
@ -342,7 +338,6 @@ void Updates::checkForUpdates()
{ {
this->setStatus_(NoUpdateAvailable); this->setStatus_(NoUpdateAvailable);
} }
return Failure;
}) })
.execute(); .execute();
this->setStatus_(Searching); this->setStatus_(Searching);

View file

@ -156,7 +156,7 @@ void uploadImageToNuuls(RawImageData imageData, ChannelPtr channel,
.headerList(extraHeaders) .headerList(extraHeaders)
.multiPart(payload) .multiPart(payload)
.onSuccess([&textEdit, channel, .onSuccess([&textEdit, channel,
originalFilePath](NetworkResult result) -> Outcome { originalFilePath](NetworkResult result) {
QString link = getSettings()->imageUploaderLink.getValue().isEmpty() QString link = getSettings()->imageUploaderLink.getValue().isEmpty()
? result.getData() ? result.getData()
: getLinkFromResponse( : getLinkFromResponse(
@ -202,8 +202,6 @@ void uploadImageToNuuls(RawImageData imageData, ChannelPtr channel,
} }
logToFile(originalFilePath, link, deletionLink, channel); logToFile(originalFilePath, link, deletionLink, channel);
return Success;
}) })
.onError([channel](NetworkResult result) -> bool { .onError([channel](NetworkResult result) -> bool {
auto errorMessage = auto errorMessage =

View file

@ -804,7 +804,7 @@ void SplitHeader::updateChannelText()
{ {
NetworkRequest(url, NetworkRequestType::Get) NetworkRequest(url, NetworkRequestType::Get)
.caller(this) .caller(this)
.onSuccess([this](auto result) -> Outcome { .onSuccess([this](auto result) {
// NOTE: We do not follow the redirects, so we need to make sure we only treat code 200 as a valid image // NOTE: We do not follow the redirects, so we need to make sure we only treat code 200 as a valid image
if (result.status() == 200) if (result.status() == 200)
{ {
@ -816,7 +816,6 @@ void SplitHeader::updateChannelText()
this->thumbnail_.clear(); this->thumbnail_.clear();
} }
this->updateChannelText(); this->updateChannelText();
return Success;
}) })
.execute(); .execute();
this->lastThumbnail_.restart(); this->lastThumbnail_.restart();

View file

@ -2,7 +2,6 @@
#include "common/NetworkManager.hpp" #include "common/NetworkManager.hpp"
#include "common/NetworkResult.hpp" #include "common/NetworkResult.hpp"
#include "common/Outcome.hpp"
#include <gtest/gtest.h> #include <gtest/gtest.h>
#include <QCoreApplication> #include <QCoreApplication>
@ -83,12 +82,10 @@ TEST(NetworkRequest, Success)
RequestWaiter waiter; RequestWaiter waiter;
NetworkRequest(url) NetworkRequest(url)
.onSuccess( .onSuccess([code, &waiter, url](const NetworkResult &result) {
[code, &waiter, url](const NetworkResult &result) -> Outcome { EXPECT_EQ(result.status(), code);
EXPECT_EQ(result.status(), code); waiter.requestDone();
waiter.requestDone(); })
return Success;
})
.onError([&](const NetworkResult & /*result*/) { .onError([&](const NetworkResult & /*result*/) {
// The codes should *not* throw an error // The codes should *not* throw an error
EXPECT_TRUE(false); EXPECT_TRUE(false);
@ -143,13 +140,11 @@ TEST(NetworkRequest, Error)
RequestWaiter waiter; RequestWaiter waiter;
NetworkRequest(url) NetworkRequest(url)
.onSuccess( .onSuccess([&waiter, url](const NetworkResult & /*result*/) {
[&waiter, url](const NetworkResult & /*result*/) -> Outcome { // The codes should throw an error
// The codes should throw an error EXPECT_TRUE(false);
EXPECT_TRUE(false); waiter.requestDone();
waiter.requestDone(); })
return Success;
})
.onError([code, &waiter, url](const NetworkResult &result) { .onError([code, &waiter, url](const NetworkResult &result) {
EXPECT_EQ(result.status(), code); EXPECT_EQ(result.status(), code);
@ -201,11 +196,10 @@ TEST(NetworkRequest, TimeoutTimingOut)
NetworkRequest(url) NetworkRequest(url)
.timeout(1000) .timeout(1000)
.onSuccess([&waiter](const NetworkResult & /*result*/) -> Outcome { .onSuccess([&waiter](const NetworkResult & /*result*/) {
// The timeout should throw an error // The timeout should throw an error
EXPECT_TRUE(false); EXPECT_TRUE(false);
waiter.requestDone(); waiter.requestDone();
return Success;
}) })
.onError([&waiter, url](const NetworkResult &result) { .onError([&waiter, url](const NetworkResult &result) {
qDebug() << QTime::currentTime().toString() qDebug() << QTime::currentTime().toString()
@ -232,11 +226,10 @@ TEST(NetworkRequest, TimeoutNotTimingOut)
NetworkRequest(url) NetworkRequest(url)
.timeout(3000) .timeout(3000)
.onSuccess([&waiter, url](const NetworkResult &result) -> Outcome { .onSuccess([&waiter, url](const NetworkResult &result) {
EXPECT_EQ(result.status(), 200); EXPECT_EQ(result.status(), 200);
waiter.requestDone(); waiter.requestDone();
return Success;
}) })
.onError([&waiter, url](const NetworkResult & /*result*/) { .onError([&waiter, url](const NetworkResult & /*result*/) {
// The timeout should *not* throw an error // The timeout should *not* throw an error
@ -263,9 +256,8 @@ TEST(NetworkRequest, FinallyCallbackOnTimeout)
NetworkRequest(url) NetworkRequest(url)
.timeout(1000) .timeout(1000)
.onSuccess([&](const NetworkResult & /*result*/) -> Outcome { .onSuccess([&](const NetworkResult & /*result*/) {
onSuccessCalled = true; onSuccessCalled = true;
return Success;
}) })
.onError([&](const NetworkResult &result) { .onError([&](const NetworkResult &result) {
onErrorCalled = true; onErrorCalled = true;