mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 11:23:38 +00:00
Merge branch 'dev' into light-theme
This commit is contained in:
commit
ce0159f5cc
@ -1,8 +1,9 @@
|
|||||||
package org.thoughtcrime.securesms.jobs;
|
package org.thoughtcrime.securesms.jobs;
|
||||||
|
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import org.greenrobot.eventbus.EventBus;
|
import org.greenrobot.eventbus.EventBus;
|
||||||
import org.thoughtcrime.securesms.ApplicationContext;
|
import org.thoughtcrime.securesms.ApplicationContext;
|
||||||
@ -39,7 +40,7 @@ public class AttachmentDownloadJob extends BaseJob implements InjectableType {
|
|||||||
|
|
||||||
public static final String KEY = "AttachmentDownloadJob";
|
public static final String KEY = "AttachmentDownloadJob";
|
||||||
|
|
||||||
private static final int MAX_ATTACHMENT_SIZE = 150 * 1024 * 1024;
|
private static final int MAX_ATTACHMENT_SIZE = 10 * 1024 * 1024;
|
||||||
private static final String TAG = AttachmentDownloadJob.class.getSimpleName();
|
private static final String TAG = AttachmentDownloadJob.class.getSimpleName();
|
||||||
|
|
||||||
private static final String KEY_MESSAGE_ID = "message_id";
|
private static final String KEY_MESSAGE_ID = "message_id";
|
||||||
@ -58,7 +59,7 @@ public class AttachmentDownloadJob extends BaseJob implements InjectableType {
|
|||||||
this(new Job.Parameters.Builder()
|
this(new Job.Parameters.Builder()
|
||||||
.setQueue("AttachmentDownloadJob" + attachmentId.getRowId() + "-" + attachmentId.getUniqueId())
|
.setQueue("AttachmentDownloadJob" + attachmentId.getRowId() + "-" + attachmentId.getUniqueId())
|
||||||
.addConstraint(NetworkConstraint.KEY)
|
.addConstraint(NetworkConstraint.KEY)
|
||||||
.setMaxAttempts(25)
|
.setMaxAttempts(5)
|
||||||
.build(),
|
.build(),
|
||||||
messageId,
|
messageId,
|
||||||
attachmentId,
|
attachmentId,
|
||||||
@ -183,19 +184,19 @@ public class AttachmentDownloadJob extends BaseJob implements InjectableType {
|
|||||||
SignalServiceAttachmentPointer createAttachmentPointer(Attachment attachment)
|
SignalServiceAttachmentPointer createAttachmentPointer(Attachment attachment)
|
||||||
throws InvalidPartException
|
throws InvalidPartException
|
||||||
{
|
{
|
||||||
boolean isPublicAttachment = TextUtils.isEmpty(attachment.getKey()) && attachment.getDigest() == null;
|
boolean isOpenGroupContext = TextUtils.isEmpty(attachment.getKey()) && attachment.getDigest() == null;
|
||||||
|
|
||||||
if (TextUtils.isEmpty(attachment.getLocation())) {
|
if (TextUtils.isEmpty(attachment.getLocation())) {
|
||||||
throw new InvalidPartException("empty content id");
|
throw new InvalidPartException("empty content id");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (TextUtils.isEmpty(attachment.getKey()) && !isPublicAttachment) {
|
if (TextUtils.isEmpty(attachment.getKey()) && !isOpenGroupContext) {
|
||||||
throw new InvalidPartException("empty encrypted key");
|
throw new InvalidPartException("empty encrypted key");
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
long id = Long.parseLong(attachment.getLocation());
|
long id = Long.parseLong(attachment.getLocation());
|
||||||
if (isPublicAttachment) {
|
if (isOpenGroupContext) {
|
||||||
return new SignalServiceAttachmentPointer(id,
|
return new SignalServiceAttachmentPointer(id,
|
||||||
null,
|
null,
|
||||||
new byte[0],
|
new byte[0],
|
||||||
@ -210,11 +211,6 @@ public class AttachmentDownloadJob extends BaseJob implements InjectableType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
byte[] key = Base64.decode(attachment.getKey());
|
byte[] key = Base64.decode(attachment.getKey());
|
||||||
String relay = null;
|
|
||||||
|
|
||||||
if (TextUtils.isEmpty(attachment.getRelay())) {
|
|
||||||
relay = attachment.getRelay();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (attachment.getDigest() != null) {
|
if (attachment.getDigest() != null) {
|
||||||
Log.i(TAG, "Downloading attachment with digest: " + Hex.toString(attachment.getDigest()));
|
Log.i(TAG, "Downloading attachment with digest: " + Hex.toString(attachment.getDigest()));
|
||||||
|
@ -2,18 +2,17 @@ package org.thoughtcrime.securesms.util;
|
|||||||
|
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.database.Cursor;
|
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.annotation.WorkerThread;
|
import androidx.annotation.WorkerThread;
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.attachments.AttachmentId;
|
import org.thoughtcrime.securesms.attachments.AttachmentId;
|
||||||
import org.thoughtcrime.securesms.attachments.DatabaseAttachment;
|
import org.thoughtcrime.securesms.attachments.DatabaseAttachment;
|
||||||
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
||||||
import org.thoughtcrime.securesms.database.model.MessageRecord;
|
|
||||||
import org.thoughtcrime.securesms.logging.Log;
|
import org.thoughtcrime.securesms.logging.Log;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@ -106,11 +105,6 @@ public class AttachmentUtil {
|
|||||||
|
|
||||||
@WorkerThread
|
@WorkerThread
|
||||||
private static boolean isFromUnknownContact(@NonNull Context context, @NonNull DatabaseAttachment attachment) {
|
private static boolean isFromUnknownContact(@NonNull Context context, @NonNull DatabaseAttachment attachment) {
|
||||||
MessageRecord message;
|
|
||||||
try (Cursor messageCursor = DatabaseFactory.getMmsDatabase(context).getMessage(attachment.getMmsId())) {
|
|
||||||
message = DatabaseFactory.getMmsDatabase(context).readerFor(messageCursor).getNext();
|
|
||||||
}
|
|
||||||
if (message == null) { return true; }
|
|
||||||
// We don't allow attachments to be sent unless we're friends with someone or the attachment is sent
|
// We don't allow attachments to be sent unless we're friends with someone or the attachment is sent
|
||||||
// in a group context. Auto-downloading attachments is therefore fine.
|
// in a group context. Auto-downloading attachments is therefore fine.
|
||||||
return false;
|
return false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user