From 01ebbc3980f10aa41f53da1dbd4d1408c4eb5ac6 Mon Sep 17 00:00:00 2001 From: Torrie Fischer Date: Tue, 18 Jul 2023 09:13:22 +0200 Subject: [PATCH] connection: emit networkError in all cases --- Quotient/connection.cpp | 15 ++++++--------- Quotient/connection.h | 4 ++-- Quotient/csapi/.whoami.cpp.swp | Bin 0 -> 12288 bytes Quotient/csapi/whoami.cpp | 1 + 4 files changed, 9 insertions(+), 11 deletions(-) create mode 100644 Quotient/csapi/.whoami.cpp.swp diff --git a/Quotient/connection.cpp b/Quotient/connection.cpp index fbb494206..422d59b5c 100644 --- a/Quotient/connection.cpp +++ b/Quotient/connection.cpp @@ -211,10 +211,7 @@ void Connection::assumeIdentity(const QString& mxId, const QString& accessToken) d->completeSetup(job->userId()); }); connect(job, &BaseJob::failure, this, [this, job] { - if (job->error() == BaseJob::StatusCode::NetworkError) - emit networkError(job->errorString(), job->rawDataSample(), - job->maxRetries(), -1); - else + if (job->error() != BaseJob::StatusCode::NetworkError) emit loginError(job->errorString(), job->rawDataSample()); }); }); @@ -448,11 +445,6 @@ void Connection::sync(int timeout) d->syncJob = nullptr; emit syncDone(); }); - connect(job, &SyncJob::retryScheduled, this, - [this, job](int retriesTaken, int nextInMilliseconds) { - emit networkError(job->errorString(), job->rawDataSample(), - retriesTaken, nextInMilliseconds); - }); connect(job, &SyncJob::failure, this, [this, job] { // SyncJob persists with retries on transient errors; if it fails, // there's likely something serious enough to stop the loop. @@ -1624,6 +1616,11 @@ BaseJob* Connection::run(BaseJob* job, RunningPolicy runningPolicy) // Reparent to protect from #397, #398 and to prevent BaseJob* from being // garbage-collected if made by or returned to QML/JavaScript. job->setParent(this); + connect(job, &BaseJob::retryScheduled, this, + [this, job](int retriesTaken, int nextInMilliseconds) { + emit networkError(job->errorString(), job->rawDataSample(), + retriesTaken, nextInMilliseconds); + }); connect(job, &BaseJob::failure, this, &Connection::requestFailed); job->initiate(d->data.get(), runningPolicy & BackgroundRequest); return job; diff --git a/Quotient/connection.h b/Quotient/connection.h index 025919574..18c6eca5a 100644 --- a/Quotient/connection.h +++ b/Quotient/connection.h @@ -766,12 +766,12 @@ public Q_SLOTS: void stateChanged(); void loginError(QString message, QString details); - //! \brief A network request (job) started by callApi() has failed + //! \brief A network request (job) started by run() (including callApi()) has failed //! \param request the pointer to the failed job //! \sa callApi void requestFailed(Quotient::BaseJob* request); - //! \brief A network request (job) failed due to network problems + //! \brief A network request (job) started by run() (including callAPI()) failed due to network problems //! //! This is _only_ emitted when the job will retry on its own; //! once it gives up, requestFailed() will be emitted. diff --git a/Quotient/csapi/.whoami.cpp.swp b/Quotient/csapi/.whoami.cpp.swp new file mode 100644 index 0000000000000000000000000000000000000000..4799cad9ebbd5c8f493d30687014977d3c6d58ee GIT binary patch literal 12288 zcmeI&&1w@-6bJBAT}o9Hm%?@GVkV@SYF+45gqDtNH2q4`7C|jHGpEfp^VOL^s|5U z)^+&u=`3h}M`d0I)8g4NEmP5M9>`SbgIXwqAogk<>2)z}$2zM;sE2c39xiCFrtvfM zbY^#bv;);%%VVuD()QsCFO!L~_dBr+Rn1G1WA^7qEWiRM2;_Qa^7c4P-@H+N)hCQ= z;_{`96DILv7GMDuU;!3j0Ty5Z7GQz@NkAuK@QN;UW_YP9!+z{YKYYs_3$OqSumB6N z01L1H3$OqSumB6Nz$p}vK0sw0;4P*2|9|xR|KkOK9wnvhQJzp9Q|2hMlyS;A%D3|X z?@(j~$8#b)KD z!?=fLn>O7@1FI_j{M-YY6m_0Pqth2`U2NiBj+v%~P4ZczUi^N>UF@RBVc9E!Nk?{d&U{)GxTpZgaNf&WlMgyZlJF e^Yzxc*s3=gV$KySn{IQfS#P!6Ww0xMwZTshp7@#o literal 0 HcmV?d00001 diff --git a/Quotient/csapi/whoami.cpp b/Quotient/csapi/whoami.cpp index af0c5d313..6028f954f 100644 --- a/Quotient/csapi/whoami.cpp +++ b/Quotient/csapi/whoami.cpp @@ -17,4 +17,5 @@ GetTokenOwnerJob::GetTokenOwnerJob() makePath("/_matrix/client/v3", "/account/whoami")) { addExpectedKey("user_id"); + setMaxRetries(std::numeric_limits::max()); }