summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorNicolas Werner <nicolas.werner@ymail.com>2022-04-08 03:24:10 +0200
committerNicolas Werner <nicolas.werner@ymail.com>2022-04-08 03:24:10 +0200
commitf316dbed439c2dea2c570d6cab1f694f6df6df6f (patch)
tree2fd2e4123dffaa7946033cc46e352aca505e6d1a /src
parentRemove sender key from megolm session index (diff)
downloadnheko-f316dbed439c2dea2c570d6cab1f694f6df6df6f.tar.xz
Fix a few issues with receiving to_device messages in initial sync
Diffstat (limited to 'src')
-rw-r--r--src/Cache.cpp20
-rw-r--r--src/Cache_p.h1
-rw-r--r--src/ChatPage.cpp31
3 files changed, 31 insertions, 21 deletions
diff --git a/src/Cache.cpp b/src/Cache.cpp

index 6493d047..ff8c7651 100644 --- a/src/Cache.cpp +++ b/src/Cache.cpp
@@ -1574,7 +1574,7 @@ Cache::saveState(const mtx::responses::Sync &res) using namespace mtx::events; auto local_user_id = this->localUserId_.toStdString(); - auto currentBatchToken = nextBatchToken(); + auto currentBatchToken = res.next_batch; auto txn = lmdb::txn::begin(env_); @@ -3942,8 +3942,15 @@ Cache::roomVerificationStatus(const std::string &room_id) trust = crypto::TOFU; } - if (!keysToRequest.empty()) - markUserKeysOutOfDate(txn, keysDb, keysToRequest, ""); + if (!keysToRequest.empty()) { + std::string_view token; + + bool result = syncStateDb_.get(txn, NEXT_BATCH_KEY, token); + + if (!result) + token = ""; + markUserKeysOutOfDate(txn, keysDb, keysToRequest, std::string(token)); + } } catch (std::exception &e) { nhlog::db()->error("Failed to calculate verification status for {}: {}", room_id, e.what()); @@ -4123,11 +4130,11 @@ Cache::userKeys_(const std::string &user_id, lmdb::txn &txn) if (res) { return json::parse(keys).get<UserKeyCache>(); } else { - return {}; + return std::nullopt; } } catch (std::exception &e) { nhlog::db()->error("Failed to retrieve user keys for {}: {}", user_id, e.what()); - return {}; + return std::nullopt; } } @@ -4365,7 +4372,7 @@ Cache::query_keys(const std::string &user_id, QObject *context{new QObject(this)}; QObject::connect( this, - &Cache::verificationStatusChanged, + &Cache::userKeysUpdateFinalize, context, [cb, user_id, context_ = context, this](std::string updated_user) mutable { if (user_id == updated_user) { @@ -4390,6 +4397,7 @@ Cache::query_keys(const std::string &user_id, } emit userKeysUpdate(last_changed, res); + emit userKeysUpdateFinalize(user_id); }); } diff --git a/src/Cache_p.h b/src/Cache_p.h
index 472c8e4c..67755575 100644 --- a/src/Cache_p.h +++ b/src/Cache_p.h
@@ -317,6 +317,7 @@ signals: void roomReadStatus(const std::map<QString, bool> &status); void removeNotification(const QString &room_id, const QString &event_id); void userKeysUpdate(const std::string &sync_token, const mtx::responses::QueryKeys &keyQuery); + void userKeysUpdateFinalize(const std::string &user_id); void verificationStatusChanged(const std::string &userid); void selfVerificationStatusChanged(); void secretChanged(const std::string name); diff --git a/src/ChatPage.cpp b/src/ChatPage.cpp
index 43455e86..0550c7f3 100644 --- a/src/ChatPage.cpp +++ b/src/ChatPage.cpp
@@ -560,25 +560,26 @@ ChatPage::startInitialSync() } } - nhlog::net()->info("initial sync completed"); - - try { - cache::client()->saveState(res); + QTimer::singleShot(0, this, [this, res] { + nhlog::net()->info("initial sync completed"); + try { + cache::client()->saveState(res); - olm::handle_to_device_messages(res.to_device.events); + olm::handle_to_device_messages(res.to_device.events); - emit initializeViews(std::move(res)); - emit initializeMentions(cache::getTimelineMentions()); + emit initializeViews(std::move(res)); + emit initializeMentions(cache::getTimelineMentions()); - cache::calculateRoomReadStatus(); - } catch (const lmdb::error &e) { - nhlog::db()->error("failed to save state after initial sync: {}", e.what()); - startInitialSync(); - return; - } + cache::calculateRoomReadStatus(); + } catch (const lmdb::error &e) { + nhlog::db()->error("failed to save state after initial sync: {}", e.what()); + startInitialSync(); + return; + } - emit trySyncCb(); - emit contentLoaded(); + emit trySyncCb(); + emit contentLoaded(); + }); }); }