Skip to content

Commit

Permalink
support edits
Browse files Browse the repository at this point in the history
  • Loading branch information
Sorunome committed Oct 24, 2019
1 parent 0bafc01 commit 0589172
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 47 deletions.
53 changes: 23 additions & 30 deletions source/event.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,35 @@ Event::Event(json_t* event) {
// okay, we have the base event constructed, time to do the type specifics
switch (type) {
case EventType::m_room_message: {
const char* msgtype = json_object_get_string_value(content, "msgtype");
const char* body = json_object_get_string_value(content, "body");
char* msgtype = json_object_get_string_value(content, "msgtype");
char* body = json_object_get_string_value(content, "body");
if (!msgtype || !body) {
// invalid message
type = EventType::invalid;
return;
}
message = new EventRoomMessage;
// now check if we are actually an edit event
json_t* relatesTo = json_object_get(content, "m.relates_to");
if (relatesTo) {
const char* relType = json_object_get_string_value(relatesTo, "rel_type");
const char* relEventId = json_object_get_string_value(relatesTo, "event_id");
if (relType && relEventId && strcmp(relType, "m.replace") == 0) {
// we have an edit
json_t* newContent = json_object_get(content, "m.new_content");
if (newContent) {
char* newMsgtype = json_object_get_string_value(newContent, "msgtype");
char* newBody = json_object_get_string_value(newContent, "body");
if (newMsgtype && newBody) {
// finally, the edit is valid
msgtype = newMsgtype;
body = newBody;
message->editEventId = relEventId;
}
}
}
}

if (strcmp(msgtype, "m.text") == 0) {
message->msgtype = EventMsgType::m_text;
} else if (strcmp(msgtype, "m.notice") == 0) {
Expand Down Expand Up @@ -248,31 +269,3 @@ void Event::print() {
bool Event::isValid() {
return type != EventType::invalid;
}

EventType Event::getType() {
return type;
}

std::string Event::getRoomName() {
return roomName->name;
}

std::string Event::getRoomTopic() {
return roomTopic->topic;
}

std::string Event::getRoomAvatarUrl() {
return roomAvatar->avatarUrl;
}

std::string Event::getMemberMxid() {
return member->stateKey;
}

Matrix::MemberInfo Event::getMemberInfo() {
return member->info;
}

u32 Event::getOriginServerTs() {
return originServerTs;
}
17 changes: 6 additions & 11 deletions source/event.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ enum struct EventMsgType : u8 {
struct EventRoomMessage {
EventMsgType msgtype;
std::string body;
std::string editEventId;
};

enum struct EventMemberMembership : u8 {
Expand Down Expand Up @@ -60,12 +61,15 @@ struct EventRoomAvatar {

class Event {
private:
Room* room = NULL;

std::string getDisplayName(std::string id);
public:
EventType type;
std::string sender;
std::string eventId;
u32 originServerTs;
Room* room = NULL;


union {
EventRoomMessage* message;
EventRoomMember* member;
Expand All @@ -74,20 +78,11 @@ class Event {
EventRoomAvatar* roomAvatar;
};

std::string getDisplayName(std::string id);
public:
Event(json_t* event);
~Event();
void setRoom(Room* r);
void print();
bool isValid();
EventType getType();
std::string getRoomName();
std::string getRoomTopic();
std::string getRoomAvatarUrl();
std::string getMemberMxid();
Matrix::MemberInfo getMemberInfo();
u32 getOriginServerTs();
};

#endif // _EVENT_H_
30 changes: 24 additions & 6 deletions source/room.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,11 @@ std::string Room::getMemberDisplayName(std::string mxid) {
std::string displayname = mxid;
if (members.count(mxid) == 0) {
request->getMemberInfo(mxid, roomId);
// insert a fake member to prevent re-queueing
members[mxid] = {
displayname: "",
avatarUrl: "",
};
}
if (members[mxid].displayname != "") {
displayname = members[mxid].displayname;
Expand Down Expand Up @@ -75,6 +80,20 @@ std::string Room::getDisplayName() {
}

void Room::addEvent(Event* evt) {
EventType type = evt->type;
// let's check if this is an edit first
if (type == EventType::m_room_message && evt->message->editEventId != "") {
// we are an edit event
for (auto const& e: events) {
if (e->eventId == evt->message->editEventId && e->type == EventType::m_room_message) {
e->message->body = evt->message->body;
e->message->msgtype = evt->message->msgtype;
dirty = true;
delete evt;
return;
}
}
}
// very first we claim the event as ours
evt->setRoom(this);
// first add the message to the internal cache
Expand All @@ -85,29 +104,28 @@ void Room::addEvent(Event* evt) {
events.erase(events.begin());
}

EventType type = evt->getType();
// update the lastMsg if it is a text message
if (type == EventType::m_room_message) {
lastMsg = evt->getOriginServerTs();
lastMsg = evt->originServerTs;
dirtyOrder = true;
}

// update room members accordingly
if (type == EventType::m_room_member) {
addMember(evt->getMemberMxid(), evt->getMemberInfo());
addMember(evt->member->stateKey, evt->member->info);
}

// check if we have room specific changes
if (type == EventType::m_room_name) {
name = evt->getRoomName();
name = evt->roomName->name;
dirtyInfo = true;
}
if (type == EventType::m_room_topic) {
topic = evt->getRoomTopic();
topic = evt->roomTopic->topic;
dirtyInfo = true;
}
if (type == EventType::m_room_avatar) {
avatarUrl = evt->getRoomAvatarUrl();
avatarUrl = evt->roomAvatar->avatarUrl;
dirtyInfo = true;
}

Expand Down

0 comments on commit 0589172

Please sign in to comment.