mirror of
https://github.com/oxen-io/session-android.git
synced 2025-08-25 17:37:57 +00:00
Chunk read sync messages.
Same thing we do with read receipts we send to other people. Just missed this part.
This commit is contained in:
@@ -8,6 +8,7 @@ import com.fasterxml.jackson.annotation.JsonProperty;
|
|||||||
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
||||||
import org.thoughtcrime.securesms.jobmanager.Data;
|
import org.thoughtcrime.securesms.jobmanager.Data;
|
||||||
import org.thoughtcrime.securesms.jobmanager.Job;
|
import org.thoughtcrime.securesms.jobmanager.Job;
|
||||||
|
import org.thoughtcrime.securesms.jobmanager.JobManager;
|
||||||
import org.thoughtcrime.securesms.jobmanager.impl.NetworkConstraint;
|
import org.thoughtcrime.securesms.jobmanager.impl.NetworkConstraint;
|
||||||
import org.thoughtcrime.securesms.logging.Log;
|
import org.thoughtcrime.securesms.logging.Log;
|
||||||
|
|
||||||
@@ -18,6 +19,7 @@ import org.thoughtcrime.securesms.recipients.RecipientId;
|
|||||||
import org.thoughtcrime.securesms.recipients.RecipientUtil;
|
import org.thoughtcrime.securesms.recipients.RecipientUtil;
|
||||||
import org.thoughtcrime.securesms.util.JsonUtils;
|
import org.thoughtcrime.securesms.util.JsonUtils;
|
||||||
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
||||||
|
import org.thoughtcrime.securesms.util.Util;
|
||||||
import org.whispersystems.signalservice.api.SignalServiceMessageSender;
|
import org.whispersystems.signalservice.api.SignalServiceMessageSender;
|
||||||
import org.whispersystems.signalservice.api.crypto.UntrustedIdentityException;
|
import org.whispersystems.signalservice.api.crypto.UntrustedIdentityException;
|
||||||
import org.whispersystems.signalservice.api.messages.multidevice.ReadMessage;
|
import org.whispersystems.signalservice.api.messages.multidevice.ReadMessage;
|
||||||
@@ -40,13 +42,13 @@ public class MultiDeviceReadUpdateJob extends BaseJob {
|
|||||||
|
|
||||||
private List<SerializableSyncMessageId> messageIds;
|
private List<SerializableSyncMessageId> messageIds;
|
||||||
|
|
||||||
public MultiDeviceReadUpdateJob(List<SyncMessageId> messageIds) {
|
private MultiDeviceReadUpdateJob(List<SyncMessageId> messageIds) {
|
||||||
this(new Job.Parameters.Builder()
|
this(new Job.Parameters.Builder()
|
||||||
.addConstraint(NetworkConstraint.KEY)
|
.addConstraint(NetworkConstraint.KEY)
|
||||||
.setLifespan(TimeUnit.DAYS.toMillis(1))
|
.setLifespan(TimeUnit.DAYS.toMillis(1))
|
||||||
.setMaxAttempts(Parameters.UNLIMITED)
|
.setMaxAttempts(Parameters.UNLIMITED)
|
||||||
.build(),
|
.build(),
|
||||||
messageIds);
|
SendReadReceiptJob.ensureSize(messageIds, SendReadReceiptJob.MAX_TIMESTAMPS));
|
||||||
}
|
}
|
||||||
|
|
||||||
private MultiDeviceReadUpdateJob(@NonNull Job.Parameters parameters, @NonNull List<SyncMessageId> messageIds) {
|
private MultiDeviceReadUpdateJob(@NonNull Job.Parameters parameters, @NonNull List<SyncMessageId> messageIds) {
|
||||||
@@ -59,6 +61,23 @@ public class MultiDeviceReadUpdateJob extends BaseJob {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues all the necessary jobs for read receipts, ensuring that they're all within the
|
||||||
|
* maximum size.
|
||||||
|
*/
|
||||||
|
public static void enqueue(@NonNull List<SyncMessageId> messageIds) {
|
||||||
|
JobManager jobManager = ApplicationDependencies.getJobManager();
|
||||||
|
List<List<SyncMessageId>> messageIdChunks = Util.chunk(messageIds, SendReadReceiptJob.MAX_TIMESTAMPS);
|
||||||
|
|
||||||
|
if (messageIdChunks.size() > 1) {
|
||||||
|
Log.w(TAG, "Large receipt count! Had to break into multiple chunks. Total count: " + messageIds.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (List<SyncMessageId> chunk : messageIdChunks) {
|
||||||
|
jobManager.add(new MultiDeviceReadUpdateJob(chunk));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NonNull Data serialize() {
|
public @NonNull Data serialize() {
|
||||||
String[] ids = new String[messageIds.size()];
|
String[] ids = new String[messageIds.size()];
|
||||||
|
@@ -35,7 +35,7 @@ public class SendReadReceiptJob extends BaseJob {
|
|||||||
|
|
||||||
private static final String TAG = SendReadReceiptJob.class.getSimpleName();
|
private static final String TAG = SendReadReceiptJob.class.getSimpleName();
|
||||||
|
|
||||||
private static final int MAX_TIMESTAMPS = 500;
|
static final int MAX_TIMESTAMPS = 500;
|
||||||
|
|
||||||
private static final String KEY_THREAD = "thread";
|
private static final String KEY_THREAD = "thread";
|
||||||
private static final String KEY_ADDRESS = "address";
|
private static final String KEY_ADDRESS = "address";
|
||||||
@@ -150,7 +150,7 @@ public class SendReadReceiptJob extends BaseJob {
|
|||||||
Log.w(TAG, "Failed to send read receipts to: " + recipientId);
|
Log.w(TAG, "Failed to send read receipts to: " + recipientId);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static <E> List<E> ensureSize(@NonNull List<E> list, int maxSize) {
|
static <E> List<E> ensureSize(@NonNull List<E> list, int maxSize) {
|
||||||
if (list.size() > maxSize) {
|
if (list.size() > maxSize) {
|
||||||
throw new IllegalArgumentException("Too large! Size: " + list.size() + ", maxSize: " + maxSize);
|
throw new IllegalArgumentException("Too large! Size: " + list.size() + ", maxSize: " + maxSize);
|
||||||
}
|
}
|
||||||
|
@@ -85,7 +85,7 @@ public class MarkReadReceiver extends BroadcastReceiver {
|
|||||||
|
|
||||||
scheduleDeletion(context, smsExpirationInfo, mmsExpirationInfo);
|
scheduleDeletion(context, smsExpirationInfo, mmsExpirationInfo);
|
||||||
|
|
||||||
ApplicationDependencies.getJobManager().add(new MultiDeviceReadUpdateJob(syncMessageIds));
|
MultiDeviceReadUpdateJob.enqueue(syncMessageIds);
|
||||||
|
|
||||||
Map<Long, List<MarkedMessageInfo>> threadToInfo = Stream.of(markedReadMessages)
|
Map<Long, List<MarkedMessageInfo>> threadToInfo = Stream.of(markedReadMessages)
|
||||||
.collect(Collectors.groupingBy(MarkedMessageInfo::getThreadId));
|
.collect(Collectors.groupingBy(MarkedMessageInfo::getThreadId));
|
||||||
|
Reference in New Issue
Block a user