From 340ec36e0edcefbedf8102627d30646c2f28d992 Mon Sep 17 00:00:00 2001 From: Evan Pipta <3pipta@gmail.com> Date: Mon, 13 Nov 2023 22:23:44 -0500 Subject: [PATCH] sdk: fix bug for cancel existing orders (#694) --- sdk/src/driftClient.ts | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/sdk/src/driftClient.ts b/sdk/src/driftClient.ts index fd1c77c23..60a10b685 100644 --- a/sdk/src/driftClient.ts +++ b/sdk/src/driftClient.ts @@ -2448,7 +2448,7 @@ export class DriftClient { * @param makerInfo * @param txParams * @param bracketOrdersParams - * @param cancelExistingOrders - Builds and returns an extra transaciton to cancel the existing orders in the same market. Intended use is to auto-cancel TP/SL orders when closing a position + * @param cancelExistingOrders - Builds and returns an extra transaciton to cancel the existing orders in the same perp market. Intended use is to auto-cancel TP/SL orders when closing a position. Ignored if orderParams.marketType is not MarketType.PERP * @returns */ public async sendMarketOrderAndGetSignedFillTx( @@ -2491,7 +2491,7 @@ export class DriftClient { let cancelOrdersIx: TransactionInstruction; let cancelExistingOrdersTx: Transaction; - if (cancelExistingOrders) { + if (cancelExistingOrders && isVariant(orderParams.marketType, 'perp')) { cancelOrdersIx = await this.getCancelOrdersIx( orderParams.marketType, orderParams.marketIndex, @@ -2896,7 +2896,8 @@ export class DriftClient { let readablePerpMarketIndex = undefined; let readableSpotMarketIndexes = undefined; - if (marketIndex) { + + if (typeof marketIndex === 'number') { if (marketType && isVariant(marketType, 'perp')) { readablePerpMarketIndex = marketIndex; } else if (marketType && isVariant(marketType, 'spot')) { @@ -3736,7 +3737,7 @@ export class DriftClient { if (!quote) { throw new Error("Could not fetch Jupiter's quote. Please try again."); } - + const transaction = await jupiterClient.getSwap({ quote, userPublicKey: this.provider.wallet.publicKey,