session-android/src/org/thoughtcrime/securesms/notifications/OptimizedMessageNotifier.java

132 lines
4.7 KiB
Java
Raw Normal View History

2020-06-26 16:17:53 +10:00
package org.thoughtcrime.securesms.notifications;
import android.content.Context;
2020-07-10 11:43:45 +10:00
import android.os.Looper;
2020-06-26 16:17:53 +10:00
2020-07-08 11:30:00 +10:00
import androidx.annotation.MainThread;
import androidx.annotation.NonNull;
2020-06-26 16:17:53 +10:00
import org.thoughtcrime.securesms.ApplicationContext;
2020-07-15 14:26:20 +10:00
import org.thoughtcrime.securesms.loki.api.PublicChatManager;
2020-06-26 16:17:53 +10:00
import org.thoughtcrime.securesms.recipients.Recipient;
import org.thoughtcrime.securesms.util.Debouncer;
2020-07-08 17:05:26 +10:00
import org.whispersystems.signalservice.loki.api.Poller;
2020-06-26 16:17:53 +10:00
import java.util.concurrent.TimeUnit;
public class OptimizedMessageNotifier implements MessageNotifier {
private final MessageNotifier wrapped;
private final Debouncer debouncer;
@MainThread
public OptimizedMessageNotifier(@NonNull MessageNotifier wrapped) {
this.wrapped = wrapped;
this.debouncer = new Debouncer(TimeUnit.SECONDS.toMillis(1));
}
@Override
public void setVisibleThread(long threadId) { wrapped.setVisibleThread(threadId); }
@Override
public void setLastDesktopActivityTimestamp(long timestamp) { wrapped.setLastDesktopActivityTimestamp(timestamp);}
@Override
public void notifyMessageDeliveryFailed(Context context, Recipient recipient, long threadId) {
wrapped.notifyMessageDeliveryFailed(context, recipient, threadId);
}
@Override
public void cancelDelayedNotifications() { wrapped.cancelDelayedNotifications(); }
@Override
public void updateNotification(@NonNull Context context) {
2020-07-16 08:55:29 +10:00
Poller lokiPoller = ApplicationContext.getInstance(context).poller;
2020-07-15 14:26:20 +10:00
PublicChatManager publicChatManager = ApplicationContext.getInstance(context).publicChatManager;
boolean isCaughtUp = true;
2020-07-10 15:36:23 +10:00
if (lokiPoller != null) {
isCaughtUp = isCaughtUp && lokiPoller.isCaughtUp();
}
2020-07-15 14:26:20 +10:00
if (publicChatManager != null) {
isCaughtUp = isCaughtUp && publicChatManager.areAllCaughtUp();
2020-06-26 16:17:53 +10:00
}
2020-07-08 11:30:00 +10:00
if (isCaughtUp) {
performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context));
2020-06-26 16:17:53 +10:00
} else {
debouncer.publish(() -> performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context)));
2020-06-26 16:17:53 +10:00
}
}
@Override
public void updateNotification(@NonNull Context context, long threadId) {
2020-07-16 08:55:29 +10:00
Poller lokiPoller = ApplicationContext.getInstance(context).poller;
2020-07-15 14:26:20 +10:00
PublicChatManager publicChatManager = ApplicationContext.getInstance(context).publicChatManager;
boolean isCaughtUp = true;
2020-07-10 15:36:23 +10:00
if (lokiPoller != null) {
isCaughtUp = isCaughtUp && lokiPoller.isCaughtUp();
2020-06-26 16:17:53 +10:00
}
2020-07-15 14:26:20 +10:00
if (publicChatManager != null) {
isCaughtUp = isCaughtUp && publicChatManager.areAllCaughtUp();
2020-07-10 15:36:23 +10:00
}
2020-07-08 11:30:00 +10:00
if (isCaughtUp) {
performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, threadId));
2020-06-26 16:17:53 +10:00
} else {
debouncer.publish(() -> performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, threadId)));
2020-06-26 16:17:53 +10:00
}
}
@Override
public void updateNotification(@NonNull Context context, long threadId, boolean signal) {
2020-07-16 08:55:29 +10:00
Poller lokiPoller = ApplicationContext.getInstance(context).poller;
2020-07-15 14:26:20 +10:00
PublicChatManager publicChatManager = ApplicationContext.getInstance(context).publicChatManager;
boolean isCaughtUp = true;
2020-07-10 15:36:23 +10:00
if (lokiPoller != null) {
isCaughtUp = isCaughtUp && lokiPoller.isCaughtUp();
}
2020-07-15 14:26:20 +10:00
if (publicChatManager != null) {
isCaughtUp = isCaughtUp && publicChatManager.areAllCaughtUp();
2020-06-26 16:17:53 +10:00
}
2020-07-08 11:30:00 +10:00
if (isCaughtUp) {
performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, threadId, signal));
2020-06-26 16:17:53 +10:00
} else {
debouncer.publish(() -> performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, threadId, signal)));
2020-06-26 16:17:53 +10:00
}
}
@Override
public void updateNotification(@androidx.annotation.NonNull Context context, boolean signal, int reminderCount) {
2020-07-16 08:55:29 +10:00
Poller lokiPoller = ApplicationContext.getInstance(context).poller;
2020-07-15 14:26:20 +10:00
PublicChatManager publicChatManager = ApplicationContext.getInstance(context).publicChatManager;
boolean isCaughtUp = true;
2020-07-10 15:36:23 +10:00
if (lokiPoller != null) {
isCaughtUp = isCaughtUp && lokiPoller.isCaughtUp();
}
2020-07-15 14:26:20 +10:00
if (publicChatManager != null) {
isCaughtUp = isCaughtUp && publicChatManager.areAllCaughtUp();
2020-06-26 16:17:53 +10:00
}
2020-07-08 11:30:00 +10:00
if (isCaughtUp) {
performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, signal, reminderCount));
2020-06-26 16:17:53 +10:00
} else {
debouncer.publish(() -> performOnBackgroundThreadIfNeeded(() -> wrapped.updateNotification(context, signal, reminderCount)));
2020-06-26 16:17:53 +10:00
}
}
@Override
public void clearReminder(@NonNull Context context) { wrapped.clearReminder(context); }
private void performOnBackgroundThreadIfNeeded(Runnable r) {
if (Looper.myLooper() == Looper.getMainLooper()) {
new Thread(r).start();
} else {
r.run();
}
}
2020-06-26 16:17:53 +10:00
}