From f0e1832df9208c4c02dd471a5a698b48c0e2d541 Mon Sep 17 00:00:00 2001 From: Paul Puey Date: Fri, 3 Nov 2023 17:54:10 -0700 Subject: [PATCH] Check maxSpendable in xrpdex --- CHANGELOG.md | 4 ++++ src/swap/defi/xrpDex.ts | 25 +++++++++++++++---------- 2 files changed, 19 insertions(+), 10 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 867c1b03..c9328a7f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # edge-exchange-plugins +## Unreleased + +- fixed: Check max spendable amount of source wallet in xrpdex quote + ## 1.0.1 (2023-10-30) - fixed: Properly report Thorchain quotes as isEstimate diff --git a/src/swap/defi/xrpDex.ts b/src/swap/defi/xrpDex.ts index 7d30b99a..1633464f 100644 --- a/src/swap/defi/xrpDex.ts +++ b/src/swap/defi/xrpDex.ts @@ -1,4 +1,4 @@ -import { round, sub } from 'biggystring' +import { gt, round, sub } from 'biggystring' import { asArray, asNumber, asObject, asOptional, asString } from 'cleaners' import { EdgeCorePluginOptions, @@ -7,6 +7,7 @@ import { EdgeSwapQuote, EdgeSwapRequest, EdgeTxSwap, + InsufficientFundsError, JsonObject, SwapCurrencyError } from 'edge-core-js/types' @@ -251,6 +252,16 @@ export function makeXrpDexPlugin(opts: EdgeCorePluginOptions): EdgeSwapPlugin { const request = convertRequest(req) const { fromCurrencyCode, fromTokenId, fromWallet, quoteFor } = request + // Get the balance of the wallet minus reserve + const maxSpendable = await fromWallet.getMaxSpendable({ + currencyCode: fromCurrencyCode, + spendTargets: [ + { + publicAddress: DUMMY_XRP_ADDRESS + } + ] + }) + let swapOrder: SwapOrder if (quoteFor === 'max') { request.quoteFor = 'from' @@ -261,20 +272,14 @@ export function makeXrpDexPlugin(opts: EdgeCorePluginOptions): EdgeSwapPlugin { const quote = await makeSwapPluginQuote(swapOrder) const swapFee = quote.networkFee.nativeAmount - // Get the balance of the wallet minus reserve - const maxSpendable = await fromWallet.getMaxSpendable({ - currencyCode: fromCurrencyCode, - spendTargets: [ - { - publicAddress: DUMMY_XRP_ADDRESS - } - ] - }) request.nativeAmount = sub(maxSpendable, swapFee) return await this.fetchSwapQuote(request, userSettings, opts) } } else { swapOrder = await fetchSwapQuoteInner(request) + if (gt(swapOrder.fromNativeAmount, maxSpendable)) { + throw new InsufficientFundsError() + } } return await makeSwapPluginQuote(swapOrder) }