2020-10-04 18:32:52 +02:00
|
|
|
#include "IvrApi.hpp"
|
|
|
|
|
|
|
|
#include "common/Outcome.hpp"
|
2020-11-21 16:20:10 +01:00
|
|
|
#include "common/QLogging.hpp"
|
2020-10-04 18:32:52 +02:00
|
|
|
|
|
|
|
#include <QUrlQuery>
|
|
|
|
|
|
|
|
namespace chatterino {
|
|
|
|
|
|
|
|
static IvrApi *instance = nullptr;
|
|
|
|
|
|
|
|
void IvrApi::getSubage(QString userName, QString channelName,
|
|
|
|
ResultCallback<IvrSubage> successCallback,
|
|
|
|
IvrFailureCallback failureCallback)
|
|
|
|
{
|
|
|
|
assert(!userName.isEmpty() && !channelName.isEmpty());
|
|
|
|
|
|
|
|
this->makeRequest("twitch/subage/" + userName + "/" + channelName, {})
|
|
|
|
.onSuccess([successCallback, failureCallback](auto result) -> Outcome {
|
|
|
|
auto root = result.parseJson();
|
|
|
|
|
|
|
|
successCallback(root);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([failureCallback](NetworkResult result) {
|
2020-11-21 16:20:10 +01:00
|
|
|
qCWarning(chatterinoIvr)
|
|
|
|
<< "Failed IVR API Call!" << result.status()
|
|
|
|
<< QString(result.getData());
|
2020-10-04 18:32:52 +02:00
|
|
|
failureCallback();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
NetworkRequest IvrApi::makeRequest(QString url, QUrlQuery urlQuery)
|
|
|
|
{
|
|
|
|
assert(!url.startsWith("/"));
|
|
|
|
|
|
|
|
const QString baseUrl("https://api.ivr.fi/");
|
|
|
|
QUrl fullUrl(baseUrl + url);
|
|
|
|
fullUrl.setQuery(urlQuery);
|
|
|
|
|
|
|
|
return NetworkRequest(fullUrl).timeout(5 * 1000).header("Accept",
|
|
|
|
"application/json");
|
|
|
|
}
|
|
|
|
|
|
|
|
void IvrApi::initialize()
|
|
|
|
{
|
|
|
|
assert(instance == nullptr);
|
|
|
|
|
|
|
|
instance = new IvrApi();
|
|
|
|
}
|
|
|
|
|
|
|
|
IvrApi *getIvr()
|
|
|
|
{
|
|
|
|
assert(instance != nullptr);
|
|
|
|
|
|
|
|
return instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace chatterino
|