2018-06-18 19:27:04 +00:00
|
|
|
/**
|
|
|
|
* Copyright (C) 2014 Open Whisper Systems
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
package org.thoughtcrime.securesms.jobmanager;
|
|
|
|
|
|
|
|
import org.thoughtcrime.securesms.jobmanager.requirements.Requirement;
|
|
|
|
|
|
|
|
import java.io.Serializable;
|
|
|
|
import java.util.LinkedList;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The set of parameters that describe a {@link org.thoughtcrime.securesms.jobmanager.Job}.
|
|
|
|
*/
|
|
|
|
public class JobParameters implements Serializable {
|
|
|
|
|
2018-06-20 02:22:39 +00:00
|
|
|
private static final long serialVersionUID = 4880456378402584584L;
|
|
|
|
|
2018-06-18 19:27:04 +00:00
|
|
|
private transient EncryptionKeys encryptionKeys;
|
|
|
|
|
|
|
|
private final List<Requirement> requirements;
|
|
|
|
private final boolean isPersistent;
|
|
|
|
private final int retryCount;
|
2018-06-20 02:22:39 +00:00
|
|
|
private final long retryUntil;
|
2018-06-18 19:27:04 +00:00
|
|
|
private final String groupId;
|
|
|
|
private final boolean wakeLock;
|
|
|
|
private final long wakeLockTimeout;
|
|
|
|
|
|
|
|
private JobParameters(List<Requirement> requirements,
|
2018-06-20 02:22:39 +00:00
|
|
|
boolean isPersistent, String groupId,
|
|
|
|
EncryptionKeys encryptionKeys,
|
|
|
|
int retryCount, long retryUntil, boolean wakeLock,
|
|
|
|
long wakeLockTimeout)
|
2018-06-18 19:27:04 +00:00
|
|
|
{
|
|
|
|
this.requirements = requirements;
|
|
|
|
this.isPersistent = isPersistent;
|
|
|
|
this.groupId = groupId;
|
|
|
|
this.encryptionKeys = encryptionKeys;
|
|
|
|
this.retryCount = retryCount;
|
2018-06-20 02:22:39 +00:00
|
|
|
this.retryUntil = retryUntil;
|
2018-06-18 19:27:04 +00:00
|
|
|
this.wakeLock = wakeLock;
|
|
|
|
this.wakeLockTimeout = wakeLockTimeout;
|
|
|
|
}
|
|
|
|
|
|
|
|
public List<Requirement> getRequirements() {
|
|
|
|
return requirements;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isPersistent() {
|
|
|
|
return isPersistent;
|
|
|
|
}
|
|
|
|
|
|
|
|
public EncryptionKeys getEncryptionKeys() {
|
|
|
|
return encryptionKeys;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setEncryptionKeys(EncryptionKeys encryptionKeys) {
|
|
|
|
this.encryptionKeys = encryptionKeys;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getRetryCount() {
|
|
|
|
return retryCount;
|
|
|
|
}
|
|
|
|
|
2018-06-20 02:22:39 +00:00
|
|
|
public long getRetryUntil() {
|
|
|
|
return retryUntil;
|
|
|
|
}
|
|
|
|
|
2018-06-18 19:27:04 +00:00
|
|
|
/**
|
|
|
|
* @return a builder used to construct JobParameters.
|
|
|
|
*/
|
|
|
|
public static Builder newBuilder() {
|
|
|
|
return new Builder();
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getGroupId() {
|
|
|
|
return groupId;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean needsWakeLock() {
|
|
|
|
return wakeLock;
|
|
|
|
}
|
|
|
|
|
|
|
|
public long getWakeLockTimeout() {
|
|
|
|
return wakeLockTimeout;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class Builder {
|
|
|
|
private List<Requirement> requirements = new LinkedList<>();
|
|
|
|
private boolean isPersistent = false;
|
|
|
|
private EncryptionKeys encryptionKeys = null;
|
|
|
|
private int retryCount = 100;
|
2018-06-20 02:22:39 +00:00
|
|
|
private long retryDuration = 0;
|
2018-06-18 19:27:04 +00:00
|
|
|
private String groupId = null;
|
|
|
|
private boolean wakeLock = false;
|
|
|
|
private long wakeLockTimeout = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify a {@link org.thoughtcrime.securesms.jobmanager.requirements.Requirement }that must be met
|
|
|
|
* before the Job is executed. May be called multiple times to register multiple requirements.
|
|
|
|
* @param requirement The Requirement that must be met.
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withRequirement(Requirement requirement) {
|
|
|
|
this.requirements.add(requirement);
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify that the Job should be durably persisted to disk, so that it remains in the queue
|
|
|
|
* across application restarts.
|
|
|
|
* @return The builder.
|
|
|
|
*/
|
|
|
|
public Builder withPersistence() {
|
|
|
|
this.isPersistent = true;
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify that the job should use encryption when durably persisted to disk.
|
|
|
|
* @param encryptionKeys The keys to encrypt the serialized job with before persisting.
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withEncryption(EncryptionKeys encryptionKeys) {
|
|
|
|
this.encryptionKeys = encryptionKeys;
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify how many times the job should be retried if execution fails but onShouldRetry() returns
|
|
|
|
* true.
|
|
|
|
*
|
|
|
|
* @param retryCount The number of times the job should be retried.
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withRetryCount(int retryCount) {
|
2018-06-20 02:22:39 +00:00
|
|
|
this.retryCount = retryCount;
|
|
|
|
this.retryDuration = 0;
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Builder withRetryDuration(long duration) {
|
|
|
|
this.retryDuration = duration;
|
|
|
|
this.retryCount = 0;
|
2018-06-18 19:27:04 +00:00
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify a groupId the job should belong to. Jobs with the same groupId are guaranteed to be
|
|
|
|
* executed serially.
|
|
|
|
*
|
|
|
|
* @param groupId The job's groupId.
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withGroupId(String groupId) {
|
|
|
|
this.groupId = groupId;
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify whether this job should hold a wake lock.
|
|
|
|
*
|
|
|
|
* @param needsWakeLock If set, this job will acquire a wakelock on add(), and hold it until
|
|
|
|
* run() completes, or cancel().
|
|
|
|
* @param timeout Specify a timeout for the wakelock. A timeout of
|
|
|
|
* 0 will result in no timeout.
|
|
|
|
*
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withWakeLock(boolean needsWakeLock, long timeout, TimeUnit unit) {
|
|
|
|
this.wakeLock = needsWakeLock;
|
|
|
|
this.wakeLockTimeout = unit.toMillis(timeout);
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify whether this job should hold a wake lock.
|
|
|
|
*
|
|
|
|
* @return the builder.
|
|
|
|
*/
|
|
|
|
public Builder withWakeLock(boolean needsWakeLock) {
|
|
|
|
return withWakeLock(needsWakeLock, 0, TimeUnit.MILLISECONDS);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the JobParameters instance that describes a Job.
|
|
|
|
*/
|
|
|
|
public JobParameters create() {
|
2018-06-20 02:22:39 +00:00
|
|
|
return new JobParameters(requirements, isPersistent, groupId, encryptionKeys, retryCount, System.currentTimeMillis() + retryDuration, wakeLock, wakeLockTimeout);
|
2018-06-18 19:27:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|