Properly migrate existing users to new plugin setup
This commit is contained in:
parent
a95ba41196
commit
0e51c00bca
1 changed files with 17 additions and 5 deletions
|
@ -102,13 +102,25 @@ class SettingsManager(private val context: Context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
internal val storagePluginType: StoragePluginEnum?
|
internal val storagePluginType: StoragePluginEnum?
|
||||||
get() = prefs.getString(PREF_KEY_STORAGE_PLUGIN, StoragePluginEnum.SAF.name)?.let {
|
get() {
|
||||||
|
val savedType = prefs.getString(PREF_KEY_STORAGE_PLUGIN, null)
|
||||||
|
return if (savedType == null) {
|
||||||
|
// check if this is an existing user that needs to be migrated
|
||||||
|
// this check could be removed after a reasonable migration time (added 2024)
|
||||||
|
if (prefs.getString(PREF_KEY_STORAGE_URI, null) != null) {
|
||||||
|
prefs.edit()
|
||||||
|
.putString(PREF_KEY_STORAGE_PLUGIN, StoragePluginEnum.SAF.name)
|
||||||
|
.apply()
|
||||||
|
StoragePluginEnum.SAF
|
||||||
|
} else null
|
||||||
|
} else savedType.let {
|
||||||
try {
|
try {
|
||||||
StoragePluginEnum.valueOf(it)
|
StoragePluginEnum.valueOf(it)
|
||||||
} catch (e: IllegalArgumentException) {
|
} catch (e: IllegalArgumentException) {
|
||||||
null
|
null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fun setStoragePlugin(plugin: StoragePlugin<*>) {
|
fun setStoragePlugin(plugin: StoragePlugin<*>) {
|
||||||
val value = when (plugin) {
|
val value = when (plugin) {
|
||||||
|
|
Loading…
Reference in a new issue