2020-06-26 16:17:53 +10:00
|
|
|
package org.thoughtcrime.securesms.notifications;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
|
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;
|
|
|
|
import org.thoughtcrime.securesms.loki.api.LokiPublicChatManager;
|
|
|
|
import org.thoughtcrime.securesms.recipients.Recipient;
|
|
|
|
import org.thoughtcrime.securesms.util.Debouncer;
|
|
|
|
import org.whispersystems.signalservice.loki.api.LokiPoller;
|
|
|
|
|
|
|
|
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) {
|
|
|
|
LokiPoller lokiPoller = ApplicationContext.getInstance(context).lokiPoller;
|
|
|
|
LokiPublicChatManager lokiPublicChatManager = ApplicationContext.getInstance(context).lokiPublicChatManager;
|
2020-07-08 11:30:00 +10:00
|
|
|
Boolean isCaughtUp = false;
|
2020-06-26 16:17:53 +10:00
|
|
|
if (lokiPoller != null && lokiPublicChatManager != null) {
|
2020-07-08 11:30:00 +10:00
|
|
|
isCaughtUp = lokiPoller.isCaughtUp() && lokiPublicChatManager.areAllCaughtUp();
|
2020-06-26 16:17:53 +10:00
|
|
|
}
|
|
|
|
|
2020-07-08 11:30:00 +10:00
|
|
|
if (isCaughtUp) {
|
2020-06-26 16:17:53 +10:00
|
|
|
wrapped.updateNotification(context);
|
|
|
|
} else {
|
|
|
|
debouncer.publish(() -> wrapped.updateNotification(context));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void updateNotification(@NonNull Context context, long threadId) {
|
|
|
|
LokiPoller lokiPoller = ApplicationContext.getInstance(context).lokiPoller;
|
|
|
|
LokiPublicChatManager lokiPublicChatManager = ApplicationContext.getInstance(context).lokiPublicChatManager;
|
2020-07-08 11:30:00 +10:00
|
|
|
Boolean isCaughtUp = false;
|
2020-06-26 16:17:53 +10:00
|
|
|
if (lokiPoller != null && lokiPublicChatManager != null) {
|
2020-07-08 11:30:00 +10:00
|
|
|
isCaughtUp = lokiPoller.isCaughtUp() && lokiPublicChatManager.areAllCaughtUp();
|
2020-06-26 16:17:53 +10:00
|
|
|
}
|
|
|
|
|
2020-07-08 11:30:00 +10:00
|
|
|
if (isCaughtUp) {
|
2020-06-26 16:17:53 +10:00
|
|
|
wrapped.updateNotification(context, threadId);
|
|
|
|
} else {
|
|
|
|
debouncer.publish(() -> wrapped.updateNotification(context, threadId));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void updateNotification(@NonNull Context context, long threadId, boolean signal) {
|
|
|
|
LokiPoller lokiPoller = ApplicationContext.getInstance(context).lokiPoller;
|
|
|
|
LokiPublicChatManager lokiPublicChatManager = ApplicationContext.getInstance(context).lokiPublicChatManager;
|
2020-07-08 11:30:00 +10:00
|
|
|
Boolean isCaughtUp = false;
|
2020-06-26 16:17:53 +10:00
|
|
|
if (lokiPoller != null && lokiPublicChatManager != null) {
|
2020-07-08 11:30:00 +10:00
|
|
|
isCaughtUp = lokiPoller.isCaughtUp() && lokiPublicChatManager.areAllCaughtUp();
|
2020-06-26 16:17:53 +10:00
|
|
|
}
|
|
|
|
|
2020-07-08 11:30:00 +10:00
|
|
|
if (isCaughtUp) {
|
2020-06-26 16:17:53 +10:00
|
|
|
wrapped.updateNotification(context, threadId, signal);
|
|
|
|
} else {
|
|
|
|
debouncer.publish(() -> wrapped.updateNotification(context, threadId, signal));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void updateNotification(@android.support.annotation.NonNull Context context, boolean signal, int reminderCount) {
|
|
|
|
LokiPoller lokiPoller = ApplicationContext.getInstance(context).lokiPoller;
|
|
|
|
LokiPublicChatManager lokiPublicChatManager = ApplicationContext.getInstance(context).lokiPublicChatManager;
|
2020-07-08 11:30:00 +10:00
|
|
|
Boolean isCaughtUp = false;
|
2020-06-26 16:17:53 +10:00
|
|
|
if (lokiPoller != null && lokiPublicChatManager != null) {
|
2020-07-08 11:30:00 +10:00
|
|
|
isCaughtUp = lokiPoller.isCaughtUp() && lokiPublicChatManager.areAllCaughtUp();
|
2020-06-26 16:17:53 +10:00
|
|
|
}
|
|
|
|
|
2020-07-08 11:30:00 +10:00
|
|
|
if (isCaughtUp) {
|
2020-06-26 16:17:53 +10:00
|
|
|
wrapped.updateNotification(context, signal, reminderCount);
|
|
|
|
} else {
|
|
|
|
debouncer.publish(() -> wrapped.updateNotification(context, signal, reminderCount));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void clearReminder(@NonNull Context context) { wrapped.clearReminder(context); }
|
|
|
|
}
|