mirror of
https://github.com/oxen-io/session-android.git
synced 2025-10-24 18:29:11 +00:00
disconnect radio regardless of MMS exception
Fixes #2498 Closes #2544 // FREEBIE
This commit is contained in:

committed by
Moxie Marlinspike

parent
ac312ff5d5
commit
96896bf8f1
@@ -110,30 +110,31 @@ public class MmsDownloadJob extends MasterSecretJob {
|
|||||||
Log.w(TAG, "Changing radio to MMS mode..");
|
Log.w(TAG, "Changing radio to MMS mode..");
|
||||||
radio.connect();
|
radio.connect();
|
||||||
|
|
||||||
Log.w(TAG, "Downloading in MMS mode with proxy...");
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
retrieveAndStore(masterSecret, radio, messageId, threadId, contentLocation,
|
Log.w(TAG, "Downloading in MMS mode with proxy...");
|
||||||
transactionId, true, true);
|
|
||||||
radio.disconnect();
|
|
||||||
return;
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
Log.w(TAG, "Downloading in MMS mode without proxy...");
|
try {
|
||||||
|
retrieveAndStore(masterSecret, radio, messageId, threadId, contentLocation,
|
||||||
|
transactionId, true, true);
|
||||||
|
return;
|
||||||
|
} catch (IOException e) {
|
||||||
|
Log.w(TAG, e);
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
Log.w(TAG, "Downloading in MMS mode without proxy...");
|
||||||
retrieveAndStore(masterSecret, radio, messageId, threadId,
|
|
||||||
contentLocation, transactionId, true, false);
|
try {
|
||||||
|
retrieveAndStore(masterSecret, radio, messageId, threadId,
|
||||||
|
contentLocation, transactionId, true, false);
|
||||||
|
} catch (IOException e) {
|
||||||
|
Log.w(TAG, e);
|
||||||
|
handleDownloadError(masterSecret, messageId, threadId,
|
||||||
|
MmsDatabase.Status.DOWNLOAD_SOFT_FAILURE,
|
||||||
|
context.getString(R.string.MmsDownloader_error_connecting_to_mms_provider),
|
||||||
|
automatic);
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
radio.disconnect();
|
radio.disconnect();
|
||||||
} catch (IOException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
radio.disconnect();
|
|
||||||
handleDownloadError(masterSecret, messageId, threadId,
|
|
||||||
MmsDatabase.Status.DOWNLOAD_SOFT_FAILURE,
|
|
||||||
context.getString(R.string.MmsDownloader_error_connecting_to_mms_provider),
|
|
||||||
automatic);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (ApnUnavailableException e) {
|
} catch (ApnUnavailableException e) {
|
||||||
|
@@ -118,23 +118,22 @@ public class MmsSendJob extends SendJob {
|
|||||||
radio.connect();
|
radio.connect();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
MmsSendResult result = sendMms(masterSecret, radio, message, true, true);
|
try {
|
||||||
radio.disconnect();
|
return sendMms(masterSecret, radio, message, true, true);
|
||||||
return result;
|
} catch (IOException e) {
|
||||||
} catch (IOException e) {
|
Log.w(TAG, e);
|
||||||
Log.w(TAG, e);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
Log.w(TAG, "Sending MMS with radio change and without proxy...");
|
Log.w(TAG, "Sending MMS with radio change and without proxy...");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
MmsSendResult result = sendMms(masterSecret, radio, message, true, false);
|
return sendMms(masterSecret, radio, message, true, false);
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
Log.w(TAG, ioe);
|
||||||
|
throw new UndeliverableMessageException(ioe);
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
radio.disconnect();
|
radio.disconnect();
|
||||||
return result;
|
|
||||||
} catch (IOException ioe) {
|
|
||||||
Log.w(TAG, ioe);
|
|
||||||
radio.disconnect();
|
|
||||||
throw new UndeliverableMessageException(ioe);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (MmsRadioException mre) {
|
} catch (MmsRadioException mre) {
|
||||||
|
Reference in New Issue
Block a user