[Sending] Refactoring
This commit is contained in:
parent
b2ae29d65d
commit
cfb757df0f
|
@ -193,7 +193,6 @@ class Room {
|
||||||
"content": {
|
"content": {
|
||||||
"msgtype": "m.text",
|
"msgtype": "m.text",
|
||||||
"body": message,
|
"body": message,
|
||||||
"txid": messageID,
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
client.connection.onEvent.add(eventUpdate);
|
client.connection.onEvent.add(eventUpdate);
|
||||||
|
@ -208,6 +207,7 @@ class Room {
|
||||||
if (res is ErrorResponse || !(res["event_id"] is String)) {
|
if (res is ErrorResponse || !(res["event_id"] is String)) {
|
||||||
// On error, set status to -1
|
// On error, set status to -1
|
||||||
eventUpdate.content["status"] = -1;
|
eventUpdate.content["status"] = -1;
|
||||||
|
eventUpdate.content["unsigned"] = {"transaction_id": messageID};
|
||||||
client.connection.onEvent.add(eventUpdate);
|
client.connection.onEvent.add(eventUpdate);
|
||||||
await client.store?.transaction(() {
|
await client.store?.transaction(() {
|
||||||
client.store.storeEventUpdate(eventUpdate);
|
client.store.storeEventUpdate(eventUpdate);
|
||||||
|
@ -215,6 +215,7 @@ class Room {
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
eventUpdate.content["status"] = 1;
|
eventUpdate.content["status"] = 1;
|
||||||
|
eventUpdate.content["unsigned"] = {"transaction_id": messageID};
|
||||||
eventUpdate.content["event_id"] = res["event_id"];
|
eventUpdate.content["event_id"] = res["event_id"];
|
||||||
client.connection.onEvent.add(eventUpdate);
|
client.connection.onEvent.add(eventUpdate);
|
||||||
await client.store?.transaction(() {
|
await client.store?.transaction(() {
|
||||||
|
@ -375,7 +376,9 @@ class Room {
|
||||||
static Future<Room> getRoomFromTableRow(
|
static Future<Room> getRoomFromTableRow(
|
||||||
Map<String, dynamic> row, Client matrix) async {
|
Map<String, dynamic> row, Client matrix) async {
|
||||||
String name = row["topic"];
|
String name = row["topic"];
|
||||||
if (name == "")
|
if (name == "" && !row["canonical_alias"].isEmpty)
|
||||||
|
name = row["canonical_alias"];
|
||||||
|
else if (name == "")
|
||||||
name = await matrix.store?.getChatNameFromMemberNames(row["id"]) ?? "";
|
name = await matrix.store?.getChatNameFromMemberNames(row["id"]) ?? "";
|
||||||
|
|
||||||
String avatarUrl = row["avatar_url"];
|
String avatarUrl = row["avatar_url"];
|
||||||
|
@ -400,6 +403,7 @@ class Room {
|
||||||
guestAccess: row["guest_access"],
|
guestAccess: row["guest_access"],
|
||||||
historyVisibility: row["history_visibility"],
|
historyVisibility: row["history_visibility"],
|
||||||
joinRules: row["join_rules"],
|
joinRules: row["join_rules"],
|
||||||
|
canonicalAlias: row["canonical_alias"],
|
||||||
powerLevels: {
|
powerLevels: {
|
||||||
"power_events_default": row["power_events_default"],
|
"power_events_default": row["power_events_default"],
|
||||||
"power_state_default": row["power_state_default"],
|
"power_state_default": row["power_state_default"],
|
||||||
|
|
|
@ -55,7 +55,7 @@ class Store {
|
||||||
_init() async {
|
_init() async {
|
||||||
var databasePath = await getDatabasesPath();
|
var databasePath = await getDatabasesPath();
|
||||||
String path = p.join(databasePath, "FluffyMatrix.db");
|
String path = p.join(databasePath, "FluffyMatrix.db");
|
||||||
_db = await openDatabase(path, version: 7,
|
_db = await openDatabase(path, version: 8,
|
||||||
onCreate: (Database db, int version) async {
|
onCreate: (Database db, int version) async {
|
||||||
await createTables(db);
|
await createTables(db);
|
||||||
}, onUpgrade: (Database db, int oldVersion, int newVersion) async {
|
}, onUpgrade: (Database db, int oldVersion, int newVersion) async {
|
||||||
|
@ -300,6 +300,12 @@ class Store {
|
||||||
txn.rawUpdate("UPDATE Rooms SET guest_access=? WHERE id=?",
|
txn.rawUpdate("UPDATE Rooms SET guest_access=? WHERE id=?",
|
||||||
[eventContent["content"]["guest_access"], chat_id]);
|
[eventContent["content"]["guest_access"], chat_id]);
|
||||||
break;
|
break;
|
||||||
|
// This event means, that the canonical alias of a room has been changed, so
|
||||||
|
// it has to be changed in the database
|
||||||
|
case "m.room.canonical_alias":
|
||||||
|
txn.rawUpdate("UPDATE Chats SET canonical_alias=? WHERE id=?",
|
||||||
|
[eventContent["content"]["alias"] ?? "", chat_id]);
|
||||||
|
break;
|
||||||
// This event means, that the topic of a room has been changed, so
|
// This event means, that the topic of a room has been changed, so
|
||||||
// it has to be changed in the database
|
// it has to be changed in the database
|
||||||
case "m.room.join_rules":
|
case "m.room.join_rules":
|
||||||
|
|
|
@ -44,14 +44,11 @@ class Timeline {
|
||||||
sub ??= room.client.connection.onEvent.stream.listen(_handleEventUpdate);
|
sub ??= room.client.connection.onEvent.stream.listen(_handleEventUpdate);
|
||||||
}
|
}
|
||||||
|
|
||||||
int _findEvent({String event_id, String txid, String unsigned_txid}) {
|
int _findEvent({String event_id, String unsigned_txid}) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < events.length; i++) {
|
for (i = 0; i < events.length; i++) {
|
||||||
if (events[i].content.containsKey("txid") &&
|
if (events[i].id == event_id ||
|
||||||
(txid != null && events[i].content["txid"] == txid) ||
|
(unsigned_txid != null && events[i].id == unsigned_txid)) break;
|
||||||
events[i].id == event_id ||
|
|
||||||
(unsigned_txid != null && events[i].content["txid"] == unsigned_txid))
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
@ -65,13 +62,10 @@ class Timeline {
|
||||||
if (i < events.length) events.removeAt(i);
|
if (i < events.length) events.removeAt(i);
|
||||||
}
|
}
|
||||||
// Is this event already in the timeline?
|
// Is this event already in the timeline?
|
||||||
else if (eventUpdate.content["status"] == 1 ||
|
else if (eventUpdate.content.containsKey("unsigned") &&
|
||||||
eventUpdate.content["status"] == -1 ||
|
eventUpdate.content["unsigned"]["transaction_id"] is String) {
|
||||||
(eventUpdate.content.containsKey("unsigned") &&
|
|
||||||
eventUpdate.content["unsigned"]["transaction_id"] is String)) {
|
|
||||||
int i = _findEvent(
|
int i = _findEvent(
|
||||||
event_id: eventUpdate.content["event_id"],
|
event_id: eventUpdate.content["event_id"],
|
||||||
txid: eventUpdate.content["content"]["txid"],
|
|
||||||
unsigned_txid: eventUpdate.content.containsKey("unsigned")
|
unsigned_txid: eventUpdate.content.containsKey("unsigned")
|
||||||
? eventUpdate.content["unsigned"]["transaction_id"]
|
? eventUpdate.content["unsigned"]["transaction_id"]
|
||||||
: null);
|
: null);
|
||||||
|
|
|
@ -59,6 +59,7 @@ void main() {
|
||||||
final String fullyRead = "fjh82jdjifd:server.abc";
|
final String fullyRead = "fjh82jdjifd:server.abc";
|
||||||
final String notificationSettings = "all";
|
final String notificationSettings = "all";
|
||||||
final String guestAccess = "forbidden";
|
final String guestAccess = "forbidden";
|
||||||
|
final String canonicalAlias = "#testroom:example.com";
|
||||||
final String historyVisibility = "invite";
|
final String historyVisibility = "invite";
|
||||||
final String joinRules = "invite";
|
final String joinRules = "invite";
|
||||||
final int now = DateTime.now().millisecondsSinceEpoch;
|
final int now = DateTime.now().millisecondsSinceEpoch;
|
||||||
|
@ -85,6 +86,7 @@ void main() {
|
||||||
"guest_access": guestAccess,
|
"guest_access": guestAccess,
|
||||||
"history_visibility": historyVisibility,
|
"history_visibility": historyVisibility,
|
||||||
"join_rules": joinRules,
|
"join_rules": joinRules,
|
||||||
|
"canonical_alias": canonicalAlias,
|
||||||
"power_events_default": 0,
|
"power_events_default": 0,
|
||||||
"power_state_default": 0,
|
"power_state_default": 0,
|
||||||
"power_redact": 0,
|
"power_redact": 0,
|
||||||
|
@ -115,6 +117,7 @@ void main() {
|
||||||
expect(room.notificationSettings, notificationSettings);
|
expect(room.notificationSettings, notificationSettings);
|
||||||
expect(room.directChatMatrixID, "");
|
expect(room.directChatMatrixID, "");
|
||||||
expect(room.draft, "");
|
expect(room.draft, "");
|
||||||
|
expect(room.canonicalAlias, canonicalAlias);
|
||||||
expect(room.prev_batch, "");
|
expect(room.prev_batch, "");
|
||||||
expect(room.guestAccess, guestAccess);
|
expect(room.guestAccess, guestAccess);
|
||||||
expect(room.historyVisibility, historyVisibility);
|
expect(room.historyVisibility, historyVisibility);
|
||||||
|
|
|
@ -103,7 +103,6 @@ void main() {
|
||||||
expect(updateCount, 4);
|
expect(updateCount, 4);
|
||||||
expect(insertList, [0, 0, 0]);
|
expect(insertList, [0, 0, 0]);
|
||||||
expect(insertList.length, timeline.events.length);
|
expect(insertList.length, timeline.events.length);
|
||||||
expect(timeline.events[0].content["txid"], "1234");
|
|
||||||
expect(timeline.events[0].id, "42");
|
expect(timeline.events[0].id, "42");
|
||||||
expect(timeline.events[0].status, 1);
|
expect(timeline.events[0].status, 1);
|
||||||
|
|
||||||
|
@ -154,11 +153,8 @@ void main() {
|
||||||
expect(updateCount, 12);
|
expect(updateCount, 12);
|
||||||
expect(insertList, [0, 0, 0, 0, 0, 0, 0]);
|
expect(insertList, [0, 0, 0, 0, 0, 0, 0]);
|
||||||
expect(insertList.length, timeline.events.length);
|
expect(insertList.length, timeline.events.length);
|
||||||
expect(timeline.events[0].content["txid"], "errortxid3");
|
|
||||||
expect(timeline.events[0].status, -1);
|
expect(timeline.events[0].status, -1);
|
||||||
expect(timeline.events[1].content["txid"], "errortxid2");
|
|
||||||
expect(timeline.events[1].status, -1);
|
expect(timeline.events[1].status, -1);
|
||||||
expect(timeline.events[2].content["txid"], "errortxid");
|
|
||||||
expect(timeline.events[2].status, -1);
|
expect(timeline.events[2].status, -1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -171,7 +167,6 @@ void main() {
|
||||||
|
|
||||||
expect(insertList, [0, 0, 0, 0, 0, 0, 0]);
|
expect(insertList, [0, 0, 0, 0, 0, 0, 0]);
|
||||||
expect(timeline.events.length, 6);
|
expect(timeline.events.length, 6);
|
||||||
expect(timeline.events[0].content["txid"], "errortxid2");
|
|
||||||
expect(timeline.events[0].status, -1);
|
expect(timeline.events[0].status, -1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -184,7 +179,6 @@ void main() {
|
||||||
|
|
||||||
expect(insertList, [0, 0, 0, 0, 0, 0, 0, 0]);
|
expect(insertList, [0, 0, 0, 0, 0, 0, 0, 0]);
|
||||||
expect(timeline.events.length, 6);
|
expect(timeline.events.length, 6);
|
||||||
expect(timeline.events[0].content["txid"], "1234");
|
|
||||||
expect(timeline.events[0].status, 1);
|
expect(timeline.events[0].status, 1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue