mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-11 20:43:38 +00:00
assert gif size constraints before OOMEs
fixes #3778 closes #3833 // FREEBIE
This commit is contained in:
parent
c36c759c8b
commit
a84dcf6a8e
@ -98,6 +98,7 @@
|
|||||||
<string name="ConversationActivity_select_contact_info">Select contact info</string>
|
<string name="ConversationActivity_select_contact_info">Select contact info</string>
|
||||||
<string name="ConversationActivity_compose_message">Compose message</string>
|
<string name="ConversationActivity_compose_message">Compose message</string>
|
||||||
<string name="ConversationActivity_sorry_there_was_an_error_setting_your_attachment">Sorry, there was an error setting your attachment.</string>
|
<string name="ConversationActivity_sorry_there_was_an_error_setting_your_attachment">Sorry, there was an error setting your attachment.</string>
|
||||||
|
<string name="ConversationActivity_the_gif_you_selected_was_too_big">The gif you selected was too big!</string>
|
||||||
<string name="ConversationActivity_sorry_the_selected_video_exceeds_message_size_restrictions">Sorry, the selected video exceeds message size restrictions (%1$skB).</string>
|
<string name="ConversationActivity_sorry_the_selected_video_exceeds_message_size_restrictions">Sorry, the selected video exceeds message size restrictions (%1$skB).</string>
|
||||||
<string name="ConversationActivity_sorry_the_selected_audio_exceeds_message_size_restrictions">Sorry, the selected audio exceeds message size restrictions (%1$skB).</string>
|
<string name="ConversationActivity_sorry_the_selected_audio_exceeds_message_size_restrictions">Sorry, the selected audio exceeds message size restrictions (%1$skB).</string>
|
||||||
<string name="ConversationActivity_recipient_is_not_a_valid_sms_or_email_address_exclamation">Recipient is not a valid SMS or email address!</string>
|
<string name="ConversationActivity_recipient_is_not_a_valid_sms_or_email_address_exclamation">Recipient is not a valid SMS or email address!</string>
|
||||||
|
@ -86,6 +86,7 @@ import org.thoughtcrime.securesms.database.MmsSmsColumns.Types;
|
|||||||
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
||||||
import org.thoughtcrime.securesms.mms.AttachmentManager;
|
import org.thoughtcrime.securesms.mms.AttachmentManager;
|
||||||
import org.thoughtcrime.securesms.mms.AttachmentTypeSelectorAdapter;
|
import org.thoughtcrime.securesms.mms.AttachmentTypeSelectorAdapter;
|
||||||
|
import org.thoughtcrime.securesms.mms.MediaConstraints;
|
||||||
import org.thoughtcrime.securesms.mms.MediaTooLargeException;
|
import org.thoughtcrime.securesms.mms.MediaTooLargeException;
|
||||||
import org.thoughtcrime.securesms.mms.MmsMediaConstraints;
|
import org.thoughtcrime.securesms.mms.MmsMediaConstraints;
|
||||||
import org.thoughtcrime.securesms.mms.OutgoingGroupMediaMessage;
|
import org.thoughtcrime.securesms.mms.OutgoingGroupMediaMessage;
|
||||||
@ -931,6 +932,11 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
attachmentManager.clear();
|
attachmentManager.clear();
|
||||||
Toast.makeText(this, R.string.ConversationActivity_sorry_there_was_an_error_setting_your_attachment,
|
Toast.makeText(this, R.string.ConversationActivity_sorry_there_was_an_error_setting_your_attachment,
|
||||||
Toast.LENGTH_LONG).show();
|
Toast.LENGTH_LONG).show();
|
||||||
|
} catch (MediaTooLargeException e) {
|
||||||
|
attachmentManager.clear();
|
||||||
|
Toast.makeText(this, getString(R.string.ConversationActivity_the_gif_you_selected_was_too_big),
|
||||||
|
Toast.LENGTH_LONG).show();
|
||||||
|
Log.w(TAG, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,9 @@ public class AttachmentManager {
|
|||||||
captureUri = null;
|
captureUri = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImage(MasterSecret masterSecret, Uri image) throws IOException, BitmapDecodingException {
|
public void setImage(MasterSecret masterSecret, Uri image)
|
||||||
|
throws IOException, BitmapDecodingException, MediaTooLargeException
|
||||||
|
{
|
||||||
if (MediaUtil.isGif(MediaUtil.getMimeType(context, image))) {
|
if (MediaUtil.isGif(MediaUtil.getMimeType(context, image))) {
|
||||||
setMedia(new GifSlide(context, masterSecret, image), masterSecret);
|
setMedia(new GifSlide(context, masterSecret, image), masterSecret);
|
||||||
} else {
|
} else {
|
||||||
|
@ -59,7 +59,7 @@ public class AudioSlide extends Slide {
|
|||||||
public static PduPart constructPartFromUri(Context context, Uri uri) throws IOException, MediaTooLargeException {
|
public static PduPart constructPartFromUri(Context context, Uri uri) throws IOException, MediaTooLargeException {
|
||||||
PduPart part = new PduPart();
|
PduPart part = new PduPart();
|
||||||
|
|
||||||
assertMediaSize(context, uri);
|
assertMediaSize(context, uri, MmsMediaConstraints.MAX_MESSAGE_SIZE);
|
||||||
|
|
||||||
Cursor cursor = null;
|
Cursor cursor = null;
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ package org.thoughtcrime.securesms.mms;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.provider.MediaStore.Audio.Media;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.crypto.MasterSecret;
|
import org.thoughtcrime.securesms.crypto.MasterSecret;
|
||||||
import org.thoughtcrime.securesms.util.BitmapDecodingException;
|
import org.thoughtcrime.securesms.util.BitmapDecodingException;
|
||||||
@ -16,9 +17,18 @@ public class GifSlide extends ImageSlide {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GifSlide(Context context, MasterSecret masterSecret, Uri uri)
|
public GifSlide(Context context, MasterSecret masterSecret, Uri uri)
|
||||||
throws IOException, BitmapDecodingException
|
throws IOException, BitmapDecodingException, MediaTooLargeException
|
||||||
{
|
{
|
||||||
super(context, masterSecret, uri);
|
super(context, masterSecret, uri);
|
||||||
|
assertMediaSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void assertMediaSize() throws MediaTooLargeException, IOException {
|
||||||
|
// TODO move assertion outside of slides and take available transport options into account
|
||||||
|
assertMediaSize(context, getPart().getDataUri(), MediaConstraints.PUSH_CONSTRAINTS.getGifMaxSize());
|
||||||
|
if (!MediaConstraints.PUSH_CONSTRAINTS.isSatisfied(context, masterSecret, part)) {
|
||||||
|
throw new MediaTooLargeException("Media exceeds maximum message size.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override public Uri getThumbnailUri() {
|
@Override public Uri getThumbnailUri() {
|
||||||
|
@ -5,6 +5,9 @@ import android.net.Uri;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.util.Pair;
|
import android.util.Pair;
|
||||||
|
|
||||||
|
import com.bumptech.glide.Glide;
|
||||||
|
import com.bumptech.glide.gifdecoder.GifDecoder;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.crypto.MasterSecret;
|
import org.thoughtcrime.securesms.crypto.MasterSecret;
|
||||||
import org.thoughtcrime.securesms.util.BitmapDecodingException;
|
import org.thoughtcrime.securesms.util.BitmapDecodingException;
|
||||||
import org.thoughtcrime.securesms.util.BitmapUtil;
|
import org.thoughtcrime.securesms.util.BitmapUtil;
|
||||||
@ -33,7 +36,7 @@ public abstract class MediaConstraints {
|
|||||||
|
|
||||||
public boolean isSatisfied(Context context, MasterSecret masterSecret, PduPart part) {
|
public boolean isSatisfied(Context context, MasterSecret masterSecret, PduPart part) {
|
||||||
try {
|
try {
|
||||||
return (MediaUtil.isGif(part) && part.getDataSize() <= getGifMaxSize()) ||
|
return (MediaUtil.isGif(part) && part.getDataSize() <= getGifMaxSize() && isWithinBounds(context, masterSecret, part.getDataUri())) ||
|
||||||
(MediaUtil.isImage(part) && part.getDataSize() <= getImageMaxSize() && isWithinBounds(context, masterSecret, part.getDataUri())) ||
|
(MediaUtil.isImage(part) && part.getDataSize() <= getImageMaxSize() && isWithinBounds(context, masterSecret, part.getDataUri())) ||
|
||||||
(MediaUtil.isAudio(part) && part.getDataSize() <= getAudioMaxSize()) ||
|
(MediaUtil.isAudio(part) && part.getDataSize() <= getAudioMaxSize()) ||
|
||||||
(MediaUtil.isVideo(part) && part.getDataSize() <= getVideoMaxSize()) ||
|
(MediaUtil.isVideo(part) && part.getDataSize() <= getVideoMaxSize()) ||
|
||||||
|
@ -86,7 +86,7 @@ public abstract class Slide {
|
|||||||
return !getPart().getPartId().isValid();
|
return !getPart().getPartId().isValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static void assertMediaSize(Context context, Uri uri)
|
protected static void assertMediaSize(Context context, Uri uri, long max)
|
||||||
throws MediaTooLargeException, IOException
|
throws MediaTooLargeException, IOException
|
||||||
{
|
{
|
||||||
InputStream in = context.getContentResolver().openInputStream(uri);
|
InputStream in = context.getContentResolver().openInputStream(uri);
|
||||||
@ -96,7 +96,7 @@ public abstract class Slide {
|
|||||||
|
|
||||||
while ((read = in.read(buffer)) != -1) {
|
while ((read = in.read(buffer)) != -1) {
|
||||||
size += read;
|
size += read;
|
||||||
if (size > MmsMediaConstraints.MAX_MESSAGE_SIZE) throw new MediaTooLargeException("Media exceeds maximum message size.");
|
if (size > max) throw new MediaTooLargeException("Media exceeds maximum message size.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ public class VideoSlide extends Slide {
|
|||||||
cursor.close();
|
cursor.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
assertMediaSize(context, uri);
|
assertMediaSize(context, uri, MmsMediaConstraints.MAX_MESSAGE_SIZE);
|
||||||
part.setDataUri(uri);
|
part.setDataUri(uri);
|
||||||
part.setContentId((System.currentTimeMillis()+"").getBytes());
|
part.setContentId((System.currentTimeMillis()+"").getBytes());
|
||||||
part.setName(("Video" + System.currentTimeMillis()).getBytes());
|
part.setName(("Video" + System.currentTimeMillis()).getBytes());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user