kopia lustrzana https://github.com/ryukoposting/Signal-Android
Removed RefreshUnidentifiedDeliveryAvailabilityJob.
It's been long enough -- it's no longer necessary to check. Also, the service is going to start returning certs no matter what, so at this point it's just an unnecessary network call.fork-5.53.8
rodzic
6108a32631
commit
c837d590ab
|
@ -37,28 +37,21 @@ import org.signal.aesgcmprovider.AesGcmProvider;
|
||||||
import org.signal.ringrtc.CallConnectionFactory;
|
import org.signal.ringrtc.CallConnectionFactory;
|
||||||
import org.thoughtcrime.securesms.components.TypingStatusRepository;
|
import org.thoughtcrime.securesms.components.TypingStatusRepository;
|
||||||
import org.thoughtcrime.securesms.components.TypingStatusSender;
|
import org.thoughtcrime.securesms.components.TypingStatusSender;
|
||||||
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
|
||||||
import org.thoughtcrime.securesms.database.helpers.SQLCipherOpenHelper;
|
import org.thoughtcrime.securesms.database.helpers.SQLCipherOpenHelper;
|
||||||
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
||||||
import org.thoughtcrime.securesms.dependencies.ApplicationDependencyProvider;
|
import org.thoughtcrime.securesms.dependencies.ApplicationDependencyProvider;
|
||||||
import org.thoughtcrime.securesms.gcm.FcmJobService;
|
import org.thoughtcrime.securesms.gcm.FcmJobService;
|
||||||
import org.thoughtcrime.securesms.insights.InsightsOptOut;
|
import org.thoughtcrime.securesms.insights.InsightsOptOut;
|
||||||
import org.thoughtcrime.securesms.jobmanager.JobManager;
|
import org.thoughtcrime.securesms.jobmanager.JobManager;
|
||||||
import org.thoughtcrime.securesms.jobmanager.JobMigrator;
|
|
||||||
import org.thoughtcrime.securesms.jobmanager.impl.JsonDataSerializer;
|
|
||||||
import org.thoughtcrime.securesms.jobs.CreateSignedPreKeyJob;
|
import org.thoughtcrime.securesms.jobs.CreateSignedPreKeyJob;
|
||||||
import org.thoughtcrime.securesms.jobs.FastJobStorage;
|
|
||||||
import org.thoughtcrime.securesms.jobs.FcmRefreshJob;
|
import org.thoughtcrime.securesms.jobs.FcmRefreshJob;
|
||||||
import org.thoughtcrime.securesms.jobs.JobManagerFactories;
|
|
||||||
import org.thoughtcrime.securesms.jobs.MultiDeviceContactUpdateJob;
|
import org.thoughtcrime.securesms.jobs.MultiDeviceContactUpdateJob;
|
||||||
import org.thoughtcrime.securesms.jobs.PushNotificationReceiveJob;
|
import org.thoughtcrime.securesms.jobs.PushNotificationReceiveJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RefreshUnidentifiedDeliveryAbilityJob;
|
|
||||||
import org.thoughtcrime.securesms.logging.AndroidLogger;
|
import org.thoughtcrime.securesms.logging.AndroidLogger;
|
||||||
import org.thoughtcrime.securesms.logging.CustomSignalProtocolLogger;
|
import org.thoughtcrime.securesms.logging.CustomSignalProtocolLogger;
|
||||||
import org.thoughtcrime.securesms.logging.Log;
|
import org.thoughtcrime.securesms.logging.Log;
|
||||||
import org.thoughtcrime.securesms.logging.PersistentLogger;
|
import org.thoughtcrime.securesms.logging.PersistentLogger;
|
||||||
import org.thoughtcrime.securesms.logging.UncaughtExceptionLogger;
|
import org.thoughtcrime.securesms.logging.UncaughtExceptionLogger;
|
||||||
import org.thoughtcrime.securesms.mediasend.LegacyCameraModels;
|
|
||||||
import org.thoughtcrime.securesms.mediasend.camerax.CameraXUtil;
|
import org.thoughtcrime.securesms.mediasend.camerax.CameraXUtil;
|
||||||
import org.thoughtcrime.securesms.migrations.ApplicationMigrations;
|
import org.thoughtcrime.securesms.migrations.ApplicationMigrations;
|
||||||
import org.thoughtcrime.securesms.notifications.MessageNotifier;
|
import org.thoughtcrime.securesms.notifications.MessageNotifier;
|
||||||
|
@ -76,7 +69,6 @@ import org.thoughtcrime.securesms.service.RotateSenderCertificateListener;
|
||||||
import org.thoughtcrime.securesms.service.RotateSignedPreKeyListener;
|
import org.thoughtcrime.securesms.service.RotateSignedPreKeyListener;
|
||||||
import org.thoughtcrime.securesms.service.UpdateApkRefreshListener;
|
import org.thoughtcrime.securesms.service.UpdateApkRefreshListener;
|
||||||
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
||||||
import org.thoughtcrime.securesms.util.VersionTracker;
|
|
||||||
import org.thoughtcrime.securesms.util.dynamiclanguage.DynamicLanguageContextWrapper;
|
import org.thoughtcrime.securesms.util.dynamiclanguage.DynamicLanguageContextWrapper;
|
||||||
import org.webrtc.voiceengine.WebRtcAudioManager;
|
import org.webrtc.voiceengine.WebRtcAudioManager;
|
||||||
import org.webrtc.voiceengine.WebRtcAudioUtils;
|
import org.webrtc.voiceengine.WebRtcAudioUtils;
|
||||||
|
@ -133,7 +125,6 @@ public class ApplicationContext extends MultiDexApplication implements DefaultLi
|
||||||
initializeCircumvention();
|
initializeCircumvention();
|
||||||
initializeRingRtc();
|
initializeRingRtc();
|
||||||
initializePendingMessages();
|
initializePendingMessages();
|
||||||
initializeUnidentifiedDeliveryAbilityRefresh();
|
|
||||||
initializeBlobProvider();
|
initializeBlobProvider();
|
||||||
initializeCameraX();
|
initializeCameraX();
|
||||||
NotificationChannels.create(this);
|
NotificationChannels.create(this);
|
||||||
|
@ -365,12 +356,6 @@ public class ApplicationContext extends MultiDexApplication implements DefaultLi
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initializeUnidentifiedDeliveryAbilityRefresh() {
|
|
||||||
if (TextSecurePreferences.isMultiDevice(this) && !TextSecurePreferences.isUnidentifiedDeliveryEnabled(this)) {
|
|
||||||
ApplicationDependencies.getJobManager().add(new RefreshUnidentifiedDeliveryAbilityJob());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initializeBlobProvider() {
|
private void initializeBlobProvider() {
|
||||||
AsyncTask.THREAD_POOL_EXECUTOR.execute(() -> {
|
AsyncTask.THREAD_POOL_EXECUTOR.execute(() -> {
|
||||||
BlobProvider.getInstance().onSessionStart(this);
|
BlobProvider.getInstance().onSessionStart(this);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package org.thoughtcrime.securesms;
|
package org.thoughtcrime.securesms;
|
||||||
|
|
||||||
|
import android.annotation.SuppressLint;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
|
@ -13,7 +14,6 @@ import androidx.appcompat.app.AlertDialog;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
||||||
import org.thoughtcrime.securesms.devicelist.Device;
|
import org.thoughtcrime.securesms.devicelist.Device;
|
||||||
import org.thoughtcrime.securesms.jobs.RefreshUnidentifiedDeliveryAbilityJob;
|
|
||||||
import org.thoughtcrime.securesms.logging.Log;
|
import org.thoughtcrime.securesms.logging.Log;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
@ -162,6 +162,7 @@ public class DeviceListFragment extends ListFragment
|
||||||
builder.show();
|
builder.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressLint("StaticFieldLeak")
|
||||||
private void handleDisconnectDevice(final long deviceId) {
|
private void handleDisconnectDevice(final long deviceId) {
|
||||||
new ProgressDialogAsyncTask<Void, Void, Void>(getActivity(),
|
new ProgressDialogAsyncTask<Void, Void, Void>(getActivity(),
|
||||||
R.string.DeviceListActivity_unlinking_device_no_ellipsis,
|
R.string.DeviceListActivity_unlinking_device_no_ellipsis,
|
||||||
|
@ -171,7 +172,6 @@ public class DeviceListFragment extends ListFragment
|
||||||
protected Void doInBackground(Void... params) {
|
protected Void doInBackground(Void... params) {
|
||||||
try {
|
try {
|
||||||
accountManager.removeDevice(deviceId);
|
accountManager.removeDevice(deviceId);
|
||||||
ApplicationDependencies.getJobManager().add(new RefreshUnidentifiedDeliveryAbilityJob());
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.w(TAG, e);
|
Log.w(TAG, e);
|
||||||
Toast.makeText(getActivity(), R.string.DeviceListActivity_network_failed, Toast.LENGTH_LONG).show();
|
Toast.makeText(getActivity(), R.string.DeviceListActivity_network_failed, Toast.LENGTH_LONG).show();
|
||||||
|
|
|
@ -40,11 +40,6 @@ public class UnidentifiedAccessUtil {
|
||||||
public static Optional<UnidentifiedAccessPair> getAccessFor(@NonNull Context context,
|
public static Optional<UnidentifiedAccessPair> getAccessFor(@NonNull Context context,
|
||||||
@NonNull Recipient recipient)
|
@NonNull Recipient recipient)
|
||||||
{
|
{
|
||||||
if (!TextSecurePreferences.isUnidentifiedDeliveryEnabled(context)) {
|
|
||||||
Log.i(TAG, "Unidentified delivery is disabled. [other]");
|
|
||||||
return Optional.absent();
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
byte[] theirUnidentifiedAccessKey = getTargetUnidentifiedAccessKey(recipient);
|
byte[] theirUnidentifiedAccessKey = getTargetUnidentifiedAccessKey(recipient);
|
||||||
byte[] ourUnidentifiedAccessKey = getSelfUnidentifiedAccessKey(context);
|
byte[] ourUnidentifiedAccessKey = getSelfUnidentifiedAccessKey(context);
|
||||||
|
@ -79,11 +74,6 @@ public class UnidentifiedAccessUtil {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<UnidentifiedAccessPair> getAccessForSync(@NonNull Context context) {
|
public static Optional<UnidentifiedAccessPair> getAccessForSync(@NonNull Context context) {
|
||||||
if (!TextSecurePreferences.isUnidentifiedDeliveryEnabled(context)) {
|
|
||||||
Log.i(TAG, "Unidentified delivery is disabled. [self]");
|
|
||||||
return Optional.absent();
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
byte[] ourUnidentifiedAccessKey = getSelfUnidentifiedAccessKey(context);
|
byte[] ourUnidentifiedAccessKey = getSelfUnidentifiedAccessKey(context);
|
||||||
byte[] ourUnidentifiedAccessCertificate = Recipient.self().isUuidSupported() ? TextSecurePreferences.getUnidentifiedAccessCertificate(context)
|
byte[] ourUnidentifiedAccessCertificate = Recipient.self().isUuidSupported() ? TextSecurePreferences.getUnidentifiedAccessCertificate(context)
|
||||||
|
|
|
@ -30,7 +30,6 @@ import org.thoughtcrime.securesms.jobs.PushNotificationReceiveJob;
|
||||||
import org.thoughtcrime.securesms.jobs.PushTextSendJob;
|
import org.thoughtcrime.securesms.jobs.PushTextSendJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RefreshAttributesJob;
|
import org.thoughtcrime.securesms.jobs.RefreshAttributesJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RefreshPreKeysJob;
|
import org.thoughtcrime.securesms.jobs.RefreshPreKeysJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RefreshUnidentifiedDeliveryAbilityJob;
|
|
||||||
import org.thoughtcrime.securesms.jobs.RequestGroupInfoJob;
|
import org.thoughtcrime.securesms.jobs.RequestGroupInfoJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RetrieveProfileAvatarJob;
|
import org.thoughtcrime.securesms.jobs.RetrieveProfileAvatarJob;
|
||||||
import org.thoughtcrime.securesms.jobs.RetrieveProfileJob;
|
import org.thoughtcrime.securesms.jobs.RetrieveProfileJob;
|
||||||
|
@ -80,7 +79,7 @@ public class WorkManagerFactoryMappings {
|
||||||
put(PushTextSendJob.class.getName(), PushTextSendJob.KEY);
|
put(PushTextSendJob.class.getName(), PushTextSendJob.KEY);
|
||||||
put(RefreshAttributesJob.class.getName(), RefreshAttributesJob.KEY);
|
put(RefreshAttributesJob.class.getName(), RefreshAttributesJob.KEY);
|
||||||
put(RefreshPreKeysJob.class.getName(), RefreshPreKeysJob.KEY);
|
put(RefreshPreKeysJob.class.getName(), RefreshPreKeysJob.KEY);
|
||||||
put(RefreshUnidentifiedDeliveryAbilityJob.class.getName(), RefreshUnidentifiedDeliveryAbilityJob.KEY);
|
put("RefreshUnidentifiedDeliveryAbilityJob", FailingJob.KEY);
|
||||||
put(RequestGroupInfoJob.class.getName(), RequestGroupInfoJob.KEY);
|
put(RequestGroupInfoJob.class.getName(), RequestGroupInfoJob.KEY);
|
||||||
put(RetrieveProfileAvatarJob.class.getName(), RetrieveProfileAvatarJob.KEY);
|
put(RetrieveProfileAvatarJob.class.getName(), RetrieveProfileAvatarJob.KEY);
|
||||||
put(RetrieveProfileJob.class.getName(), RetrieveProfileJob.KEY);
|
put(RetrieveProfileJob.class.getName(), RetrieveProfileJob.KEY);
|
||||||
|
|
|
@ -67,7 +67,6 @@ public final class JobManagerFactories {
|
||||||
put(RefreshAttributesJob.KEY, new RefreshAttributesJob.Factory());
|
put(RefreshAttributesJob.KEY, new RefreshAttributesJob.Factory());
|
||||||
put(RefreshOwnProfileJob.KEY, new RefreshOwnProfileJob.Factory());
|
put(RefreshOwnProfileJob.KEY, new RefreshOwnProfileJob.Factory());
|
||||||
put(RefreshPreKeysJob.KEY, new RefreshPreKeysJob.Factory());
|
put(RefreshPreKeysJob.KEY, new RefreshPreKeysJob.Factory());
|
||||||
put(RefreshUnidentifiedDeliveryAbilityJob.KEY, new RefreshUnidentifiedDeliveryAbilityJob.Factory());
|
|
||||||
put(RequestGroupInfoJob.KEY, new RequestGroupInfoJob.Factory());
|
put(RequestGroupInfoJob.KEY, new RequestGroupInfoJob.Factory());
|
||||||
put(RetrieveProfileAvatarJob.KEY, new RetrieveProfileAvatarJob.Factory());
|
put(RetrieveProfileAvatarJob.KEY, new RetrieveProfileAvatarJob.Factory());
|
||||||
put(RetrieveProfileJob.KEY, new RetrieveProfileJob.Factory());
|
put(RetrieveProfileJob.KEY, new RetrieveProfileJob.Factory());
|
||||||
|
@ -99,6 +98,7 @@ public final class JobManagerFactories {
|
||||||
put("PushContentReceiveJob", new FailingJob.Factory());
|
put("PushContentReceiveJob", new FailingJob.Factory());
|
||||||
put("AttachmentUploadJob", new FailingJob.Factory());
|
put("AttachmentUploadJob", new FailingJob.Factory());
|
||||||
put("MmsSendJob", new FailingJob.Factory());
|
put("MmsSendJob", new FailingJob.Factory());
|
||||||
|
put("RefreshUnidentifiedDeliveryAbilityJob", new FailingJob.Factory());
|
||||||
}};
|
}};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -632,7 +632,6 @@ public class PushDecryptJob extends BaseJob {
|
||||||
{
|
{
|
||||||
if (message.isContactsRequest()) {
|
if (message.isContactsRequest()) {
|
||||||
ApplicationDependencies.getJobManager().add(new MultiDeviceContactUpdateJob(true));
|
ApplicationDependencies.getJobManager().add(new MultiDeviceContactUpdateJob(true));
|
||||||
ApplicationDependencies.getJobManager().add(new RefreshUnidentifiedDeliveryAbilityJob());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (message.isGroupsRequest()) {
|
if (message.isGroupsRequest()) {
|
||||||
|
|
|
@ -133,17 +133,15 @@ public class PushMediaSendJob extends PushSendJob {
|
||||||
DatabaseFactory.getMmsSmsDatabase(context).incrementReadReceiptCount(id, System.currentTimeMillis());
|
DatabaseFactory.getMmsSmsDatabase(context).incrementReadReceiptCount(id, System.currentTimeMillis());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (TextSecurePreferences.isUnidentifiedDeliveryEnabled(context)) {
|
if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN && profileKey == null) {
|
||||||
if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN && profileKey == null) {
|
log(TAG, "Marking recipient as UD-unrestricted following a UD send.");
|
||||||
log(TAG, "Marking recipient as UD-unrestricted following a UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.UNRESTRICTED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.UNRESTRICTED);
|
} else if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN) {
|
||||||
} else if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN) {
|
log(TAG, "Marking recipient as UD-enabled following a UD send.");
|
||||||
log(TAG, "Marking recipient as UD-enabled following a UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.ENABLED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.ENABLED);
|
} else if (!unidentified && accessMode != UnidentifiedAccessMode.DISABLED) {
|
||||||
} else if (!unidentified && accessMode != UnidentifiedAccessMode.DISABLED) {
|
log(TAG, "Marking recipient as UD-disabled following a non-UD send.");
|
||||||
log(TAG, "Marking recipient as UD-disabled following a non-UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.DISABLED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.DISABLED);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (message.getExpiresIn() > 0 && !message.isExpirationUpdate()) {
|
if (message.getExpiresIn() > 0 && !message.isExpirationUpdate()) {
|
||||||
|
|
|
@ -95,17 +95,15 @@ public class PushTextSendJob extends PushSendJob {
|
||||||
DatabaseFactory.getMmsSmsDatabase(context).incrementReadReceiptCount(id, System.currentTimeMillis());
|
DatabaseFactory.getMmsSmsDatabase(context).incrementReadReceiptCount(id, System.currentTimeMillis());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (TextSecurePreferences.isUnidentifiedDeliveryEnabled(context)) {
|
if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN && profileKey == null) {
|
||||||
if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN && profileKey == null) {
|
log(TAG, "Marking recipient as UD-unrestricted following a UD send.");
|
||||||
log(TAG, "Marking recipient as UD-unrestricted following a UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.UNRESTRICTED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.UNRESTRICTED);
|
} else if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN) {
|
||||||
} else if (unidentified && accessMode == UnidentifiedAccessMode.UNKNOWN) {
|
log(TAG, "Marking recipient as UD-enabled following a UD send.");
|
||||||
log(TAG, "Marking recipient as UD-enabled following a UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.ENABLED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.ENABLED);
|
} else if (!unidentified && accessMode != UnidentifiedAccessMode.DISABLED) {
|
||||||
} else if (!unidentified && accessMode != UnidentifiedAccessMode.DISABLED) {
|
log(TAG, "Marking recipient as UD-disabled following a non-UD send.");
|
||||||
log(TAG, "Marking recipient as UD-disabled following a non-UD send.");
|
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.DISABLED);
|
||||||
DatabaseFactory.getRecipientDatabase(context).setUnidentifiedAccessMode(recipient.getId(), UnidentifiedAccessMode.DISABLED);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (record.getExpiresIn() > 0) {
|
if (record.getExpiresIn() > 0) {
|
||||||
|
|
|
@ -54,8 +54,6 @@ public class RefreshAttributesJob extends BaseJob {
|
||||||
SignalServiceAccountManager signalAccountManager = ApplicationDependencies.getSignalServiceAccountManager();
|
SignalServiceAccountManager signalAccountManager = ApplicationDependencies.getSignalServiceAccountManager();
|
||||||
signalAccountManager.setAccountAttributes(null, registrationId, fetchesMessages, pin,
|
signalAccountManager.setAccountAttributes(null, registrationId, fetchesMessages, pin,
|
||||||
unidentifiedAccessKey, universalUnidentifiedAccess);
|
unidentifiedAccessKey, universalUnidentifiedAccess);
|
||||||
|
|
||||||
ApplicationDependencies.getJobManager().add(new RefreshUnidentifiedDeliveryAbilityJob());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,103 +0,0 @@
|
||||||
package org.thoughtcrime.securesms.jobs;
|
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.crypto.ProfileKeyUtil;
|
|
||||||
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies;
|
|
||||||
import org.thoughtcrime.securesms.jobmanager.Data;
|
|
||||||
import org.thoughtcrime.securesms.jobmanager.Job;
|
|
||||||
import org.thoughtcrime.securesms.jobmanager.impl.NetworkConstraint;
|
|
||||||
import org.thoughtcrime.securesms.logging.Log;
|
|
||||||
import org.thoughtcrime.securesms.service.IncomingMessageObserver;
|
|
||||||
import org.thoughtcrime.securesms.util.Base64;
|
|
||||||
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
|
||||||
import org.whispersystems.libsignal.util.guava.Optional;
|
|
||||||
import org.whispersystems.signalservice.api.SignalServiceMessagePipe;
|
|
||||||
import org.whispersystems.signalservice.api.SignalServiceMessageReceiver;
|
|
||||||
import org.whispersystems.signalservice.api.crypto.ProfileCipher;
|
|
||||||
import org.whispersystems.signalservice.api.profiles.SignalServiceProfile;
|
|
||||||
import org.whispersystems.signalservice.api.push.SignalServiceAddress;
|
|
||||||
import org.whispersystems.signalservice.api.push.exceptions.PushNetworkException;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class RefreshUnidentifiedDeliveryAbilityJob extends BaseJob {
|
|
||||||
|
|
||||||
public static final String KEY = "RefreshUnidentifiedDeliveryAbilityJob";
|
|
||||||
|
|
||||||
private static final String TAG = RefreshUnidentifiedDeliveryAbilityJob.class.getSimpleName();
|
|
||||||
|
|
||||||
public RefreshUnidentifiedDeliveryAbilityJob() {
|
|
||||||
this(new Job.Parameters.Builder()
|
|
||||||
.addConstraint(NetworkConstraint.KEY)
|
|
||||||
.setMaxAttempts(10)
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
|
|
||||||
private RefreshUnidentifiedDeliveryAbilityJob(@NonNull Job.Parameters parameters) {
|
|
||||||
super(parameters);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public @NonNull Data serialize() {
|
|
||||||
return Data.EMPTY;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public @NonNull String getFactoryKey() {
|
|
||||||
return KEY;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onRun() throws Exception {
|
|
||||||
byte[] profileKey = ProfileKeyUtil.getProfileKey(context);
|
|
||||||
SignalServiceAddress address = new SignalServiceAddress(Optional.of(TextSecurePreferences.getLocalUuid(context)), Optional.of(TextSecurePreferences.getLocalNumber(context)));
|
|
||||||
SignalServiceProfile profile = retrieveProfile(address);
|
|
||||||
|
|
||||||
boolean enabled = profile.getUnidentifiedAccess() != null && isValidVerifier(profileKey, profile.getUnidentifiedAccess());
|
|
||||||
|
|
||||||
TextSecurePreferences.setIsUnidentifiedDeliveryEnabled(context, enabled);
|
|
||||||
Log.i(TAG, "Set UD status to: " + enabled);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCanceled() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean onShouldRetry(@NonNull Exception exception) {
|
|
||||||
return exception instanceof PushNetworkException;
|
|
||||||
}
|
|
||||||
|
|
||||||
private SignalServiceProfile retrieveProfile(@NonNull SignalServiceAddress address) throws IOException {
|
|
||||||
SignalServiceMessageReceiver receiver = ApplicationDependencies.getSignalServiceMessageReceiver();
|
|
||||||
SignalServiceMessagePipe pipe = IncomingMessageObserver.getPipe();
|
|
||||||
|
|
||||||
if (pipe != null) {
|
|
||||||
try {
|
|
||||||
return pipe.getProfile(address, Optional.absent());
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return receiver.retrieveProfile(address, Optional.absent());
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean isValidVerifier(@NonNull byte[] profileKey, @NonNull String verifier) {
|
|
||||||
ProfileCipher profileCipher = new ProfileCipher(profileKey);
|
|
||||||
try {
|
|
||||||
return profileCipher.verifyUnidentifiedAccess(Base64.decode(verifier));
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Factory implements Job.Factory<RefreshUnidentifiedDeliveryAbilityJob> {
|
|
||||||
@Override
|
|
||||||
public @NonNull RefreshUnidentifiedDeliveryAbilityJob create(@NonNull Parameters parameters, @NonNull Data data) {
|
|
||||||
return new RefreshUnidentifiedDeliveryAbilityJob(parameters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Ładowanie…
Reference in New Issue