Skip to content
Snippets Groups Projects
Verified Commit cc3d32c6 authored by Nicolas Werner's avatar Nicolas Werner
Browse files

Move check for duplicate /sync responses to the same thread

parent 0dc40e50
No related branches found
No related tags found
No related merge requests found
Pipeline #897 passed
......@@ -805,8 +805,17 @@ ChatPage::startInitialSync()
}
void
ChatPage::handleSyncResponse(const mtx::responses::Sync &res)
ChatPage::handleSyncResponse(const mtx::responses::Sync &res, const std::string &prev_batch_token)
{
try {
if (prev_batch_token != cache::nextBatchToken()) {
nhlog::net()->warn("Duplicate sync, dropping");
return;
}
} catch (const lmdb::error &e) {
nhlog::db()->warn("Logged out in the mean time, dropping sync");
}
nhlog::net()->debug("sync completed: {}", res.next_batch);
// Ensure that we have enough one-time keys available.
......@@ -861,15 +870,6 @@ ChatPage::trySync()
http::client()->sync(
opts,
[this, since = opts.since](const mtx::responses::Sync &res, mtx::http::RequestErr err) {
try {
if (since != cache::nextBatchToken()) {
nhlog::net()->warn("Duplicate sync, dropping");
return;
}
} catch (const lmdb::error &e) {
nhlog::db()->warn("Logged out in the mean time, dropping sync");
}
if (err) {
const auto error = QString::fromStdString(err->matrix_error.error);
const auto msg = tr("Please try to login again: %1").arg(error);
......@@ -895,7 +895,7 @@ ChatPage::trySync()
return;
}
emit newSyncResponse(res);
emit newSyncResponse(res, since);
});
}
......@@ -1448,4 +1448,4 @@ void
ChatPage::highlightRoom(const QString &room_id)
{
room_list_->highlightSelectedRoom(room_id);
}
\ No newline at end of file
}
......@@ -141,7 +141,7 @@ signals:
void trySyncCb();
void tryDelayedSyncCb();
void tryInitialSyncCb();
void newSyncResponse(const mtx::responses::Sync &res);
void newSyncResponse(const mtx::responses::Sync &res, const std::string &prev_batch_token);
void leftRoom(const QString &room_id);
void newRoom(const QString &room_id);
......@@ -194,7 +194,8 @@ private slots:
void changeRoom(const QString &room_id);
void dropToLoginPage(const QString &msg);
void handleSyncResponse(const mtx::responses::Sync &res);
void handleSyncResponse(const mtx::responses::Sync &res,
const std::string &prev_batch_token);
private:
static ChatPage *instance_;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment