From 1d7f1f9dafd98e66a2fcc7ed584748b935b16808 Mon Sep 17 00:00:00 2001 From: Paul Puey Date: Wed, 18 Oct 2023 22:00:55 -0700 Subject: [PATCH] Make Thorchain give estimate quotes --- CHANGELOG.md | 4 +++ src/swap/defi/thorchain.ts | 73 +++++++++++++++++++++++--------------- 2 files changed, 49 insertions(+), 28 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8735e707..65273a90 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,9 +2,13 @@ ## Unreleased +<<<<<<< HEAD ## 0.21.11 (2023-10-19) - added: Enable Zcash receiving on Godex +======= +- changed: Thorchain quotes to estimate rate +>>>>>>> 727ea4c (Make Thorchain give estimate quotes) ## 0.21.10 (2023-10-09) diff --git a/src/swap/defi/thorchain.ts b/src/swap/defi/thorchain.ts index 8a8e7c05..17ba4605 100644 --- a/src/swap/defi/thorchain.ts +++ b/src/swap/defi/thorchain.ts @@ -257,6 +257,7 @@ interface CalcSwapParams { toWallet: EdgeCurrencyWallet toCurrencyCode: string toAddress: string + isEstimate: boolean nativeAmount: string minAmount: MinAmount | undefined sourcePool: Pool @@ -300,7 +301,8 @@ export function makeThorchainPlugin( } const fetchSwapQuoteInner = async ( - request: EdgeSwapRequestPlugin + request: EdgeSwapRequestPlugin, + isEstimate: boolean ): Promise => { const { fromCurrencyCode, @@ -390,29 +392,33 @@ export function makeThorchainPlugin( streamingQuantity = thorchain.streamingQuantity ?? streamingQuantity } - const volatilitySpreadFinal = getVolatilitySpread({ - fromPluginId: fromWallet.currencyInfo.pluginId, - fromTokenId, - fromCurrencyCode, - toPluginId: toWallet.currencyInfo.pluginId, - toTokenId, - toCurrencyCode, - likeKindVolatilitySpread, - volatilitySpread, - perAssetSpread - }) + const volatilitySpreadFinal = isEstimate + ? '0' + : getVolatilitySpread({ + fromPluginId: fromWallet.currencyInfo.pluginId, + fromTokenId, + fromCurrencyCode, + toPluginId: toWallet.currencyInfo.pluginId, + toTokenId, + toCurrencyCode, + likeKindVolatilitySpread, + volatilitySpread, + perAssetSpread + }) - const volatilitySpreadStreamingFinal = getVolatilitySpread({ - fromPluginId: fromWallet.currencyInfo.pluginId, - fromTokenId, - fromCurrencyCode, - toPluginId: toWallet.currencyInfo.pluginId, - toTokenId, - toCurrencyCode, - likeKindVolatilitySpread: likeKindVolatilitySpreadStreaming, - volatilitySpread: volatilitySpreadStreaming, - perAssetSpread: perAssetSpreadStreaming - }) + const volatilitySpreadStreamingFinal = isEstimate + ? '0' + : getVolatilitySpread({ + fromPluginId: fromWallet.currencyInfo.pluginId, + fromTokenId, + fromCurrencyCode, + toPluginId: toWallet.currencyInfo.pluginId, + toTokenId, + toCurrencyCode, + likeKindVolatilitySpread: likeKindVolatilitySpreadStreaming, + volatilitySpread: volatilitySpreadStreaming, + perAssetSpread: perAssetSpreadStreaming + }) log.warn(`volatilitySpreadFinal: ${volatilitySpreadFinal.toString()}`) log.warn( @@ -476,6 +482,7 @@ export function makeThorchainPlugin( toWallet, toCurrencyCode, toAddress, + isEstimate, nativeAmount, minAmount, sourcePool, @@ -498,6 +505,7 @@ export function makeThorchainPlugin( toWallet, toCurrencyCode, toAddress, + isEstimate, nativeAmount, minAmount, sourcePool, @@ -634,8 +642,12 @@ export function makeThorchainPlugin( async fetchSwapQuote(req: EdgeSwapRequest): Promise { const request = convertRequest(req) - const newRequest = await getMaxSwappable(fetchSwapQuoteInner, request) - const swapOrder = await fetchSwapQuoteInner(newRequest) + const newRequest = await getMaxSwappable( + fetchSwapQuoteInner, + request, + true + ) + const swapOrder = await fetchSwapQuoteInner(newRequest, true) return await makeSwapPluginQuote(swapOrder) } } @@ -652,6 +664,7 @@ const calcSwapFrom = async ({ toWallet, toCurrencyCode, toAddress, + isEstimate, nativeAmount, minAmount, sourcePool, @@ -770,7 +783,9 @@ const calcSwapFrom = async ({ const toNativeAmount = round(toNativeAmountFloat, 0) log(`toNativeAmount: ${toNativeAmount}`) - const memo = preMemo.replace(':0/', `:${toThorAmountWithSpread}/`) + const memo = isEstimate + ? preMemo + : preMemo.replace(':0/', `:${toThorAmountWithSpread}/`) return { canBePartial, @@ -796,7 +811,7 @@ const calcSwapTo = async ({ toCurrencyCode, toAddress, nativeAmount, - minAmount, + isEstimate, sourcePool, destPool, thorname, @@ -906,7 +921,9 @@ const calcSwapTo = async ({ const fromNativeAmount = round(fromNativeAmountFloat, 0) log(`fromNativeAmount: ${fromNativeAmount}`) - const memo = preMemo.replace(':0/', `:${requestedToThorAmount}/`) + const memo = isEstimate + ? preMemo + : preMemo.replace(':0/', `:${requestedToThorAmount}/`) return { canBePartial,