mirror of
https://github.com/oxen-io/session-android.git
synced 2025-04-03 23:15:39 +00:00
Manually calculate length of attachments if they're super old
Fixes #7560
This commit is contained in:
parent
2c82b3610d
commit
b9f99f9941
@ -20,7 +20,6 @@ import org.thoughtcrime.securesms.crypto.AttachmentSecret;
|
|||||||
import org.thoughtcrime.securesms.crypto.ClassicDecryptingPartInputStream;
|
import org.thoughtcrime.securesms.crypto.ClassicDecryptingPartInputStream;
|
||||||
import org.thoughtcrime.securesms.crypto.IdentityKeyUtil;
|
import org.thoughtcrime.securesms.crypto.IdentityKeyUtil;
|
||||||
import org.thoughtcrime.securesms.crypto.ModernDecryptingPartInputStream;
|
import org.thoughtcrime.securesms.crypto.ModernDecryptingPartInputStream;
|
||||||
import org.thoughtcrime.securesms.database.Address;
|
|
||||||
import org.thoughtcrime.securesms.database.AttachmentDatabase;
|
import org.thoughtcrime.securesms.database.AttachmentDatabase;
|
||||||
import org.thoughtcrime.securesms.database.MmsDatabase;
|
import org.thoughtcrime.securesms.database.MmsDatabase;
|
||||||
import org.thoughtcrime.securesms.database.MmsSmsColumns;
|
import org.thoughtcrime.securesms.database.MmsSmsColumns;
|
||||||
@ -190,7 +189,11 @@ public class FullBackupExporter extends FullBackupBase {
|
|||||||
String data = cursor.getString(cursor.getColumnIndexOrThrow(AttachmentDatabase.DATA));
|
String data = cursor.getString(cursor.getColumnIndexOrThrow(AttachmentDatabase.DATA));
|
||||||
byte[] random = cursor.getBlob(cursor.getColumnIndexOrThrow(AttachmentDatabase.DATA_RANDOM));
|
byte[] random = cursor.getBlob(cursor.getColumnIndexOrThrow(AttachmentDatabase.DATA_RANDOM));
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(data)) {
|
if (!TextUtils.isEmpty(data) && size <= 0) {
|
||||||
|
size = calculateVeryOldStreamLength(attachmentSecret, random, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!TextUtils.isEmpty(data) && size > 0) {
|
||||||
InputStream inputStream;
|
InputStream inputStream;
|
||||||
|
|
||||||
if (random != null && random.length == 32) inputStream = ModernDecryptingPartInputStream.createFor(attachmentSecret, random, new File(data), 0);
|
if (random != null && random.length == 32) inputStream = ModernDecryptingPartInputStream.createFor(attachmentSecret, random, new File(data), 0);
|
||||||
@ -203,6 +206,23 @@ public class FullBackupExporter extends FullBackupBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static long calculateVeryOldStreamLength(@NonNull AttachmentSecret attachmentSecret, @Nullable byte[] random, @NonNull String data) throws IOException {
|
||||||
|
long result = 0;
|
||||||
|
InputStream inputStream;
|
||||||
|
|
||||||
|
if (random != null && random.length == 32) inputStream = ModernDecryptingPartInputStream.createFor(attachmentSecret, random, new File(data), 0);
|
||||||
|
else inputStream = ClassicDecryptingPartInputStream.createFor(attachmentSecret, new File(data));
|
||||||
|
|
||||||
|
int read;
|
||||||
|
byte[] buffer = new byte[8192];
|
||||||
|
|
||||||
|
while ((read = inputStream.read(buffer, 0, buffer.length)) != -1) {
|
||||||
|
result += read;
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
private static class BackupFrameOutputStream extends BackupStream {
|
private static class BackupFrameOutputStream extends BackupStream {
|
||||||
|
|
||||||
private final OutputStream outputStream;
|
private final OutputStream outputStream;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user