mirror of
https://github.com/oxen-io/session-android.git
synced 2025-03-26 17:40:50 +00:00
116 lines
4.9 KiB
Java
116 lines
4.9 KiB
Java
package org.thoughtcrime.securesms.notifications;
|
|
|
|
import android.annotation.SuppressLint;
|
|
import android.content.BroadcastReceiver;
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.os.AsyncTask;
|
|
import android.support.annotation.NonNull;
|
|
import android.support.v4.app.NotificationManagerCompat;
|
|
|
|
import com.annimon.stream.Collectors;
|
|
import com.annimon.stream.Stream;
|
|
|
|
import org.thoughtcrime.securesms.ApplicationContext;
|
|
import org.thoughtcrime.securesms.database.Address;
|
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
|
import org.thoughtcrime.securesms.database.MessagingDatabase.ExpirationInfo;
|
|
import org.thoughtcrime.securesms.database.MessagingDatabase.MarkedMessageInfo;
|
|
import org.thoughtcrime.securesms.database.MessagingDatabase.SyncMessageId;
|
|
import org.thoughtcrime.securesms.jobs.MultiDeviceReadUpdateJob;
|
|
import org.thoughtcrime.securesms.jobs.SendReadReceiptJob;
|
|
import org.thoughtcrime.securesms.logging.Log;
|
|
import org.thoughtcrime.securesms.loki.MultiDeviceUtilKt;
|
|
import org.thoughtcrime.securesms.service.ExpiringMessageManager;
|
|
import org.whispersystems.signalservice.loki.api.LokiStorageAPI;
|
|
|
|
import java.util.LinkedList;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
import kotlin.Unit;
|
|
|
|
public class MarkReadReceiver extends BroadcastReceiver {
|
|
|
|
private static final String TAG = MarkReadReceiver.class.getSimpleName();
|
|
public static final String CLEAR_ACTION = "org.thoughtcrime.securesms.notifications.CLEAR";
|
|
public static final String THREAD_IDS_EXTRA = "thread_ids";
|
|
public static final String NOTIFICATION_ID_EXTRA = "notification_id";
|
|
|
|
@SuppressLint("StaticFieldLeak")
|
|
@Override
|
|
public void onReceive(final Context context, Intent intent) {
|
|
if (!CLEAR_ACTION.equals(intent.getAction()))
|
|
return;
|
|
|
|
final long[] threadIds = intent.getLongArrayExtra(THREAD_IDS_EXTRA);
|
|
|
|
if (threadIds != null) {
|
|
NotificationManagerCompat.from(context).cancel(intent.getIntExtra(NOTIFICATION_ID_EXTRA, -1));
|
|
|
|
new AsyncTask<Void, Void, Void>() {
|
|
@Override
|
|
protected Void doInBackground(Void... params) {
|
|
List<MarkedMessageInfo> messageIdsCollection = new LinkedList<>();
|
|
|
|
for (long threadId : threadIds) {
|
|
Log.i(TAG, "Marking as read: " + threadId);
|
|
List<MarkedMessageInfo> messageIds = DatabaseFactory.getThreadDatabase(context).setRead(threadId, true);
|
|
messageIdsCollection.addAll(messageIds);
|
|
}
|
|
|
|
process(context, messageIdsCollection);
|
|
|
|
MessageNotifier.updateNotification(context);
|
|
|
|
return null;
|
|
}
|
|
}.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
|
}
|
|
}
|
|
|
|
public static void process(@NonNull Context context, @NonNull List<MarkedMessageInfo> markedReadMessages) {
|
|
if (markedReadMessages.isEmpty()) return;
|
|
|
|
List<SyncMessageId> syncMessageIds = new LinkedList<>();
|
|
|
|
for (MarkedMessageInfo messageInfo : markedReadMessages) {
|
|
scheduleDeletion(context, messageInfo.getExpirationInfo());
|
|
syncMessageIds.add(messageInfo.getSyncMessageId());
|
|
}
|
|
|
|
ApplicationContext.getInstance(context)
|
|
.getJobManager()
|
|
.add(new MultiDeviceReadUpdateJob(syncMessageIds));
|
|
|
|
Map<Address, List<SyncMessageId>> addressMap = Stream.of(markedReadMessages)
|
|
.map(MarkedMessageInfo::getSyncMessageId)
|
|
.collect(Collectors.groupingBy(SyncMessageId::getAddress));
|
|
|
|
for (Address address : addressMap.keySet()) {
|
|
LokiStorageAPI storageAPI = LokiStorageAPI.Companion.getShared();
|
|
|
|
List<Long> timestamps = Stream.of(addressMap.get(address)).map(SyncMessageId::getTimetamp).toList();
|
|
|
|
MultiDeviceUtilKt.getAllDevices(context, address.serialize(), storageAPI, (devicePublicKey, isFriend, friendCount) -> {
|
|
// Loki - This also prevents read receipts from being sent in group chats as they don't maintain a friend request status
|
|
if (isFriend) {
|
|
ApplicationContext.getInstance(context).getJobManager().add(new SendReadReceiptJob(Address.fromSerialized(devicePublicKey), timestamps));
|
|
}
|
|
return Unit.INSTANCE;
|
|
});
|
|
}
|
|
}
|
|
|
|
private static void scheduleDeletion(Context context, ExpirationInfo expirationInfo) {
|
|
if (expirationInfo.getExpiresIn() > 0 && expirationInfo.getExpireStarted() <= 0) {
|
|
ExpiringMessageManager expirationManager = ApplicationContext.getInstance(context).getExpiringMessageManager();
|
|
|
|
if (expirationInfo.isMms()) DatabaseFactory.getMmsDatabase(context).markExpireStarted(expirationInfo.getId());
|
|
else DatabaseFactory.getSmsDatabase(context).markExpireStarted(expirationInfo.getId());
|
|
|
|
expirationManager.scheduleDeletion(expirationInfo.getId(), expirationInfo.isMms(), expirationInfo.getExpiresIn());
|
|
}
|
|
}
|
|
}
|