mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-22 19:08:58 +03:00
Fix edited replies
This commit is contained in:
parent
d6504812c7
commit
faeaf9dc6b
3 changed files with 38 additions and 4 deletions
|
@ -264,6 +264,20 @@ struct EventRelations
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct SetEventRelations
|
||||||
|
{
|
||||||
|
mtx::common::Relations new_relations;
|
||||||
|
template<class Content>
|
||||||
|
using related_ev_id_t = decltype(Content::relations);
|
||||||
|
template<class T>
|
||||||
|
void operator()(mtx::events::Event<T> &e)
|
||||||
|
{
|
||||||
|
if constexpr (is_detected<related_ev_id_t, T>::value) {
|
||||||
|
e.content.relations = std::move(new_relations);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
struct EventTransactionId
|
struct EventTransactionId
|
||||||
{
|
{
|
||||||
template<class T>
|
template<class T>
|
||||||
|
@ -426,6 +440,13 @@ mtx::accessors::relations(const mtx::events::collections::TimelineEvents &event)
|
||||||
return std::visit(EventRelations{}, event);
|
return std::visit(EventRelations{}, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
mtx::accessors::set_relations(mtx::events::collections::TimelineEvents &event,
|
||||||
|
mtx::common::Relations relations)
|
||||||
|
{
|
||||||
|
std::visit(SetEventRelations{std::move(relations)}, event);
|
||||||
|
}
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
mtx::accessors::transaction_id(const mtx::events::collections::TimelineEvents &event)
|
mtx::accessors::transaction_id(const mtx::events::collections::TimelineEvents &event)
|
||||||
{
|
{
|
||||||
|
|
|
@ -55,6 +55,8 @@ std::string
|
||||||
mimetype(const mtx::events::collections::TimelineEvents &event);
|
mimetype(const mtx::events::collections::TimelineEvents &event);
|
||||||
mtx::common::Relations
|
mtx::common::Relations
|
||||||
relations(const mtx::events::collections::TimelineEvents &event);
|
relations(const mtx::events::collections::TimelineEvents &event);
|
||||||
|
void
|
||||||
|
set_relations(mtx::events::collections::TimelineEvents &event, mtx::common::Relations relations);
|
||||||
std::string
|
std::string
|
||||||
transaction_id(const mtx::events::collections::TimelineEvents &event);
|
transaction_id(const mtx::events::collections::TimelineEvents &event);
|
||||||
|
|
||||||
|
|
|
@ -415,6 +415,7 @@ EventStore::edits(const std::string &event_id)
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
auto original_sender = mtx::accessors::sender(*original_event);
|
auto original_sender = mtx::accessors::sender(*original_event);
|
||||||
|
auto original_relations = mtx::accessors::relations(*original_event);
|
||||||
|
|
||||||
std::vector<mtx::events::collections::TimelineEvents> edits;
|
std::vector<mtx::events::collections::TimelineEvents> edits;
|
||||||
for (const auto &id : event_ids) {
|
for (const auto &id : event_ids) {
|
||||||
|
@ -422,10 +423,20 @@ EventStore::edits(const std::string &event_id)
|
||||||
if (!related_event)
|
if (!related_event)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
auto edit_rel = mtx::accessors::relations(*related_event);
|
auto related_ev = *related_event;
|
||||||
|
|
||||||
|
auto edit_rel = mtx::accessors::relations(related_ev);
|
||||||
if (edit_rel.replaces() == event_id &&
|
if (edit_rel.replaces() == event_id &&
|
||||||
original_sender == mtx::accessors::sender(*related_event))
|
original_sender == mtx::accessors::sender(related_ev)) {
|
||||||
edits.push_back(*related_event);
|
if (edit_rel.synthesized && original_relations.reply_to() &&
|
||||||
|
!edit_rel.reply_to()) {
|
||||||
|
edit_rel.relations.push_back(
|
||||||
|
{mtx::common::RelationType::InReplyTo,
|
||||||
|
original_relations.reply_to().value()});
|
||||||
|
mtx::accessors::set_relations(related_ev, std::move(edit_rel));
|
||||||
|
}
|
||||||
|
edits.push_back(std::move(related_ev));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
auto c = cache::client();
|
auto c = cache::client();
|
||||||
|
|
Loading…
Reference in a new issue