[Connection] Clean up receipts

This commit is contained in:
Christian Pauly 2019-10-25 08:02:56 +00:00
parent fb0750b69a
commit 88b9cdd345
4 changed files with 18 additions and 20 deletions

View file

@ -461,15 +461,13 @@ class Connection {
break; break;
} }
} }
if (userTimestampMap[mxid].containsKey("ts")) { if (userTimestampMap[mxid].containsKey("ts")) {
if (receiptStateContent[eventID] == null) receiptStateContent[mxid] = {
receiptStateContent[eventID] = {"m.read": {}}; "event_id": eventID,
else if (receiptStateContent[eventID]["m.read"] == null)
receiptStateContent[eventID]["m.read"] = {};
receiptStateContent[eventID]["m.read"][mxid] = {
"ts": userTimestampMap[mxid]["ts"], "ts": userTimestampMap[mxid]["ts"],
}; };
print(
"$mxid hat $eventID um ${userTimestampMap[mxid]["ts"]} gelesen!");
} }
} }
} }

View file

@ -101,15 +101,13 @@ class Event extends RoomState {
/// Returns a list of [Receipt] instances for this event. /// Returns a list of [Receipt] instances for this event.
List<Receipt> get receipts { List<Receipt> get receipts {
if (!(room.roomAccountData.containsKey("m.receipt") && if (!(room.roomAccountData.containsKey("m.receipt"))) return [];
room.roomAccountData["m.receipt"].content.containsKey(eventId)))
return [];
List<Receipt> receiptsList = []; List<Receipt> receiptsList = [];
for (var entry in room for (var entry in room.roomAccountData["m.receipt"].content.entries) {
.roomAccountData["m.receipt"].content[eventId]["m.read"].entries) { if (entry.value["event_id"] == eventId)
receiptsList.add(Receipt( receiptsList.add(Receipt(
room.states[entry.key]?.asUser ?? User(entry.key), room.states[entry.key]?.asUser ?? User(entry.key),
ChatTime(entry.value["ts"]))); ChatTime(entry.value["ts"])));
} }
return receiptsList; return receiptsList;
} }

View file

@ -130,9 +130,12 @@ void main() {
expect(matrix.roomList.rooms[1].roomAccountData.length, 3); expect(matrix.roomList.rooms[1].roomAccountData.length, 3);
expect( expect(
matrix.roomList.rooms[1].roomAccountData["m.receipt"] matrix.roomList.rooms[1].roomAccountData["m.receipt"]
.content["7365636s6r6432:example.com"]["m.read"] .content["@alice:example.com"]["ts"],
["@alice:example.com"]["ts"],
1436451550453); 1436451550453);
expect(
matrix.roomList.rooms[1].roomAccountData["m.receipt"]
.content["@alice:example.com"]["event_id"],
"7365636s6r6432:example.com");
expect(matrix.roomList.rooms.length, 2); expect(matrix.roomList.rooms.length, 2);
expect(matrix.roomList.rooms[1].canonicalAlias, expect(matrix.roomList.rooms[1].canonicalAlias,
"#famedlyContactDiscovery:${matrix.userID.split(":")[1]}"); "#famedlyContactDiscovery:${matrix.userID.split(":")[1]}");

View file

@ -103,10 +103,9 @@ void main() {
room.roomAccountData["m.receipt"] = RoomAccountData.fromJson({ room.roomAccountData["m.receipt"] = RoomAccountData.fromJson({
"type": "m.receipt", "type": "m.receipt",
"content": { "content": {
"1": { "@alice:example.com": {
"m.read": { "event_id": "1",
"@alice:example.com": {"ts": 1436451550453} "ts": 1436451550453,
}
} }
}, },
"room_id": roomID, "room_id": roomID,