From 0d06d50a65c46de07b16e2390669390bde19d188 Mon Sep 17 00:00:00 2001 From: Moxie Marlinspike Date: Tue, 11 Nov 2014 21:11:57 -0800 Subject: [PATCH] Let's have JobManager only deal with checked exceptions. Also, switch to Builder for JobManager construction. --- .../jobqueue/JobManagerTest.java | 58 +++++++++++++---- .../jobqueue/jobs/PersistentTestJob.java | 6 +- .../jobs/RequirementDeferringTestJob.java | 6 +- .../whispersystems/jobqueue/jobs/TestJob.java | 4 +- .../util/MockRequirementProvider.java | 5 ++ .../jobqueue/util/PersistentResult.java | 2 +- .../jobqueue/util/RunnableThrowable.java | 2 +- .../java/org/whispersystems/jobqueue/Job.java | 5 +- .../whispersystems/jobqueue/JobConsumer.java | 19 +++--- .../whispersystems/jobqueue/JobManager.java | 62 +++++++++++++++++-- .../org/whispersystems/jobqueue/JobQueue.java | 4 ++ .../securesms/ApplicationContext.java | 23 +++---- .../securesms/jobs/AttachmentDownloadJob.java | 4 +- .../securesms/jobs/AvatarDownloadJob.java | 4 +- .../securesms/jobs/CleanPreKeysJob.java | 2 +- .../securesms/jobs/CreateSignedPreKeyJob.java | 5 +- .../securesms/jobs/DeliveryReceiptJob.java | 8 +-- .../securesms/jobs/GcmRefreshJob.java | 2 +- .../securesms/jobs/MasterSecretJob.java | 12 ++-- .../securesms/jobs/MmsDownloadJob.java | 2 +- .../securesms/jobs/MmsReceiveJob.java | 2 +- .../securesms/jobs/MmsSendJob.java | 2 +- .../securesms/jobs/PushDecryptJob.java | 2 +- .../securesms/jobs/PushGroupSendJob.java | 4 +- .../securesms/jobs/PushMediaSendJob.java | 4 +- .../securesms/jobs/PushReceiveJob.java | 2 +- .../securesms/jobs/PushTextSendJob.java | 4 +- .../securesms/jobs/RefreshPreKeysJob.java | 8 +-- .../securesms/jobs/SmsDecryptJob.java | 5 +- .../securesms/jobs/SmsReceiveJob.java | 2 +- .../securesms/jobs/SmsSendJob.java | 2 +- .../securesms/jobs/SmsSentJob.java | 2 +- 32 files changed, 180 insertions(+), 94 deletions(-) diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/JobManagerTest.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/JobManagerTest.java index db8bdb9906..e7f3d67f45 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/JobManagerTest.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/JobManagerTest.java @@ -7,6 +7,7 @@ import org.whispersystems.jobqueue.jobs.RequirementDeferringTestJob; import org.whispersystems.jobqueue.jobs.RequirementTestJob; import org.whispersystems.jobqueue.jobs.TestJob; import org.whispersystems.jobqueue.persistence.JavaJobSerializer; +import org.whispersystems.jobqueue.requirements.RequirementProvider; import org.whispersystems.jobqueue.util.MockRequirement; import org.whispersystems.jobqueue.util.MockRequirementProvider; import org.whispersystems.jobqueue.util.PersistentMockRequirement; @@ -15,12 +16,17 @@ import org.whispersystems.jobqueue.util.PersistentResult; import org.whispersystems.jobqueue.util.RunnableThrowable; import java.io.IOException; +import java.util.LinkedList; +import java.util.List; public class JobManagerTest extends AndroidTestCase { public void testTransientJobExecution() throws InterruptedException { TestJob testJob = new TestJob(); - JobManager jobManager = new JobManager(getContext(), "transient-test", null, null, 1); + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("transient-test") + .withConsumerThreads(1) + .build(); jobManager.add(testJob); @@ -32,8 +38,12 @@ public class JobManagerTest extends AndroidTestCase { MockRequirementProvider provider = new MockRequirementProvider(); MockRequirement requirement = new MockRequirement(false); TestJob testJob = new RequirementTestJob(requirement); - JobManager jobManager = new JobManager(getContext(), "transient-requirement-test", - provider, null, 1); + + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("transient-requirement-test") + .withRequirementProviders(provider) + .withConsumerThreads(1) + .build(); jobManager.add(testJob); @@ -75,8 +85,12 @@ public class JobManagerTest extends AndroidTestCase { MockRequirementProvider provider = new MockRequirementProvider(); MockRequirement requirement = new MockRequirement(false); RequirementDeferringTestJob testJob = new RequirementDeferringTestJob(requirement, 5, waitRunnable); - JobManager jobManager = new JobManager(getContext(), "transient-requirement-test", - provider, null, 1); + + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("transient-requirement-test") + .withRequirementProviders(provider) + .withConsumerThreads(1) + .build(); jobManager.add(testJob); @@ -106,8 +120,11 @@ public class JobManagerTest extends AndroidTestCase { public void testPersistentJobExecuton() throws InterruptedException { PersistentMockRequirement requirement = new PersistentMockRequirement(); PersistentTestJob testJob = new PersistentTestJob(requirement); - JobManager jobManager = new JobManager(getContext(), "persistent-requirement-test3", - null, new JavaJobSerializer(getContext()), 1); + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("persistent-requirement-test3") + .withJobSerializer(new JavaJobSerializer(getContext())) + .withConsumerThreads(1) + .build(); PersistentResult.getInstance().reset(); PersistentRequirement.getInstance().setPresent(false); @@ -118,8 +135,12 @@ public class JobManagerTest extends AndroidTestCase { assertTrue(!PersistentResult.getInstance().isRan()); PersistentRequirement.getInstance().setPresent(true); - jobManager = new JobManager(getContext(), "persistent-requirement-test3", null, - new JavaJobSerializer(getContext()), 1); + + jobManager = JobManager.newBuilder(getContext()) + .withName("persistent-requirement-test3") + .withJobSerializer(new JavaJobSerializer(getContext())) + .withConsumerThreads(1) + .build(); assertTrue(PersistentResult.getInstance().isRan()); } @@ -128,8 +149,12 @@ public class JobManagerTest extends AndroidTestCase { EncryptionKeys keys = new EncryptionKeys(new byte[30]); PersistentMockRequirement requirement = new PersistentMockRequirement(); PersistentTestJob testJob = new PersistentTestJob(requirement, keys); - JobManager jobManager = new JobManager(getContext(), "persistent-requirement-test4", - null, new JavaJobSerializer(getContext()), 1); + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("persistent-requirement-test4") + .withJobSerializer(new JavaJobSerializer(getContext())) + .withConsumerThreads(1) + .build(); + jobManager.setEncryptionKeys(keys); PersistentResult.getInstance().reset(); @@ -141,7 +166,11 @@ public class JobManagerTest extends AndroidTestCase { assertTrue(!PersistentResult.getInstance().isRan()); PersistentRequirement.getInstance().setPresent(true); - jobManager = new JobManager(getContext(), "persistent-requirement-test4", null, new JavaJobSerializer(getContext()), 1); + jobManager = JobManager.newBuilder(getContext()) + .withName("persistent-requirement-test4") + .withJobSerializer(new JavaJobSerializer(getContext())) + .withConsumerThreads(1) + .build(); assertTrue(!PersistentResult.getInstance().isRan()); @@ -169,7 +198,10 @@ public class JobManagerTest extends AndroidTestCase { TestJob testJobOne = new TestJob(JobParameters.newBuilder().withGroupId("foo").create(), waitRunnable); TestJob testJobTwo = new TestJob(JobParameters.newBuilder().withGroupId("foo").create()); TestJob testJobThree = new TestJob(JobParameters.newBuilder().withGroupId("bar").create()); - JobManager jobManager = new JobManager(getContext(), "transient-test", null, null, 3); + JobManager jobManager = JobManager.newBuilder(getContext()) + .withName("transient-test") + .withConsumerThreads(3) + .build(); jobManager.add(testJobOne); jobManager.add(testJobTwo); diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/PersistentTestJob.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/PersistentTestJob.java index 0f582e72ef..0d9a561f47 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/PersistentTestJob.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/PersistentTestJob.java @@ -19,11 +19,11 @@ public class PersistentTestJob extends Job { @Override public void onAdded() { - PersistentResult.getInstance().onAdded();; + PersistentResult.getInstance().onAdded(); } @Override - public void onRun() throws Throwable { + public void onRun() throws Exception { PersistentResult.getInstance().onRun(); } @@ -33,7 +33,7 @@ public class PersistentTestJob extends Job { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception exception) { return false; } } diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/RequirementDeferringTestJob.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/RequirementDeferringTestJob.java index e64b7a3661..5306d39316 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/RequirementDeferringTestJob.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/RequirementDeferringTestJob.java @@ -20,7 +20,7 @@ public class RequirementDeferringTestJob extends TestJob { } @Override - public void onRun() throws Throwable { + public void onRun() throws Exception { synchronized (RAN_LOCK) { this.ran = true; } @@ -34,8 +34,8 @@ public class RequirementDeferringTestJob extends TestJob { } @Override - public boolean onShouldRetry(Throwable throwable) { - if (throwable instanceof Exception) { + public boolean onShouldRetry(Exception exception) { + if (exception instanceof Exception) { return true; } return false; diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/TestJob.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/TestJob.java index b99ae2347b..5e3a866b8a 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/TestJob.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/jobs/TestJob.java @@ -37,7 +37,7 @@ public class TestJob extends Job { } @Override - public void onRun() throws Throwable { + public void onRun() throws Exception { synchronized (RAN_LOCK) { this.ran = true; } @@ -54,7 +54,7 @@ public class TestJob extends Job { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception exception) { return false; } diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/MockRequirementProvider.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/MockRequirementProvider.java index 235449e18e..ba2e27a183 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/MockRequirementProvider.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/MockRequirementProvider.java @@ -15,4 +15,9 @@ public class MockRequirementProvider implements RequirementProvider { public void setListener(RequirementListener listener) { this.listener = listener; } + + @Override + public String getName() { + return "mock-requirement-provider"; + } } diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/PersistentResult.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/PersistentResult.java index ffd213ae85..7bdff69ccd 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/PersistentResult.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/PersistentResult.java @@ -23,7 +23,7 @@ public class PersistentResult { } } - public void onRun() throws Throwable { + public void onRun() throws Exception { synchronized (RAN_LOCK) { this.ran = true; } diff --git a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/RunnableThrowable.java b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/RunnableThrowable.java index abbdf97de1..470d66e204 100644 --- a/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/RunnableThrowable.java +++ b/jobqueue/src/androidTest/java/org/whispersystems/jobqueue/util/RunnableThrowable.java @@ -2,7 +2,7 @@ package org.whispersystems.jobqueue.util; public interface RunnableThrowable { - public void run() throws Throwable; + public void run() throws Exception; public void shouldThrow(Boolean value); } diff --git a/jobqueue/src/main/java/org/whispersystems/jobqueue/Job.java b/jobqueue/src/main/java/org/whispersystems/jobqueue/Job.java index 202f95c993..d4793a0355 100644 --- a/jobqueue/src/main/java/org/whispersystems/jobqueue/Job.java +++ b/jobqueue/src/main/java/org/whispersystems/jobqueue/Job.java @@ -81,9 +81,10 @@ public abstract class Job implements Serializable { } public abstract void onAdded(); - public abstract void onRun() throws Throwable; + public abstract void onRun() throws Exception; + public abstract boolean onShouldRetry(Exception exception); public abstract void onCanceled(); - public abstract boolean onShouldRetry(Throwable throwable); + } diff --git a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobConsumer.java b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobConsumer.java index 4bbbaff931..d1febb53a3 100644 --- a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobConsumer.java +++ b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobConsumer.java @@ -42,11 +42,12 @@ public class JobConsumer extends Thread { @Override public void run() { while (true) { - Job job = jobQueue.getNext(); + Job job = jobQueue.getNext(); + JobResult result = runJob(job); - JobResult result; - - if ((result = runJob(job)) != JobResult.DEFERRED) { + if (result == JobResult.DEFERRED) { + jobQueue.push(job); + } else { if (result == JobResult.FAILURE) { job.onCanceled(); } @@ -54,8 +55,6 @@ public class JobConsumer extends Thread { if (job.isPersistent()) { persistentStorage.remove(job.getPersistentId()); } - } else { - jobQueue.add(job); } if (job.getGroupId() != null) { @@ -72,9 +71,11 @@ public class JobConsumer extends Thread { try { job.onRun(); return JobResult.SUCCESS; - } catch (Throwable throwable) { - Log.w(TAG, throwable); - if (!job.onShouldRetry(throwable)) { + } catch (Exception exception) { + Log.w(TAG, exception); + if (exception instanceof RuntimeException) { + throw (RuntimeException)exception; + } else if (!job.onShouldRetry(exception)) { return JobResult.FAILURE; } else if (!job.isRequirementsMet()) { job.setRunIteration(runIteration+1); diff --git a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobManager.java b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobManager.java index 63e4071df1..4db4a77a59 100644 --- a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobManager.java +++ b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobManager.java @@ -26,6 +26,7 @@ import org.whispersystems.jobqueue.requirements.RequirementListener; import org.whispersystems.jobqueue.requirements.RequirementProvider; import java.io.IOException; +import java.util.Arrays; import java.util.List; import java.util.concurrent.Executor; import java.util.concurrent.Executors; @@ -41,10 +42,10 @@ public class JobManager implements RequirementListener { private final List requirementProviders; private final DependencyInjector dependencyInjector; - public JobManager(Context context, String name, - List requirementProviders, - DependencyInjector dependencyInjector, - JobSerializer jobSerializer, int consumers) + private JobManager(Context context, String name, + List requirementProviders, + DependencyInjector dependencyInjector, + JobSerializer jobSerializer, int consumers) { this.persistentStorage = new PersistentStorage(context, name, jobSerializer, dependencyInjector); this.requirementProviders = requirementProviders; @@ -63,6 +64,10 @@ public class JobManager implements RequirementListener { } } + public static Builder newBuilder(Context context) { + return new Builder(context); + } + public RequirementProvider getRequirementProvider(String name) { for (RequirementProvider provider : requirementProviders) { if (provider.getName().equals(name)) { @@ -131,4 +136,53 @@ public class JobManager implements RequirementListener { } } + public static class Builder { + private final Context context; + private String name; + private List requirementProviders; + private DependencyInjector dependencyInjector; + private JobSerializer jobSerializer; + private int consumerThreads; + + Builder(Context context) { + this.context = context; + this.consumerThreads = 5; + } + + public Builder withName(String name) { + this.name = name; + return this; + } + + public Builder withRequirementProviders(RequirementProvider... requirementProviders) { + this.requirementProviders = Arrays.asList(requirementProviders); + return this; + } + + public Builder withDependencyInjector(DependencyInjector dependencyInjector) { + this.dependencyInjector = dependencyInjector; + return this; + } + + public Builder withJobSerializer(JobSerializer jobSerializer) { + this.jobSerializer = jobSerializer; + return this; + } + + public Builder withConsumerThreads(int consumerThreads) { + this.consumerThreads = consumerThreads; + return this; + } + + public JobManager build() { + if (name == null) { + throw new IllegalArgumentException("You must specify a name!"); + } + + return new JobManager(context, name, requirementProviders, + dependencyInjector, jobSerializer, + consumerThreads); + } + } + } diff --git a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobQueue.java b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobQueue.java index 6218a31405..e8c031fc46 100644 --- a/jobqueue/src/main/java/org/whispersystems/jobqueue/JobQueue.java +++ b/jobqueue/src/main/java/org/whispersystems/jobqueue/JobQueue.java @@ -43,6 +43,10 @@ public class JobQueue { notifyAll(); } + synchronized void push(Job job) { + jobQueue.push(job); + } + public synchronized Job getNext() { try { Job nextAvailableJob; diff --git a/src/org/thoughtcrime/securesms/ApplicationContext.java b/src/org/thoughtcrime/securesms/ApplicationContext.java index 5cc6af2f0b..e82393fae6 100644 --- a/src/org/thoughtcrime/securesms/ApplicationContext.java +++ b/src/org/thoughtcrime/securesms/ApplicationContext.java @@ -22,18 +22,12 @@ import android.content.Context; import org.thoughtcrime.securesms.crypto.PRNGFixes; import org.thoughtcrime.securesms.dependencies.AxolotlStorageModule; import org.thoughtcrime.securesms.dependencies.InjectableType; -import org.thoughtcrime.securesms.jobs.persistence.EncryptingJobSerializer; -import org.thoughtcrime.securesms.jobs.GcmRefreshJob; -import org.thoughtcrime.securesms.jobs.requirements.MasterSecretRequirementProvider; import org.thoughtcrime.securesms.dependencies.TextSecureCommunicationModule; +import org.thoughtcrime.securesms.jobs.GcmRefreshJob; +import org.thoughtcrime.securesms.jobs.persistence.EncryptingJobSerializer; import org.thoughtcrime.securesms.util.TextSecurePreferences; import org.whispersystems.jobqueue.JobManager; import org.whispersystems.jobqueue.dependencies.DependencyInjector; -import org.whispersystems.jobqueue.requirements.NetworkRequirementProvider; -import org.whispersystems.jobqueue.requirements.RequirementProvider; - -import java.util.LinkedList; -import java.util.List; import dagger.ObjectGraph; @@ -79,13 +73,12 @@ public class ApplicationContext extends Application implements DependencyInjecto } private void initializeJobManager() { - List providers = new LinkedList() {{ - add(new NetworkRequirementProvider(ApplicationContext.this)); - add(new MasterSecretRequirementProvider(ApplicationContext.this)); - }}; - - this.jobManager = new JobManager(this, "TextSecureJobs", providers, this, - new EncryptingJobSerializer(this), 5); + this.jobManager = JobManager.newBuilder(this) + .withName("TextSecureJobs") + .withDependencyInjector(this) + .withJobSerializer(new EncryptingJobSerializer(this)) + .withConsumerThreads(5) + .build(); } private void initializeDependencyInjection() { diff --git a/src/org/thoughtcrime/securesms/jobs/AttachmentDownloadJob.java b/src/org/thoughtcrime/securesms/jobs/AttachmentDownloadJob.java index 1b578982c9..bf5f5ed205 100644 --- a/src/org/thoughtcrime/securesms/jobs/AttachmentDownloadJob.java +++ b/src/org/thoughtcrime/securesms/jobs/AttachmentDownloadJob.java @@ -77,8 +77,8 @@ public class AttachmentDownloadJob extends MasterSecretJob implements Injectable } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof PushNetworkException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof PushNetworkException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/AvatarDownloadJob.java b/src/org/thoughtcrime/securesms/jobs/AvatarDownloadJob.java index a638b63a84..f6d9725c66 100644 --- a/src/org/thoughtcrime/securesms/jobs/AvatarDownloadJob.java +++ b/src/org/thoughtcrime/securesms/jobs/AvatarDownloadJob.java @@ -91,8 +91,8 @@ public class AvatarDownloadJob extends MasterSecretJob { public void onCanceled() {} @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof IOException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof IOException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/CleanPreKeysJob.java b/src/org/thoughtcrime/securesms/jobs/CleanPreKeysJob.java index a475d3edda..4132572a56 100644 --- a/src/org/thoughtcrime/securesms/jobs/CleanPreKeysJob.java +++ b/src/org/thoughtcrime/securesms/jobs/CleanPreKeysJob.java @@ -84,7 +84,7 @@ public class CleanPreKeysJob extends MasterSecretJob implements InjectableType { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception throwable) { if (throwable instanceof NonSuccessfulResponseCodeException) return false; if (throwable instanceof PushNetworkException) return true; return false; diff --git a/src/org/thoughtcrime/securesms/jobs/CreateSignedPreKeyJob.java b/src/org/thoughtcrime/securesms/jobs/CreateSignedPreKeyJob.java index 4ce100e867..61b16eec5b 100644 --- a/src/org/thoughtcrime/securesms/jobs/CreateSignedPreKeyJob.java +++ b/src/org/thoughtcrime/securesms/jobs/CreateSignedPreKeyJob.java @@ -7,7 +7,6 @@ import org.thoughtcrime.securesms.crypto.IdentityKeyUtil; import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.crypto.PreKeyUtil; import org.thoughtcrime.securesms.dependencies.InjectableType; -import org.thoughtcrime.securesms.push.TextSecureCommunicationFactory; import org.thoughtcrime.securesms.util.ParcelUtil; import org.thoughtcrime.securesms.util.TextSecurePreferences; import org.whispersystems.jobqueue.EncryptionKeys; @@ -60,8 +59,8 @@ public class CreateSignedPreKeyJob extends ContextJob implements InjectableType public void onCanceled() {} @Override - public boolean onShouldRetry(Throwable throwable) { - if (throwable instanceof PushNetworkException) return true; + public boolean onShouldRetry(Exception exception) { + if (exception instanceof PushNetworkException) return true; return false; } } diff --git a/src/org/thoughtcrime/securesms/jobs/DeliveryReceiptJob.java b/src/org/thoughtcrime/securesms/jobs/DeliveryReceiptJob.java index 0db87f8fdb..857b83a5df 100644 --- a/src/org/thoughtcrime/securesms/jobs/DeliveryReceiptJob.java +++ b/src/org/thoughtcrime/securesms/jobs/DeliveryReceiptJob.java @@ -62,10 +62,10 @@ public class DeliveryReceiptJob extends ContextJob implements InjectableType { } @Override - public boolean onShouldRetry(Throwable throwable) { - Log.w(TAG, throwable); - if (throwable instanceof NonSuccessfulResponseCodeException) return false; - if (throwable instanceof PushNetworkException) return true; + public boolean onShouldRetry(Exception exception) { + Log.w(TAG, exception); + if (exception instanceof NonSuccessfulResponseCodeException) return false; + if (exception instanceof PushNetworkException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/GcmRefreshJob.java b/src/org/thoughtcrime/securesms/jobs/GcmRefreshJob.java index a9a559ad85..4a38585a68 100644 --- a/src/org/thoughtcrime/securesms/jobs/GcmRefreshJob.java +++ b/src/org/thoughtcrime/securesms/jobs/GcmRefreshJob.java @@ -56,7 +56,7 @@ public class GcmRefreshJob extends ContextJob { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception throwable) { if (throwable instanceof NonSuccessfulResponseCodeException) return false; return true; } diff --git a/src/org/thoughtcrime/securesms/jobs/MasterSecretJob.java b/src/org/thoughtcrime/securesms/jobs/MasterSecretJob.java index c477d16b94..7d10ba1207 100644 --- a/src/org/thoughtcrime/securesms/jobs/MasterSecretJob.java +++ b/src/org/thoughtcrime/securesms/jobs/MasterSecretJob.java @@ -13,19 +13,19 @@ public abstract class MasterSecretJob extends ContextJob { } @Override - public void onRun() throws Throwable { + public void onRun() throws Exception { MasterSecret masterSecret = getMasterSecret(); onRun(masterSecret); } @Override - public boolean onShouldRetry(Throwable throwable) { - if (throwable instanceof RequirementNotMetException) return true; - return onShouldRetryThrowable(throwable); + public boolean onShouldRetry(Exception exception) { + if (exception instanceof RequirementNotMetException) return true; + return onShouldRetryThrowable(exception); } - public abstract void onRun(MasterSecret masterSecret) throws Throwable; - public abstract boolean onShouldRetryThrowable(Throwable throwable); + public abstract void onRun(MasterSecret masterSecret) throws Exception; + public abstract boolean onShouldRetryThrowable(Exception exception); private MasterSecret getMasterSecret() throws RequirementNotMetException { MasterSecret masterSecret = KeyCachingService.getMasterSecret(context); diff --git a/src/org/thoughtcrime/securesms/jobs/MmsDownloadJob.java b/src/org/thoughtcrime/securesms/jobs/MmsDownloadJob.java index b90f12833d..0c6118d17b 100644 --- a/src/org/thoughtcrime/securesms/jobs/MmsDownloadJob.java +++ b/src/org/thoughtcrime/securesms/jobs/MmsDownloadJob.java @@ -179,7 +179,7 @@ public class MmsDownloadJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/MmsReceiveJob.java b/src/org/thoughtcrime/securesms/jobs/MmsReceiveJob.java index af1401a0c7..9107a51fb4 100644 --- a/src/org/thoughtcrime/securesms/jobs/MmsReceiveJob.java +++ b/src/org/thoughtcrime/securesms/jobs/MmsReceiveJob.java @@ -63,7 +63,7 @@ public class MmsReceiveJob extends ContextJob { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception exception) { return false; } } diff --git a/src/org/thoughtcrime/securesms/jobs/MmsSendJob.java b/src/org/thoughtcrime/securesms/jobs/MmsSendJob.java index 6b7521982c..a032bfad42 100644 --- a/src/org/thoughtcrime/securesms/jobs/MmsSendJob.java +++ b/src/org/thoughtcrime/securesms/jobs/MmsSendJob.java @@ -84,7 +84,7 @@ public class MmsSendJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java b/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java index b98a984981..49b0098bc3 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java @@ -78,7 +78,7 @@ public class PushDecryptJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/PushGroupSendJob.java b/src/org/thoughtcrime/securesms/jobs/PushGroupSendJob.java index dcac734331..81f740bf83 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushGroupSendJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushGroupSendJob.java @@ -97,8 +97,8 @@ public class PushGroupSendJob extends PushSendJob implements InjectableType { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof IOException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof IOException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/PushMediaSendJob.java b/src/org/thoughtcrime/securesms/jobs/PushMediaSendJob.java index 5735078cef..f638e8c209 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushMediaSendJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushMediaSendJob.java @@ -86,8 +86,8 @@ public class PushMediaSendJob extends PushSendJob implements InjectableType { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof RequirementNotMetException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof RequirementNotMetException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/PushReceiveJob.java b/src/org/thoughtcrime/securesms/jobs/PushReceiveJob.java index 8ee5370b6c..a91f36123a 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushReceiveJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushReceiveJob.java @@ -60,7 +60,7 @@ public class PushReceiveJob extends ContextJob { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/PushTextSendJob.java b/src/org/thoughtcrime/securesms/jobs/PushTextSendJob.java index 76181df937..e00a5edf65 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushTextSendJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushTextSendJob.java @@ -82,8 +82,8 @@ public class PushTextSendJob extends PushSendJob implements InjectableType { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof RetryLaterException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof RetryLaterException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/RefreshPreKeysJob.java b/src/org/thoughtcrime/securesms/jobs/RefreshPreKeysJob.java index 156f6eb76f..d7f7db4cc0 100644 --- a/src/org/thoughtcrime/securesms/jobs/RefreshPreKeysJob.java +++ b/src/org/thoughtcrime/securesms/jobs/RefreshPreKeysJob.java @@ -9,7 +9,6 @@ import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.crypto.PreKeyUtil; import org.thoughtcrime.securesms.dependencies.InjectableType; import org.thoughtcrime.securesms.jobs.requirements.MasterSecretRequirement; -import org.thoughtcrime.securesms.push.TextSecureCommunicationFactory; import org.thoughtcrime.securesms.util.TextSecurePreferences; import org.whispersystems.jobqueue.JobParameters; import org.whispersystems.jobqueue.requirements.NetworkRequirement; @@ -17,7 +16,6 @@ import org.whispersystems.libaxolotl.IdentityKeyPair; import org.whispersystems.libaxolotl.state.PreKeyRecord; import org.whispersystems.libaxolotl.state.SignedPreKeyRecord; import org.whispersystems.textsecure.api.TextSecureAccountManager; -import org.whispersystems.textsecure.push.PushServiceSocket; import org.whispersystems.textsecure.push.exceptions.NonSuccessfulResponseCodeException; import org.whispersystems.textsecure.push.exceptions.PushNetworkException; @@ -76,9 +74,9 @@ public class RefreshPreKeysJob extends MasterSecretJob implements InjectableType } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { - if (throwable instanceof NonSuccessfulResponseCodeException) return false; - if (throwable instanceof PushNetworkException) return true; + public boolean onShouldRetryThrowable(Exception exception) { + if (exception instanceof NonSuccessfulResponseCodeException) return false; + if (exception instanceof PushNetworkException) return true; return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/SmsDecryptJob.java b/src/org/thoughtcrime/securesms/jobs/SmsDecryptJob.java index 3294841713..bd8f343654 100644 --- a/src/org/thoughtcrime/securesms/jobs/SmsDecryptJob.java +++ b/src/org/thoughtcrime/securesms/jobs/SmsDecryptJob.java @@ -5,15 +5,14 @@ import android.util.Log; import org.thoughtcrime.securesms.crypto.AsymmetricMasterCipher; import org.thoughtcrime.securesms.crypto.AsymmetricMasterSecret; -import org.thoughtcrime.securesms.crypto.SecurityEvent; import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.crypto.MasterSecretUtil; +import org.thoughtcrime.securesms.crypto.SecurityEvent; import org.thoughtcrime.securesms.crypto.SmsCipher; import org.thoughtcrime.securesms.crypto.storage.TextSecureAxolotlStore; import org.thoughtcrime.securesms.database.DatabaseFactory; import org.thoughtcrime.securesms.database.EncryptingSmsDatabase; import org.thoughtcrime.securesms.database.NoSuchMessageException; -import org.thoughtcrime.securesms.database.SmsDatabase; import org.thoughtcrime.securesms.database.model.SmsMessageRecord; import org.thoughtcrime.securesms.jobs.requirements.MasterSecretRequirement; import org.thoughtcrime.securesms.notifications.MessageNotifier; @@ -94,7 +93,7 @@ public class SmsDecryptJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/SmsReceiveJob.java b/src/org/thoughtcrime/securesms/jobs/SmsReceiveJob.java index 2a8731e1f2..69be005ade 100644 --- a/src/org/thoughtcrime/securesms/jobs/SmsReceiveJob.java +++ b/src/org/thoughtcrime/securesms/jobs/SmsReceiveJob.java @@ -55,7 +55,7 @@ public class SmsReceiveJob extends ContextJob { } @Override - public boolean onShouldRetry(Throwable throwable) { + public boolean onShouldRetry(Exception exception) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/SmsSendJob.java b/src/org/thoughtcrime/securesms/jobs/SmsSendJob.java index 3895d1c5de..905950ff8a 100644 --- a/src/org/thoughtcrime/securesms/jobs/SmsSendJob.java +++ b/src/org/thoughtcrime/securesms/jobs/SmsSendJob.java @@ -73,7 +73,7 @@ public class SmsSendJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception throwable) { return false; } diff --git a/src/org/thoughtcrime/securesms/jobs/SmsSentJob.java b/src/org/thoughtcrime/securesms/jobs/SmsSentJob.java index 3bcbdfc390..322e721951 100644 --- a/src/org/thoughtcrime/securesms/jobs/SmsSentJob.java +++ b/src/org/thoughtcrime/securesms/jobs/SmsSentJob.java @@ -58,7 +58,7 @@ public class SmsSentJob extends MasterSecretJob { } @Override - public boolean onShouldRetryThrowable(Throwable throwable) { + public boolean onShouldRetryThrowable(Exception throwable) { return false; }