Merge pull request #2849 from dlvoy/fix-prefs-import-crash
Fix preferences import/export related crashes
This commit is contained in:
commit
fc69e851d1
4 changed files with 27 additions and 9 deletions
|
@ -257,6 +257,7 @@ dependencies {
|
||||||
implementation 'androidx.percentlayout:percentlayout:1.0.0'
|
implementation 'androidx.percentlayout:percentlayout:1.0.0'
|
||||||
implementation "androidx.preference:preference-ktx:1.1.1"
|
implementation "androidx.preference:preference-ktx:1.1.1"
|
||||||
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
||||||
|
implementation "androidx.fragment:fragment:${fragmentVersion}"
|
||||||
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
|
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
|
||||||
implementation 'com.google.android.material:material:1.1.0'
|
implementation 'com.google.android.material:material:1.1.0'
|
||||||
|
|
||||||
|
|
|
@ -209,18 +209,24 @@ class ImportExportPrefs @Inject constructor(
|
||||||
} catch (e: IOException) {
|
} catch (e: IOException) {
|
||||||
ToastUtils.errorToast(activity, e.message)
|
ToastUtils.errorToast(activity, e.message)
|
||||||
log.error(TAG, "Unhandled exception", e)
|
log.error(TAG, "Unhandled exception", e)
|
||||||
|
} catch (e: PrefFileNotFoundError) {
|
||||||
|
ToastUtils.Long.errorToast(activity, resourceHelper.gs(R.string.preferences_export_canceled)
|
||||||
|
+ "\n\n" + resourceHelper.gs(R.string.filenotfound)
|
||||||
|
+ ": " + e.message
|
||||||
|
+ "\n\n" + resourceHelper.gs(R.string.needstoragepermission))
|
||||||
|
log.error(TAG, "File system exception", e)
|
||||||
|
} catch (e: PrefIOError) {
|
||||||
|
ToastUtils.Long.errorToast(activity, resourceHelper.gs(R.string.preferences_export_canceled)
|
||||||
|
+ "\n\n" + resourceHelper.gs(R.string.needstoragepermission)
|
||||||
|
+ ": " + e.message)
|
||||||
|
log.error(TAG, "File system exception", e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun importSharedPreferences(fragment: Fragment) {
|
fun importSharedPreferences(fragment: Fragment) {
|
||||||
fragment.activity?.let { fragmentAct ->
|
fragment.activity?.let { fragmentAct ->
|
||||||
val callForPrefFile = fragmentAct.registerForActivityResult(PrefsFileContract()) {
|
importSharedPreferences(fragmentAct)
|
||||||
it?.let {
|
|
||||||
importSharedPreferences(fragmentAct, it)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
callForPrefFile.launch(null)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -230,7 +236,15 @@ class ImportExportPrefs @Inject constructor(
|
||||||
importSharedPreferences(activity, it)
|
importSharedPreferences(activity, it)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
callForPrefFile.launch(null)
|
callForPrefFile.launch(null)
|
||||||
|
} catch (e: IllegalArgumentException) {
|
||||||
|
// this exception happens on some early implementations of ActivityResult contracts
|
||||||
|
// when registered and called for the second time
|
||||||
|
ToastUtils.errorToast(activity, resourceHelper.gs(R.string.goto_main_try_again))
|
||||||
|
log.error(TAG, "Internal android framework exception", e)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun importSharedPreferences(activity: Activity, importFile: PrefsFile) {
|
private fun importSharedPreferences(activity: Activity, importFile: PrefsFile) {
|
||||||
|
@ -267,7 +281,7 @@ class ImportExportPrefs @Inject constructor(
|
||||||
restartAppAfterImport(activity)
|
restartAppAfterImport(activity)
|
||||||
} else {
|
} else {
|
||||||
// for impossible imports it should not be called
|
// for impossible imports it should not be called
|
||||||
ToastUtils.errorToast(activity, "Cannot import preferences!")
|
ToastUtils.errorToast(activity, resourceHelper.gs(R.string.preferences_import_impossible))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -206,6 +206,8 @@
|
||||||
<string name="password_preferences_decrypt_prompt">You will be asked for master password, which is needed to decrypt imported preferences.</string>
|
<string name="password_preferences_decrypt_prompt">You will be asked for master password, which is needed to decrypt imported preferences.</string>
|
||||||
<string name="preferences_export_canceled">Export canceled! Preferences were NOT exported!</string>
|
<string name="preferences_export_canceled">Export canceled! Preferences were NOT exported!</string>
|
||||||
<string name="preferences_import_canceled">Import canceled! Preferences were NOT imported!</string>
|
<string name="preferences_import_canceled">Import canceled! Preferences were NOT imported!</string>
|
||||||
|
<string name="preferences_import_impossible">Cannot import preferences!</string>
|
||||||
|
<string name="goto_main_try_again">Please go back to main screen and try again.</string>
|
||||||
|
|
||||||
<string name="preferences_import_list_title">Select file to import</string>
|
<string name="preferences_import_list_title">Select file to import</string>
|
||||||
|
|
||||||
|
@ -950,7 +952,7 @@
|
||||||
<string name="askforpermission">Ask for permission</string>
|
<string name="askforpermission">Ask for permission</string>
|
||||||
<string name="needsystemwindowpermission">Application needs system window permission for notifications</string>
|
<string name="needsystemwindowpermission">Application needs system window permission for notifications</string>
|
||||||
<string name="needlocationpermission">Application needs location permission for BT scan and WiFi identification</string>
|
<string name="needlocationpermission">Application needs location permission for BT scan and WiFi identification</string>
|
||||||
<string name="needstoragepermission">Application needs storage permission to be able store log files</string>
|
<string name="needstoragepermission">Application needs storage permission to be able store log files and export settings</string>
|
||||||
<string name="request">Request</string>
|
<string name="request">Request</string>
|
||||||
<string name="insulinsourcesetup">Configure Insulin plugin</string>
|
<string name="insulinsourcesetup">Configure Insulin plugin</string>
|
||||||
<string name="exit">Exit</string>
|
<string name="exit">Exit</string>
|
||||||
|
|
|
@ -12,6 +12,7 @@ buildscript {
|
||||||
dagger_version = '2.28.1'
|
dagger_version = '2.28.1'
|
||||||
coroutinesVersion = '1.3.7'
|
coroutinesVersion = '1.3.7'
|
||||||
activityVersion = '1.2.0-alpha06'
|
activityVersion = '1.2.0-alpha06'
|
||||||
|
fragmentVersion = '1.3.0-alpha07'
|
||||||
ormLiteVersion = "4.46"
|
ormLiteVersion = "4.46"
|
||||||
}
|
}
|
||||||
repositories {
|
repositories {
|
||||||
|
|
Loading…
Reference in a new issue