mirror of
https://github.com/signalapp/Signal-Android.git
synced 2026-04-21 09:20:19 +01:00
Sync keys with linked devices.
This commit is contained in:
@@ -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;
|
||||
}
|
||||
|
||||
|
||||
@@ -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)
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user