Retry initial sync only on specific errors
fixes #233
fixes #89
2 files changed, 17 insertions, 6 deletions
diff --git a/src/ChatPage.cc b/src/ChatPage.cc
index 93ae562e..571ac67a 100644
--- a/src/ChatPage.cc
+++ b/src/ChatPage.cc
@@ -361,7 +361,7 @@ ChatPage::ChatPage(QSharedPointer<MatrixClient> client,
});
initialSyncTimer_ = new QTimer(this);
- connect(initialSyncTimer_, &QTimer::timeout, this, &ChatPage::retryInitialSync);
+ connect(initialSyncTimer_, &QTimer::timeout, this, [this]() { retryInitialSync(); });
syncTimeoutTimer_ = new QTimer(this);
connect(syncTimeoutTimer_, &QTimer::timeout, this, [this]() {
@@ -965,19 +965,30 @@ ChatPage::setGroupViewState(bool isEnabled)
}
void
-ChatPage::retryInitialSync()
+ChatPage::retryInitialSync(int status_code)
{
initialSyncTimer_->stop();
if (client_->getHomeServer().isEmpty()) {
deleteConfigs();
+ resetUI();
+ emit showLoginPage("Sync error. Please try again.");
return;
}
- qWarning() << "Retrying initial sync";
+ // Retry on Bad-Gateway & Gateway-Timeout errors
+ if (status_code == -1 || status_code == 504 || status_code == 502 || status_code == 524) {
+ qWarning() << "retrying initial sync";
- client_->initialSync();
- initialSyncTimer_->start(INITIAL_SYNC_RETRY_TIMEOUT);
+ client_->initialSync();
+ initialSyncTimer_->start(INITIAL_SYNC_RETRY_TIMEOUT);
+ } else {
+ // Drop into the login screen.
+ deleteConfigs();
+ resetUI();
+
+ emit showLoginPage(QString("Sync error %1. Please try again.").arg(status_code));
+ }
}
void
diff --git a/src/MatrixClient.cc b/src/MatrixClient.cc
index 544f58cb..5471e410 100644
--- a/src/MatrixClient.cc
+++ b/src/MatrixClient.cc
@@ -401,7 +401,7 @@ MatrixClient::initialSync() noexcept
if (status == 0 || status >= 400) {
qDebug() << "Error code received" << status;
- emit initialSyncFailed();
+ emit initialSyncFailed(status);
return;
}
|