Add function for direct chat handling

This commit is contained in:
Christian Pauly 2019-06-12 11:46:57 +02:00
parent 06bcf90d6e
commit f8557c38f5
2 changed files with 73 additions and 43 deletions

View file

@ -176,8 +176,7 @@ class Room {
if (txid == null) txid = "txid${DateTime.now().millisecondsSinceEpoch}"; if (txid == null) txid = "txid${DateTime.now().millisecondsSinceEpoch}";
final dynamic res = await client.connection.jsonRequest( final dynamic res = await client.connection.jsonRequest(
type: "PUT", type: "PUT",
action: action: "/client/r0/rooms/${id}/send/m.room.message/$txid",
"/client/r0/rooms/${id}/send/m.room.message/$txid",
data: {"msgtype": "m.text", "body": message}); data: {"msgtype": "m.text", "body": message});
if (res["errcode"] == "M_LIMIT_EXCEEDED") if (res["errcode"] == "M_LIMIT_EXCEEDED")
client.connection.onError.add(res["error"]); client.connection.onError.add(res["error"]);
@ -185,16 +184,12 @@ class Room {
} }
Future<String> sendTextEvent(String message) async { Future<String> sendTextEvent(String message) async {
final String type = "m.room.message"; final String type = "m.room.message";
final int now = DateTime.now().millisecondsSinceEpoch; final int now = DateTime.now().millisecondsSinceEpoch;
final String messageID = "msg$now"; final String messageID = "msg$now";
EventUpdate eventUpdate = EventUpdate( EventUpdate eventUpdate =
type: type, EventUpdate(type: type, roomID: id, eventType: "timeline", content: {
roomID: id,
eventType: "timeline",
content: {
"type": type, "type": type,
"id": messageID, "id": messageID,
"sender": client.userID, "sender": client.userID,
@ -204,24 +199,24 @@ class Room {
"msgtype": "m.text", "msgtype": "m.text",
"body": message, "body": message,
} }
} });
);
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);
}); });
final dynamic res = await sendText(message, txid: messageID); final dynamic res = await sendText(message, txid: messageID);
if (res is ErrorResponse) { if (res is ErrorResponse) {
client.store.db.rawUpdate("UPDATE Events SET status=-1 WHERE id=?", [ messageID ]); client.store.db
} .rawUpdate("UPDATE Events SET status=-1 WHERE id=?", [messageID]);
else { } else {
final String newEventID = res["event_id"]; final String newEventID = res["event_id"];
final List<Map<String,dynamic>> event = await client.store.db.rawQuery("SELECT * FROM Events WHERE id=?", [ newEventID ]); final List<Map<String, dynamic>> event = await client.store.db
.rawQuery("SELECT * FROM Events WHERE id=?", [newEventID]);
if (event.length > 0) { if (event.length > 0) {
client.store.db.rawDelete("DELETE FROM Events WHERE id=?", [messageID]); client.store.db.rawDelete("DELETE FROM Events WHERE id=?", [messageID]);
} } else {
else { client.store.db.rawUpdate("UPDATE Events SET id=?, status=1 WHERE id=?",
client.store.db.rawUpdate("UPDATE Events SET id=?, status=1 WHERE id=?", [ newEventID, messageID ]); [newEventID, messageID]);
} }
return newEventID; return newEventID;
} }
@ -306,7 +301,8 @@ class Room {
if (resp is ErrorResponse) return; if (resp is ErrorResponse) return;
if (!(resp["chunk"] is List<dynamic> && resp["chunk"].length > 0 && if (!(resp["chunk"] is List<dynamic> &&
resp["chunk"].length > 0 &&
resp["end"] is String)) return; resp["end"] is String)) return;
List<dynamic> history = resp["chunk"]; List<dynamic> history = resp["chunk"];
@ -326,17 +322,37 @@ class Room {
}); });
} }
Future<dynamic> addToDirectChat(String userID) async {
Map<String, List<String>> directChats =
await client.store.getAccountDataDirectChats();
if (directChats.containsKey(userID)) if (!directChats[userID].contains(id))
directChats[userID].add(id);
else
return null; // Is already in direct chats
else
directChats[userID] = [id];
final resp = await client.connection.jsonRequest(
type: "PUT",
action: "/client/r0/user/${client.userID}/account_data/m.direct",
data: directChats);
return resp;
}
Future<dynamic> sendReadReceipt(String eventID) async { Future<dynamic> sendReadReceipt(String eventID) async {
final dynamic resp = client.connection.jsonRequest( final dynamic resp = client.connection.jsonRequest(
type: "fully_read", type: "fully_read",
action: "/client/r0/rooms/$id/read_markers", action: "/client/r0/rooms/$id/read_markers",
data: {"m.fully_read": eventID,"m.read": eventID,}); data: {
"m.fully_read": eventID,
"m.read": eventID,
});
return resp; return resp;
} }
/// Returns a Room from a json String which comes normally from the store. /// Returns a Room from a json String which comes normally from the store.
static Future<Room> getRoomFromTableRow(Map<String, dynamic> row, static Future<Room> getRoomFromTableRow(
Client matrix) async { Map<String, dynamic> row, Client matrix) async {
String name = row["topic"]; String name = row["topic"];
if (name == "") if (name == "")
name = await matrix.store?.getChatNameFromMemberNames(row["id"]) ?? ""; name = await matrix.store?.getChatNameFromMemberNames(row["id"]) ?? "";

View file

@ -463,7 +463,8 @@ class Store {
bool onlyDirect = false, bool onlyDirect = false,
bool onlyGroups = false}) async { bool onlyGroups = false}) async {
if (onlyDirect && onlyGroups) return []; if (onlyDirect && onlyGroups) return [];
List<Map<String, dynamic>> res = await db.rawQuery("SELECT rooms.*, events.origin_server_ts, events.content_json, events.type, events.sender, events.status, events.state_key " + List<Map<String, dynamic>> res = await db.rawQuery(
"SELECT rooms.*, events.origin_server_ts, events.content_json, events.type, events.sender, events.status, events.state_key " +
" FROM Rooms rooms LEFT JOIN Events events " + " FROM Rooms rooms LEFT JOIN Events events " +
" ON rooms.id=events.chat_id " + " ON rooms.id=events.chat_id " +
" WHERE rooms.id!='' " + " WHERE rooms.id!='' " +
@ -563,6 +564,19 @@ class Store {
return powerMap; return powerMap;
} }
Future<Map<String, List<String>>> getAccountDataDirectChats() async {
Map<String, List<String>> directChats = {};
List<Map<String, dynamic>> res = await db.rawQuery(
"SELECT id, direct_chat_matrix_id FROM Rooms WHERE direct_chat_matrix_id!=''");
for (int i = 0; i < res.length; i++) {
if (directChats.containsKey(res[i]["direct_chat_matrix_id"]))
directChats[res[i]["direct_chat_matrix_id"]].add(res[i]["id"]);
else
directChats[res[i]["direct_chat_matrix_id"]] = [res[i]["id"]];
}
return directChats;
}
/// The database sheme for the Client class. /// The database sheme for the Client class.
static final String ClientsScheme = 'CREATE TABLE IF NOT EXISTS Clients(' + static final String ClientsScheme = 'CREATE TABLE IF NOT EXISTS Clients(' +
'client TEXT PRIMARY KEY, ' + 'client TEXT PRIMARY KEY, ' +