Implement /ignore and /unignore commands

Simplify authorized network requests for Twitch V5 api
add onShow virtual function to settings pages if they need to be refreshed when shown
Actually ignoring messages from ignored users is still not implemented

Working on #247
This commit is contained in:
Rasmus Karlsson 2018-05-12 20:34:13 +02:00 committed by fourtf
parent 5b26cdaa07
commit 937fffc34b
2 changed files with 49 additions and 1 deletions

View file

@ -55,7 +55,6 @@ public:
bool isAnon() const; bool isAnon() const;
void loadIgnores(); void loadIgnores();
void ignore(const QString &targetName, void ignore(const QString &targetName,
std::function<void(IgnoreResult, const QString &)> onFinished); std::function<void(IgnoreResult, const QString &)> onFinished);
void ignoreByID(const QString &targetUserID, const QString &targetName, void ignoreByID(const QString &targetUserID, const QString &targetName,

View file

@ -151,15 +151,26 @@ public:
} }
void setRawHeader(const char *headerName, const char *value) void setRawHeader(const char *headerName, const char *value)
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
=======
{ {
this->data.request.setRawHeader(headerName, value); this->data.request.setRawHeader(headerName, value);
} }
void setRawHeader(const char *headerName, const QByteArray &value) void setRawHeader(const char *headerName, const QByteArray &value)
>>>>>>> Implement /ignore and /unignore commands
{ {
this->data.request.setRawHeader(headerName, value); this->data.request.setRawHeader(headerName, value);
} }
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
void setRawHeader(const char *headerName, const QByteArray &value)
{
this->data.request.setRawHeader(headerName, value);
}
=======
>>>>>>> Implement /ignore and /unignore commands
void setRawHeader(const char *headerName, const QString &value) void setRawHeader(const char *headerName, const QString &value)
{ {
this->data.request.setRawHeader(headerName, value.toUtf8()); this->data.request.setRawHeader(headerName, value.toUtf8());
@ -302,16 +313,28 @@ public:
void execute() void execute()
{ {
switch (this->data.requestType) { switch (this->data.requestType) {
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
case GetRequest: { case GetRequest: {
this->executeGet(); this->executeGet();
} break; } break;
case PutRequest: { case PutRequest: {
=======
case GET: {
this->executeGet();
} break;
case PUT: {
>>>>>>> Implement /ignore and /unignore commands
debug::Log("Call PUT request!"); debug::Log("Call PUT request!");
this->executePut(); this->executePut();
} break; } break;
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
case DeleteRequest: { case DeleteRequest: {
=======
case DELETE: {
>>>>>>> Implement /ignore and /unignore commands
debug::Log("Call DELETE request!"); debug::Log("Call DELETE request!");
this->executeDelete(); this->executeDelete();
} break; } break;
@ -369,6 +392,7 @@ private:
worker->moveToThread(&NetworkManager::workerThread); worker->moveToThread(&NetworkManager::workerThread);
if (this->data.caller != nullptr) { if (this->data.caller != nullptr) {
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
QObject::connect(worker, &NetworkWorker::doneUrl, QObject::connect(worker, &NetworkWorker::doneUrl,
this->data.caller, [data = this->data](auto reply) mutable { this->data.caller, [data = this->data](auto reply) mutable {
auto &dat = data; auto &dat = data;
@ -377,6 +401,12 @@ private:
if (data.onError) { if (data.onError) {
data.onError(reply->error()); data.onError(reply->error());
} }
=======
QObject::connect(worker, &NetworkWorker::doneUrl,
this->data.caller, [data = this->data](auto reply) mutable {
if (reply->error() != QNetworkReply::NetworkError::NoError) {
// TODO: We might want to call an onError callback here
>>>>>>> Implement /ignore and /unignore commands
return; return;
} }
@ -395,6 +425,7 @@ private:
} }
QObject::connect(&requester, &NetworkRequester::requestUrl, worker, QObject::connect(&requester, &NetworkRequester::requestUrl, worker,
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
[ timer, data = std::move(this->data), worker ]() { [ timer, data = std::move(this->data), worker ]() {
QNetworkReply *reply; QNetworkReply *reply;
switch (data.requestType) { switch (data.requestType) {
@ -407,6 +438,20 @@ private:
} break; } break;
case DeleteRequest: { case DeleteRequest: {
=======
[ timer, data = std::move(this->data), worker ]() {
QNetworkReply *reply;
switch (data.requestType) {
case GET: {
reply = NetworkManager::NaM.get(data.request);
} break;
case PUT: {
reply = NetworkManager::NaM.put(data.request, data.payload);
} break;
case DELETE: {
>>>>>>> Implement /ignore and /unignore commands
reply = NetworkManager::NaM.deleteResource(data.request); reply = NetworkManager::NaM.deleteResource(data.request);
} break; } break;
} }
@ -431,7 +476,11 @@ private:
} }
QObject::connect(reply, &QNetworkReply::finished, worker, QObject::connect(reply, &QNetworkReply::finished, worker,
<<<<<<< 5b26cdaa0777562a0b3c663a203528eca56bd5df
[ data = std::move(data), worker, reply ]() mutable { [ data = std::move(data), worker, reply ]() mutable {
=======
[ data = std::move(data), worker, reply ]() mutable {
>>>>>>> Implement /ignore and /unignore commands
if (data.caller == nullptr) { if (data.caller == nullptr) {
QByteArray bytes = reply->readAll(); QByteArray bytes = reply->readAll();
data.writeToCache(bytes); data.writeToCache(bytes);