From d13be7c5c1be2492d38959a29e1b1c33df4938ff Mon Sep 17 00:00:00 2001 From: Torsten Grote Date: Tue, 11 Aug 2020 15:24:25 -0300 Subject: [wallet] start to move deserialization into the backend API and off the UI thread for less sluggish, i.e. more responsive UI --- .../net/taler/wallet/backend/WalletResponse.kt | 82 ++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 wallet/src/main/java/net/taler/wallet/backend/WalletResponse.kt (limited to 'wallet/src/main/java/net/taler/wallet/backend/WalletResponse.kt') diff --git a/wallet/src/main/java/net/taler/wallet/backend/WalletResponse.kt b/wallet/src/main/java/net/taler/wallet/backend/WalletResponse.kt new file mode 100644 index 0000000..05a53f3 --- /dev/null +++ b/wallet/src/main/java/net/taler/wallet/backend/WalletResponse.kt @@ -0,0 +1,82 @@ +/* + * This file is part of GNU Taler + * (C) 2020 Taler Systems S.A. + * + * GNU Taler is free software; you can redistribute it and/or modify it under the + * terms of the GNU General Public License as published by the Free Software + * Foundation; either version 3, or (at your option) any later version. + * + * GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY + * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR + * A PARTICULAR PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along with + * GNU Taler; see the file COPYING. If not, see + */ + +package net.taler.wallet.backend + +import kotlinx.serialization.SerialName +import kotlinx.serialization.Serializable +import org.json.JSONObject + +@Serializable +sealed class WalletResponse { + @Serializable + @SerialName("response") + data class Success( + val result: T + ) : WalletResponse() + + @Serializable + @SerialName("error") + data class Error( + val error: WalletErrorInfo + ) : WalletResponse() + + fun onSuccess(block: (result: T) -> Unit): WalletResponse { + if (this is Success) block(this.result) + return this + } + + fun onError(block: (result: WalletErrorInfo) -> Unit): WalletResponse { + if (this is Error) block(this.error) + return this + } +} + +@Serializable +data class WalletErrorInfo( + // Numeric error code defined defined in the + // GANA gnu-taler-error-codes registry. + val talerErrorCode: Int, + + // English description of the error code. + val talerErrorHint: String, + + // English diagnostic message that can give details + // for the instance of the error. + val message: String, + + // Error details, type depends + // on talerErrorCode + val details: String? +) { + val userFacingMsg: String + get() { + return StringBuilder().apply { + append(talerErrorCode) + append(" ") + append(message) + details?.let { it -> + val details = JSONObject(it) + details.optJSONObject("errorResponse")?.let { errorResponse -> + append("\n\n") + append(errorResponse.optString("code")) + append(" ") + append(errorResponse.optString("hint")) + } + } + }.toString() + } +} -- cgit v1.2.3