diff options
author | fiaxh <git@mx.ax.lt> | 2017-03-12 21:22:45 +0100 |
---|---|---|
committer | fiaxh <git@mx.ax.lt> | 2017-03-12 21:24:25 +0100 |
commit | 13cef27d46bb8c3c6a274983fc8569752fb69b5d (patch) | |
tree | 6ddde22c3c2b33a932eda8b0b8a7f4266b9db7f0 | |
parent | c2643a45b0dc05c4fd82ec7d32577700dae7450e (diff) | |
download | dino-13cef27d46bb8c3c6a274983fc8569752fb69b5d.tar.gz dino-13cef27d46bb8c3c6a274983fc8569752fb69b5d.zip |
Search messages having a uuid stanza id by id + account
-rw-r--r-- | libdino/src/service/database.vala | 3 | ||||
-rw-r--r-- | libdino/src/service/message_manager.vala | 2 |
2 files changed, 3 insertions, 2 deletions
diff --git a/libdino/src/service/database.vala b/libdino/src/service/database.vala index 885a1a8f..953fa0b1 100644 --- a/libdino/src/service/database.vala +++ b/libdino/src/service/database.vala @@ -293,9 +293,10 @@ public class Database : Qlite.Database { .count() > 0; } - public bool contains_message_by_stanza_id(string stanza_id) { + public bool contains_message_by_stanza_id(string stanza_id, Account account) { return message.select() .with(message.stanza_id, "=", stanza_id) + .with(message.account_id, "=", account.id) .count() > 0; } diff --git a/libdino/src/service/message_manager.vala b/libdino/src/service/message_manager.vala index b24aa12d..9f87c932 100644 --- a/libdino/src/service/message_manager.vala +++ b/libdino/src/service/message_manager.vala @@ -115,7 +115,7 @@ public class MessageManager : StreamInteractionModule, Object { pre_message_received(new_message, message, conversation); bool is_uuid = new_message.stanza_id != null && Regex.match_simple("""[0-9A-Fa-f]{8}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{12}""", new_message.stanza_id); - if ((is_uuid && !db.contains_message_by_stanza_id(new_message.stanza_id)) || + if ((is_uuid && !db.contains_message_by_stanza_id(new_message.stanza_id, conversation.account)) || (!is_uuid && !db.contains_message(new_message, conversation.account))) { db.add_message(new_message, conversation.account); add_message(new_message, conversation); |