From 55624eb33bae14380efe8ca085dc420390b23702 Mon Sep 17 00:00:00 2001 From: Torsten Grote Date: Tue, 1 Nov 2022 15:36:17 -0300 Subject: [wallet] Allow exporting the entire DB --- .../net/taler/wallet/settings/SettingsManager.kt | 28 ++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'wallet/src/main/java/net/taler/wallet/settings/SettingsManager.kt') diff --git a/wallet/src/main/java/net/taler/wallet/settings/SettingsManager.kt b/wallet/src/main/java/net/taler/wallet/settings/SettingsManager.kt index 6bf1673..349c7b1 100644 --- a/wallet/src/main/java/net/taler/wallet/settings/SettingsManager.kt +++ b/wallet/src/main/java/net/taler/wallet/settings/SettingsManager.kt @@ -26,6 +26,7 @@ import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch import kotlinx.coroutines.withContext import net.taler.wallet.R +import net.taler.wallet.backend.WALLET_DB class SettingsManager( private val context: Context, @@ -59,4 +60,31 @@ class SettingsManager( Toast.makeText(context, R.string.settings_logcat_error, LENGTH_LONG).show() } + fun exportDb(uri: Uri?) { + if (uri == null) { + onDbExportError() + return + } + scope.launch(Dispatchers.IO) { + try { + context.contentResolver.openOutputStream(uri, "wt")?.use { outputStream -> + context.openFileInput(WALLET_DB).use { inputStream -> + inputStream.copyTo(outputStream) + } + } ?: onDbExportError() + } catch (e: Exception) { + Log.e(SettingsManager::class.simpleName, "Error exporting db: ", e) + onDbExportError() + return@launch + } + withContext(Dispatchers.Main) { + Toast.makeText(context, R.string.settings_db_export_success, LENGTH_LONG).show() + } + } + } + + private fun onDbExportError() { + Toast.makeText(context, R.string.settings_db_export_error, LENGTH_LONG).show() + } + } -- cgit v1.2.3