/* * 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.lib.wallet.exchange import io.ktor.client.HttpClient import io.ktor.client.request.get import kotlinx.serialization.SerialName import kotlinx.serialization.Serializable import net.taler.lib.common.Amount import net.taler.lib.common.Timestamp @Serializable internal data class Wire( val accounts: List, val fees: Map> ) { companion object { /** * Fetch an exchange's /wire with the given normalized base URL. */ suspend fun fetch(httpClient: HttpClient, exchangeBaseUrl: String): Wire { return httpClient.get("${exchangeBaseUrl}wire") } } } @Serializable internal data class AccountInfo( @SerialName("payto_uri") val paytoUri: String, @SerialName("master_sig") val masterSig: String, ) /** * Wire fees as announced by the exchange. */ @Serializable internal data class WireFee( /** * Fee for wire transfers. */ @SerialName("wire_fee") val wireFee: Amount, /** * Fees to close and refund a reserve. */ @SerialName("closing_fee") val closingFee: Amount, /** * Start date of the fee. */ @SerialName("start_date") val startStamp: Timestamp, /** * End date of the fee. */ @SerialName("end_date") val endStamp: Timestamp, /** * Signature made by the exchange master key. */ @SerialName("sig") val signature: String, )