From 789eeec77716188923528a6191127e8aececa08c Mon Sep 17 00:00:00 2001 From: sudden6 Date: Thu, 21 Jan 2016 00:29:54 +0100 Subject: [PATCH 1/2] fix toxme error handling fixes a bug in Toxme::deleteAddress returning a QNetworkReply::NetworkError adds some warning messages --- src/net/toxme.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/net/toxme.cpp b/src/net/toxme.cpp index 8fdbe4fb3..79fe81c1b 100644 --- a/src/net/toxme.cpp +++ b/src/net/toxme.cpp @@ -47,6 +47,10 @@ QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::Netw qApp->processEvents(); } + error = reply->error(); + if (error) + qWarning() << "makeJsonRequest: A network error occured:" << error.errorString(); + return reply->readAll(); } @@ -70,6 +74,10 @@ QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &erro qApp->processEvents(); } + error = reply->error(); + if (error) + qWarning() << "getServerPubkey: A network error occured:" << error.errorString(); + // Extract key static const QByteArray pattern{"key\":\""}; @@ -277,8 +285,6 @@ int Toxme::deleteAddress(QString server, ToxId id) QString apiUrl = server + "/api"; QNetworkReply::NetworkError error = QNetworkReply::NoError; QByteArray response = makeJsonRequest(apiUrl, prepareEncryptedJson(pubkeyUrl, 2, payload), error); - if (error != QNetworkReply::NoError) - return error; return extractError(response); } From 641486d5070b92557af59657d192d111646eea08 Mon Sep 17 00:00:00 2001 From: sudden6 Date: Thu, 21 Jan 2016 01:11:47 +0100 Subject: [PATCH 2/2] Simpliefy code, return early on error --- src/net/toxme.cpp | 26 ++++++++++++-------------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/src/net/toxme.cpp b/src/net/toxme.cpp index 79fe81c1b..9b384de6b 100644 --- a/src/net/toxme.cpp +++ b/src/net/toxme.cpp @@ -38,18 +38,17 @@ QByteArray Toxme::makeJsonRequest(QString url, QString json, QNetworkReply::Netw request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); QNetworkReply* reply = netman.post(request,json.toUtf8()); - while (reply->isRunning()) { - error = reply->error(); - if (error) - break; - - reply->waitForReadyRead(100); + while (!reply->isFinished()) + { qApp->processEvents(); } error = reply->error(); if (error) - qWarning() << "makeJsonRequest: A network error occured:" << error.errorString(); + { + qWarning() << "makeJsonRequest: A network error occured:" << reply->errorString(); + return QByteArray(); + } return reply->readAll(); } @@ -65,18 +64,17 @@ QByteArray Toxme::getServerPubkey(QString url, QNetworkReply::NetworkError &erro request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); QNetworkReply* reply = netman.get(request); - while (reply->isRunning()) { - error = reply->error(); - if (error) - break; - - reply->waitForReadyRead(100); + while (!reply->isFinished()) + { qApp->processEvents(); } error = reply->error(); if (error) - qWarning() << "getServerPubkey: A network error occured:" << error.errorString(); + { + qWarning() << "getServerPubkey: A network error occured:" << reply->errorString(); + return QByteArray(); + } // Extract key static const QByteArray pattern{"key\":\""};