Clean up key requests + autoreload
This commit is contained in:
parent
983690c94f
commit
cea7f4574f
@ -340,7 +340,7 @@ if(USE_BUNDLED_MTXCLIENT)
|
|||||||
FetchContent_Declare(
|
FetchContent_Declare(
|
||||||
MatrixClient
|
MatrixClient
|
||||||
GIT_REPOSITORY https://github.com/Nheko-Reborn/mtxclient.git
|
GIT_REPOSITORY https://github.com/Nheko-Reborn/mtxclient.git
|
||||||
GIT_TAG ad5575bc24089dc385e97d9ace026414b618775c
|
GIT_TAG da9958e14e035fbf22d498074d381b2ea0092a9d
|
||||||
)
|
)
|
||||||
FetchContent_MakeAvailable(MatrixClient)
|
FetchContent_MakeAvailable(MatrixClient)
|
||||||
else()
|
else()
|
||||||
|
@ -146,7 +146,7 @@
|
|||||||
"name": "mtxclient",
|
"name": "mtxclient",
|
||||||
"sources": [
|
"sources": [
|
||||||
{
|
{
|
||||||
"commit": "ad5575bc24089dc385e97d9ace026414b618775c",
|
"commit": "da9958e14e035fbf22d498074d381b2ea0092a9d",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/Nheko-Reborn/mtxclient.git"
|
"url": "https://github.com/Nheko-Reborn/mtxclient.git"
|
||||||
}
|
}
|
||||||
|
@ -1249,6 +1249,12 @@ ChatPage::unbanUser(QString userid, QString reason)
|
|||||||
reason.trimmed().toStdString());
|
reason.trimmed().toStdString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ChatPage::receivedSessionKey(const std::string &room_id, const std::string &session_id)
|
||||||
|
{
|
||||||
|
view_manager_->receivedSessionKey(room_id, session_id);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ChatPage::sendTypingNotifications()
|
ChatPage::sendTypingNotifications()
|
||||||
{
|
{
|
||||||
|
@ -107,6 +107,8 @@ public slots:
|
|||||||
void banUser(QString userid, QString reason);
|
void banUser(QString userid, QString reason);
|
||||||
void unbanUser(QString userid, QString reason);
|
void unbanUser(QString userid, QString reason);
|
||||||
|
|
||||||
|
void receivedSessionKey(const std::string &room_id, const std::string &session_id);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void connectionLost();
|
void connectionLost();
|
||||||
void connectionRestored();
|
void connectionRestored();
|
||||||
|
47
src/Olm.cpp
47
src/Olm.cpp
@ -388,9 +388,10 @@ import_inbound_megolm_session(
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(Nico): Reload messages encrypted with this key.
|
|
||||||
nhlog::crypto()->info(
|
nhlog::crypto()->info(
|
||||||
"established inbound megolm session ({}, {})", roomKey.content.room_id, roomKey.sender);
|
"established inbound megolm session ({}, {})", roomKey.content.room_id, roomKey.sender);
|
||||||
|
|
||||||
|
ChatPage::instance()->receivedSessionKey(index.room_id, index.session_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -401,48 +402,24 @@ mark_keys_as_published()
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
request_keys(const std::string &room_id, const std::string &event_id)
|
send_key_request_for(mtx::events::EncryptedEvent<mtx::events::msg::Encrypted> e,
|
||||||
{
|
const std::string &request_id,
|
||||||
nhlog::crypto()->info("requesting keys for event {} at {}", event_id, room_id);
|
bool cancel)
|
||||||
|
|
||||||
http::client()->get_event(
|
|
||||||
room_id,
|
|
||||||
event_id,
|
|
||||||
[event_id, room_id](const mtx::events::collections::TimelineEvents &res,
|
|
||||||
mtx::http::RequestErr err) {
|
|
||||||
using namespace mtx::events;
|
|
||||||
|
|
||||||
if (err) {
|
|
||||||
nhlog::net()->warn(
|
|
||||||
"failed to retrieve event {} from {}", event_id, room_id);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!std::holds_alternative<EncryptedEvent<msg::Encrypted>>(res)) {
|
|
||||||
nhlog::net()->info(
|
|
||||||
"retrieved event is not encrypted: {} from {}", event_id, room_id);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
olm::send_key_request_for(room_id, std::get<EncryptedEvent<msg::Encrypted>>(res));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
send_key_request_for(const std::string &room_id,
|
|
||||||
const mtx::events::EncryptedEvent<mtx::events::msg::Encrypted> &e)
|
|
||||||
{
|
{
|
||||||
using namespace mtx::events;
|
using namespace mtx::events;
|
||||||
|
|
||||||
nhlog::crypto()->debug("sending key request: {}", json(e).dump(2));
|
nhlog::crypto()->debug("sending key request: sender_key {}, session_id {}",
|
||||||
|
e.content.sender_key,
|
||||||
|
e.content.session_id);
|
||||||
|
|
||||||
mtx::events::msg::KeyRequest request;
|
mtx::events::msg::KeyRequest request;
|
||||||
request.action = mtx::events::msg::RequestAction::Request;
|
request.action = !cancel ? mtx::events::msg::RequestAction::Request
|
||||||
|
: mtx::events::msg::RequestAction::Cancellation;
|
||||||
request.algorithm = MEGOLM_ALGO;
|
request.algorithm = MEGOLM_ALGO;
|
||||||
request.room_id = room_id;
|
request.room_id = e.room_id;
|
||||||
request.sender_key = e.content.sender_key;
|
request.sender_key = e.content.sender_key;
|
||||||
request.session_id = e.content.session_id;
|
request.session_id = e.content.session_id;
|
||||||
request.request_id = "key_request." + http::client()->generate_txn_id();
|
request.request_id = request_id;
|
||||||
request.requesting_device_id = http::client()->device_id();
|
request.requesting_device_id = http::client()->device_id();
|
||||||
|
|
||||||
nhlog::crypto()->debug("m.room_key_request: {}", json(request).dump(2));
|
nhlog::crypto()->debug("m.room_key_request: {}", json(request).dump(2));
|
||||||
|
@ -96,11 +96,9 @@ mark_keys_as_published();
|
|||||||
|
|
||||||
//! Request the encryption keys from sender's device for the given event.
|
//! Request the encryption keys from sender's device for the given event.
|
||||||
void
|
void
|
||||||
request_keys(const std::string &room_id, const std::string &event_id);
|
send_key_request_for(mtx::events::EncryptedEvent<mtx::events::msg::Encrypted> e,
|
||||||
|
const std::string &request_id,
|
||||||
void
|
bool cancel = false);
|
||||||
send_key_request_for(const std::string &room_id,
|
|
||||||
const mtx::events::EncryptedEvent<mtx::events::msg::Encrypted> &);
|
|
||||||
|
|
||||||
void
|
void
|
||||||
handle_key_request_message(const mtx::events::DeviceEvent<mtx::events::msg::KeyRequest> &);
|
handle_key_request_message(const mtx::events::DeviceEvent<mtx::events::msg::KeyRequest> &);
|
||||||
|
@ -212,6 +212,28 @@ EventStore::clearTimeline()
|
|||||||
emit endResetModel();
|
emit endResetModel();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
EventStore::receivedSessionKey(const std::string &session_id)
|
||||||
|
{
|
||||||
|
if (!pending_key_requests.count(session_id))
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto request = pending_key_requests.at(session_id);
|
||||||
|
pending_key_requests.erase(session_id);
|
||||||
|
|
||||||
|
olm::send_key_request_for(request.events.front(), request.request_id, true);
|
||||||
|
|
||||||
|
for (const auto &e : request.events) {
|
||||||
|
auto idx = idToIndex(e.event_id);
|
||||||
|
if (idx) {
|
||||||
|
decryptedEvents_.remove({room_id_, e.event_id});
|
||||||
|
events_by_id_.remove({room_id_, e.event_id});
|
||||||
|
events_.remove({room_id_, toInternalIdx(*idx)});
|
||||||
|
emit dataChanged(*idx, *idx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
EventStore::handleSync(const mtx::responses::Timeline &events)
|
EventStore::handleSync(const mtx::responses::Timeline &events)
|
||||||
{
|
{
|
||||||
@ -294,18 +316,6 @@ EventStore::handleSync(const mtx::responses::Timeline &events)
|
|||||||
*d_event)) {
|
*d_event)) {
|
||||||
handle_room_verification(*d_event);
|
handle_room_verification(*d_event);
|
||||||
}
|
}
|
||||||
// else {
|
|
||||||
// // only the key.verification.ready sent by localuser's other
|
|
||||||
// device
|
|
||||||
// // is of significance as it is used for detecting accepted request
|
|
||||||
// if (std::get_if<mtx::events::RoomEvent<
|
|
||||||
// mtx::events::msg::KeyVerificationReady>>(d_event)) {
|
|
||||||
// auto msg = std::get_if<mtx::events::RoomEvent<
|
|
||||||
// mtx::events::msg::KeyVerificationReady>>(d_event);
|
|
||||||
// ChatPage::instance()->receivedDeviceVerificationReady(
|
|
||||||
// msg->content);
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -501,7 +511,7 @@ EventStore::decryptEvent(const IdIndex &idx,
|
|||||||
|
|
||||||
if (decryptionResult.error) {
|
if (decryptionResult.error) {
|
||||||
switch (*decryptionResult.error) {
|
switch (*decryptionResult.error) {
|
||||||
case olm::DecryptionErrorCode::MissingSession:
|
case olm::DecryptionErrorCode::MissingSession: {
|
||||||
dummy.content.body =
|
dummy.content.body =
|
||||||
tr("-- Encrypted Event (No keys found for decryption) --",
|
tr("-- Encrypted Event (No keys found for decryption) --",
|
||||||
"Placeholder, when the message was not decrypted yet or can't be "
|
"Placeholder, when the message was not decrypted yet or can't be "
|
||||||
@ -512,8 +522,21 @@ EventStore::decryptEvent(const IdIndex &idx,
|
|||||||
index.session_id,
|
index.session_id,
|
||||||
e.sender);
|
e.sender);
|
||||||
// TODO: Check if this actually works and look in key backup
|
// TODO: Check if this actually works and look in key backup
|
||||||
olm::send_key_request_for(room_id_, e);
|
auto copy = e;
|
||||||
|
copy.room_id = room_id_;
|
||||||
|
if (pending_key_requests.count(e.content.session_id)) {
|
||||||
|
pending_key_requests.at(e.content.session_id)
|
||||||
|
.events.push_back(copy);
|
||||||
|
} else {
|
||||||
|
PendingKeyRequests request;
|
||||||
|
request.request_id =
|
||||||
|
"key_request." + http::client()->generate_txn_id();
|
||||||
|
request.events.push_back(copy);
|
||||||
|
olm::send_key_request_for(copy, request.request_id);
|
||||||
|
pending_key_requests[e.content.session_id] = request;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case olm::DecryptionErrorCode::DbError:
|
case olm::DecryptionErrorCode::DbError:
|
||||||
nhlog::db()->critical(
|
nhlog::db()->critical(
|
||||||
"failed to retrieve megolm session with index ({}, {}, {})",
|
"failed to retrieve megolm session with index ({}, {}, {})",
|
||||||
|
@ -104,6 +104,7 @@ signals:
|
|||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void addPending(mtx::events::collections::TimelineEvents event);
|
void addPending(mtx::events::collections::TimelineEvents event);
|
||||||
|
void receivedSessionKey(const std::string &session_id);
|
||||||
void clearTimeline();
|
void clearTimeline();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -121,6 +122,13 @@ private:
|
|||||||
static QCache<Index, mtx::events::collections::TimelineEvents> events_;
|
static QCache<Index, mtx::events::collections::TimelineEvents> events_;
|
||||||
static QCache<IdIndex, mtx::events::collections::TimelineEvents> events_by_id_;
|
static QCache<IdIndex, mtx::events::collections::TimelineEvents> events_by_id_;
|
||||||
|
|
||||||
|
struct PendingKeyRequests
|
||||||
|
{
|
||||||
|
std::string request_id;
|
||||||
|
std::vector<mtx::events::EncryptedEvent<mtx::events::msg::Encrypted>> events;
|
||||||
|
};
|
||||||
|
std::map<std::string, PendingKeyRequests> pending_key_requests;
|
||||||
|
|
||||||
std::string current_txn;
|
std::string current_txn;
|
||||||
int current_txn_error_count = 0;
|
int current_txn_error_count = 0;
|
||||||
bool noMoreMessages = false;
|
bool noMoreMessages = false;
|
||||||
|
@ -264,6 +264,10 @@ public slots:
|
|||||||
}
|
}
|
||||||
void setDecryptDescription(bool decrypt) { decryptDescription = decrypt; }
|
void setDecryptDescription(bool decrypt) { decryptDescription = decrypt; }
|
||||||
void clearTimeline() { events.clearTimeline(); }
|
void clearTimeline() { events.clearTimeline(); }
|
||||||
|
void receivedSessionKey(const std::string &session_key)
|
||||||
|
{
|
||||||
|
events.receivedSessionKey(session_key);
|
||||||
|
}
|
||||||
|
|
||||||
QString roomName() const;
|
QString roomName() const;
|
||||||
QString roomTopic() const;
|
QString roomTopic() const;
|
||||||
|
@ -440,6 +440,15 @@ TimelineViewManager::updateReadReceipts(const QString &room_id,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
TimelineViewManager::receivedSessionKey(const std::string &room_id, const std::string &session_id)
|
||||||
|
{
|
||||||
|
auto room = models.find(QString::fromStdString(room_id));
|
||||||
|
if (room != models.end()) {
|
||||||
|
room.value()->receivedSessionKey(session_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TimelineViewManager::initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs)
|
TimelineViewManager::initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs)
|
||||||
{
|
{
|
||||||
|
@ -92,6 +92,7 @@ signals:
|
|||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void updateReadReceipts(const QString &room_id, const std::vector<QString> &event_ids);
|
void updateReadReceipts(const QString &room_id, const std::vector<QString> &event_ids);
|
||||||
|
void receivedSessionKey(const std::string &room_id, const std::string &session_id);
|
||||||
void initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs);
|
void initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs);
|
||||||
|
|
||||||
void setHistoryView(const QString &room_id);
|
void setHistoryView(const QString &room_id);
|
||||||
|
Loading…
Reference in New Issue
Block a user