diff options
author | Christian Schneppe <christian@pix-art.de> | 2017-05-09 20:48:56 +0200 |
---|---|---|
committer | Christian Schneppe <christian@pix-art.de> | 2017-05-09 20:48:56 +0200 |
commit | c0afad2fcd2be07834f64625204984879880afd5 (patch) | |
tree | 4d936b19362d1f4acd01d982e88813661fc7eb42 /src/main/java/de/pixart/messenger/services/NotificationService.java | |
parent | 699dbe2e2a56ac36160950c1ac06b16f59eab6c1 (diff) |
avoid race conditions when downloading files or decrypting pgp messages
and waiting for sm catchup
Diffstat (limited to 'src/main/java/de/pixart/messenger/services/NotificationService.java')
-rw-r--r-- | src/main/java/de/pixart/messenger/services/NotificationService.java | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/main/java/de/pixart/messenger/services/NotificationService.java b/src/main/java/de/pixart/messenger/services/NotificationService.java index 56f0427c0..460779a60 100644 --- a/src/main/java/de/pixart/messenger/services/NotificationService.java +++ b/src/main/java/de/pixart/messenger/services/NotificationService.java @@ -45,6 +45,7 @@ import de.pixart.messenger.ui.ManageAccountActivity; import de.pixart.messenger.ui.TimePreference; import de.pixart.messenger.utils.GeoHelper; import de.pixart.messenger.utils.UIHelper; +import de.pixart.messenger.xmpp.XmppConnection; public class NotificationService { @@ -175,6 +176,18 @@ public class NotificationService { } public void push(final Message message) { + synchronized (message.getConversation().getAccount()) { + final XmppConnection connection = message.getConversation().getAccount().getXmppConnection(); + if (connection.isWaitingForSmCatchup()) { + connection.incrementSmCatchupMessageCounter(); + pushFromBacklog(message); + } else { + pushNow(message); + } + } + } + + private void pushNow(final Message message) { mXmppConnectionService.updateUnreadCountBadge(); if (!notify(message)) { Log.d(Config.LOGTAG, message.getConversation().getAccount().getJid().toBareJid() + ": suppressing notification because turned off"); |