diff options
author | Torsten Grote <t@grobox.de> | 2020-07-31 09:29:03 -0300 |
---|---|---|
committer | Torsten Grote <t@grobox.de> | 2020-07-31 09:29:03 -0300 |
commit | dabc0ce62c93f8d78ed800e0f3c63b7fd5cb9e25 (patch) | |
tree | ae648793b16926017aa0e18204dcc81a94f9fbca | |
parent | 8562b15381d99e5c1a5c15a64dd124d04b2fab6a (diff) | |
download | taler-android-dabc0ce62c93f8d78ed800e0f3c63b7fd5cb9e25.tar.gz taler-android-dabc0ce62c93f8d78ed800e0f3c63b7fd5cb9e25.tar.bz2 taler-android-dabc0ce62c93f8d78ed800e0f3c63b7fd5cb9e25.zip |
[cashier] check version from bank when configuring
real version isn't checked because bank reports invalid version syntax
-rw-r--r-- | cashier/src/main/java/net/taler/cashier/MainViewModel.kt | 32 |
1 files changed, 20 insertions, 12 deletions
diff --git a/cashier/src/main/java/net/taler/cashier/MainViewModel.kt b/cashier/src/main/java/net/taler/cashier/MainViewModel.kt index a4fd35e..1740494 100644 --- a/cashier/src/main/java/net/taler/cashier/MainViewModel.kt +++ b/cashier/src/main/java/net/taler/cashier/MainViewModel.kt @@ -36,11 +36,13 @@ import net.taler.cashier.HttpHelper.makeJsonGetRequest import net.taler.cashier.withdraw.WithdrawManager import net.taler.common.AmountParserException import net.taler.common.SignedAmount +import net.taler.common.Version +import net.taler.common.getIncompatibleStringOrNull import net.taler.common.isOnline private val TAG = MainViewModel::class.java.simpleName -private const val VERSION_BANK = "0:0:0" +private val VERSION_BANK = Version(0, 0, 0) private const val PREF_NAME = "net.taler.cashier.prefs" private const val PREF_KEY_BANK_URL = "bankUrl" private const val PREF_KEY_USERNAME = "username" @@ -91,17 +93,23 @@ class MainViewModel(private val app: Application) : AndroidViewModel(app) { Log.d(TAG, "Checking config: $url") val result = when (val response = makeJsonGetRequest(url, config)) { is HttpJsonResult.Success -> { - val version = response.json.getString("version") - // TODO check if version is compatible - val currency = response.json.getString("currency") - try { - mCurrency.postValue(currency) - prefs.edit().putString(PREF_KEY_CURRENCY, currency).apply() - // save config - saveConfig(config) - ConfigResult.Success - } catch (e: Exception) { - ConfigResult.Error(false, "Invalid Config: ${response.json}") + // check if bank's version is compatible with app + // TODO use real version response when fixed in bank + val version = "0:0:0" // response.json.getString("version") + val versionIncompatible = VERSION_BANK.getIncompatibleStringOrNull(app, version) + if (versionIncompatible != null) { + ConfigResult.Error(false, versionIncompatible) + } else { + val currency = response.json.getString("currency") + try { + mCurrency.postValue(currency) + prefs.edit().putString(PREF_KEY_CURRENCY, currency).apply() + // save config + saveConfig(config) + ConfigResult.Success + } catch (e: Exception) { + ConfigResult.Error(false, "Invalid Config: ${response.json}") + } } } is HttpJsonResult.Error -> { |