2014-11-03 15:16:04 -08:00
|
|
|
package org.thoughtcrime.securesms.jobs;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
import android.util.Log;
|
|
|
|
|
|
|
|
import org.thoughtcrime.securesms.ApplicationContext;
|
|
|
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
|
|
|
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
|
|
|
import org.whispersystems.jobqueue.JobManager;
|
|
|
|
import org.whispersystems.jobqueue.JobParameters;
|
|
|
|
import org.whispersystems.libaxolotl.InvalidVersionException;
|
2014-11-04 15:01:32 -08:00
|
|
|
import org.whispersystems.textsecure.api.messages.TextSecureEnvelope;
|
2014-11-09 20:35:08 -08:00
|
|
|
import org.thoughtcrime.securesms.database.TextSecureDirectory;
|
|
|
|
import org.thoughtcrime.securesms.database.NotInDirectoryException;
|
2014-11-12 11:35:54 -08:00
|
|
|
import org.whispersystems.textsecure.api.push.ContactTokenDetails;
|
2014-11-03 15:16:04 -08:00
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
|
|
|
public class PushReceiveJob extends ContextJob {
|
|
|
|
|
|
|
|
private static final String TAG = PushReceiveJob.class.getSimpleName();
|
|
|
|
|
|
|
|
private final String data;
|
|
|
|
|
2015-01-25 17:43:24 -08:00
|
|
|
public PushReceiveJob(Context context) {
|
|
|
|
super(context, JobParameters.newBuilder().create());
|
|
|
|
this.data = null;
|
|
|
|
}
|
|
|
|
|
2014-11-03 15:16:04 -08:00
|
|
|
public PushReceiveJob(Context context, String data) {
|
|
|
|
super(context, JobParameters.newBuilder()
|
|
|
|
.withPersistence()
|
2015-03-18 14:25:27 -07:00
|
|
|
.withWakeLock(true)
|
2014-11-03 15:16:04 -08:00
|
|
|
.create());
|
|
|
|
|
|
|
|
this.data = data;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onAdded() {}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onRun() {
|
|
|
|
try {
|
2014-11-04 15:01:32 -08:00
|
|
|
String sessionKey = TextSecurePreferences.getSignalingKey(context);
|
|
|
|
TextSecureEnvelope envelope = new TextSecureEnvelope(data, sessionKey);
|
2014-11-03 15:16:04 -08:00
|
|
|
|
2015-01-25 17:43:24 -08:00
|
|
|
handle(envelope, true);
|
2014-11-03 15:16:04 -08:00
|
|
|
} catch (IOException | InvalidVersionException e) {
|
|
|
|
Log.w(TAG, e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onCanceled() {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-11-11 21:11:57 -08:00
|
|
|
public boolean onShouldRetry(Exception exception) {
|
2014-11-03 15:16:04 -08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2015-01-25 17:43:24 -08:00
|
|
|
public void handle(TextSecureEnvelope envelope, boolean sendExplicitReceipt) {
|
|
|
|
if (!isActiveNumber(context, envelope.getSource())) {
|
|
|
|
TextSecureDirectory directory = TextSecureDirectory.getInstance(context);
|
|
|
|
ContactTokenDetails contactTokenDetails = new ContactTokenDetails();
|
|
|
|
contactTokenDetails.setNumber(envelope.getSource());
|
|
|
|
|
|
|
|
directory.setNumber(contactTokenDetails, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (envelope.isReceipt()) handleReceipt(envelope);
|
|
|
|
else handleMessage(envelope, sendExplicitReceipt);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void handleMessage(TextSecureEnvelope envelope, boolean sendExplicitReceipt) {
|
2014-11-03 15:16:04 -08:00
|
|
|
JobManager jobManager = ApplicationContext.getInstance(context).getJobManager();
|
2014-11-04 15:01:32 -08:00
|
|
|
long messageId = DatabaseFactory.getPushDatabase(context).insert(envelope);
|
2014-11-03 15:16:04 -08:00
|
|
|
|
2015-01-25 17:43:24 -08:00
|
|
|
if (sendExplicitReceipt) {
|
|
|
|
jobManager.add(new DeliveryReceiptJob(context, envelope.getSource(),
|
|
|
|
envelope.getTimestamp(),
|
|
|
|
envelope.getRelay()));
|
|
|
|
}
|
2014-11-03 15:16:04 -08:00
|
|
|
|
2015-02-23 09:53:32 -08:00
|
|
|
jobManager.add(new PushDecryptJob(context, messageId, envelope.getSource()));
|
2014-11-03 15:16:04 -08:00
|
|
|
}
|
|
|
|
|
2014-11-04 15:01:32 -08:00
|
|
|
private void handleReceipt(TextSecureEnvelope envelope) {
|
|
|
|
Log.w(TAG, String.format("Received receipt: (XXXXX, %d)", envelope.getTimestamp()));
|
|
|
|
DatabaseFactory.getMmsSmsDatabase(context).incrementDeliveryReceiptCount(envelope.getSource(),
|
|
|
|
envelope.getTimestamp());
|
2014-11-03 15:16:04 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
private boolean isActiveNumber(Context context, String e164number) {
|
|
|
|
boolean isActiveNumber;
|
|
|
|
|
|
|
|
try {
|
2014-11-09 20:35:08 -08:00
|
|
|
isActiveNumber = TextSecureDirectory.getInstance(context).isActiveNumber(e164number);
|
2014-11-03 15:16:04 -08:00
|
|
|
} catch (NotInDirectoryException e) {
|
|
|
|
isActiveNumber = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return isActiveNumber;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|