Skip to content

Commit

Permalink
Implement MSC3664, pushrules for related events
Browse files Browse the repository at this point in the history
  • Loading branch information
deepbluev7 committed Dec 5, 2022
1 parent ea5984a commit 59703d3
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 4 deletions.
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -595,7 +595,7 @@ if(USE_BUNDLED_MTXCLIENT)
FetchContent_Declare(
MatrixClient
GIT_REPOSITORY https://github.com/Nheko-Reborn/mtxclient.git
GIT_TAG c7a13e79289ae35c4e2a9bccb3fdeb2bc03a925d
GIT_TAG 7155cbb8ed3289f2cc7269da7607b0dd012f471b
)
set(BUILD_LIB_EXAMPLES OFF CACHE INTERNAL "")
set(BUILD_LIB_TESTS OFF CACHE INTERNAL "")
Expand Down
2 changes: 1 addition & 1 deletion io.github.NhekoReborn.Nheko.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,7 @@ modules:
buildsystem: cmake-ninja
name: mtxclient
sources:
- commit: c7a13e79289ae35c4e2a9bccb3fdeb2bc03a925d
- commit: 7155cbb8ed3289f2cc7269da7607b0dd012f471b
#tag: v0.8.2
type: git
url: https://github.com/Nheko-Reborn/mtxclient.git
Expand Down
24 changes: 23 additions & 1 deletion src/ChatPage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,10 @@ ChatPage::ChatPage(QSharedPointer<UserSettings> userSettings, QObject *parent)
cache::getEventIndex(room_id, cache::client()->getFullyReadEventId(room_id));

auto ctx = roomModel->pushrulesRoomContext();
std::vector<
std::pair<mtx::common::Relation, mtx::events::collections::TimelineEvent>>
relatedEvents;

for (const auto &event : room.timeline.events) {
mtx::events::collections::TimelineEvent te{event};
std::visit([room_id = room_id](auto &event_) { event_.room_id = room_id; },
Expand All @@ -277,7 +281,25 @@ ChatPage::ChatPage(QSharedPointer<UserSettings> userSettings, QObject *parent)
te.data = result.event.value();
}

auto actions = pushrules->evaluate(te, ctx);
relatedEvents.clear();
for (const auto &r : mtx::accessors::relations(te.data).relations) {
auto related = cache::client()->getEvent(room_id, r.event_id);
if (related) {
relatedEvents.emplace_back(r, *related);
if (auto encryptedEvent = std::get_if<
mtx::events::EncryptedEvent<mtx::events::msg::Encrypted>>(
&related->data);
encryptedEvent && userSettings_->decryptNotifications()) {
MegolmSessionIndex index(room_id, encryptedEvent->content);

auto result = olm::decryptEvent(index, *encryptedEvent);
if (result.event)
relatedEvents.back().second.data = result.event.value();
}
}
}

auto actions = pushrules->evaluate(te, ctx, relatedEvents);
if (std::find(actions.begin(),
actions.end(),
mtx::pushrules::actions::Action{
Expand Down
13 changes: 12 additions & 1 deletion src/timeline/TimelineModel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -742,7 +742,18 @@ TimelineModel::data(const mtx::events::collections::TimelineEvents &event, int r
case Notificationlevel: {
const auto &push = ChatPage::instance()->pushruleEvaluator();
if (push) {
auto actions = push->evaluate({event}, pushrulesRoomContext());
const auto &id = event_id(event);
std::vector<std::pair<mtx::common::Relation, mtx::events::collections::TimelineEvent>>
relatedEvents;
for (const auto &r : mtx::accessors::relations(event).relations) {
auto related = events.get(r.event_id, id);
if (related) {
relatedEvents.emplace_back(r,
mtx::events::collections::TimelineEvent{*related});
}
}

auto actions = push->evaluate({event}, pushrulesRoomContext(), relatedEvents);
if (std::find(actions.begin(),
actions.end(),
mtx::pushrules::actions::Action{
Expand Down

0 comments on commit 59703d3

Please sign in to comment.