aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/pixart/messenger/services/NotificationService.java
diff options
context:
space:
mode:
authorChristian Schneppe <christian@pix-art.de>2017-05-09 20:48:56 +0200
committerChristian Schneppe <christian@pix-art.de>2017-05-09 20:48:56 +0200
commitc0afad2fcd2be07834f64625204984879880afd5 (patch)
tree4d936b19362d1f4acd01d982e88813661fc7eb42 /src/main/java/de/pixart/messenger/services/NotificationService.java
parent699dbe2e2a56ac36160950c1ac06b16f59eab6c1 (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.java13
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");