Sync keys with linked devices.

This commit is contained in:
Cody Henthorne
2023-10-11 16:34:35 -04:00
parent 6a6b80cce2
commit 1f9320200a
7 changed files with 62 additions and 5 deletions

View File

@@ -139,9 +139,10 @@ public class ApplicationMigrations {
static final int COPY_USERNAME_TO_SIGNAL_STORE = 95;
static final int RECHECK_PAYMENTS = 96;
static final int THREAD_COUNT_DB_MIGRATION = 97;
static final int SYNC_KEYS_MIGRATION = 98;
}
public static final int CURRENT_VERSION = 97;
public static final int CURRENT_VERSION = 98;
/**
* This *must* be called after the {@link JobManager} has been instantiated, but *before* the call
@@ -632,6 +633,10 @@ public class ApplicationMigrations {
jobs.put(Version.THREAD_COUNT_DB_MIGRATION, new DatabaseMigrationJob());
}
if (lastSeenVersion < Version.SYNC_KEYS_MIGRATION) {
jobs.put(Version.SYNC_KEYS_MIGRATION, new SyncKeysMigrationJob());
}
return jobs;
}

View File

@@ -0,0 +1,36 @@
package org.thoughtcrime.securesms.migrations
import org.thoughtcrime.securesms.dependencies.ApplicationDependencies
import org.thoughtcrime.securesms.jobmanager.Job
import org.thoughtcrime.securesms.jobs.MultiDeviceKeysUpdateJob
import org.thoughtcrime.securesms.util.TextSecurePreferences
/**
* Migration to sync keys with linked devices.
*/
internal class SyncKeysMigrationJob(
parameters: Parameters = Parameters.Builder().build()
) : MigrationJob(parameters) {
companion object {
const val KEY = "SyncKeysMigrationJob"
}
override fun getFactoryKey(): String = KEY
override fun isUiBlocking(): Boolean = false
override fun performMigration() {
if (TextSecurePreferences.isMultiDevice(context)) {
ApplicationDependencies.getJobManager().add(MultiDeviceKeysUpdateJob())
}
}
override fun shouldRetry(e: Exception): Boolean = false
class Factory : Job.Factory<SyncKeysMigrationJob> {
override fun create(parameters: Parameters, serializedData: ByteArray?): SyncKeysMigrationJob {
return SyncKeysMigrationJob(parameters)
}
}
}