@cowprotocol/sdk-trading 0.3.2-beta.0 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -63,17 +63,62 @@ var import_sdk_order_book = require("@cowprotocol/sdk-order-book");
63
63
  var import_sdk_config = require("@cowprotocol/sdk-config");
64
64
  var DEFAULT_QUOTE_VALIDITY = 60 * 30;
65
65
  var DEFAULT_SLIPPAGE_BPS = 50;
66
- var ETH_FLOW_DEFAULT_SLIPPAGE_BPS = {
67
- ...(0, import_sdk_config.mapSupportedNetworks)(DEFAULT_SLIPPAGE_BPS),
68
- // 0.5% by default for most chains
69
- [import_sdk_config.SupportedChainId.MAINNET]: 200
70
- // 2% for mainnet
71
- };
66
+ var ETH_FLOW_DEFAULT_SLIPPAGE_BPS = (0, import_sdk_config.mapSupportedNetworks)(DEFAULT_SLIPPAGE_BPS);
72
67
  var SIGN_SCHEME_MAP = {
73
68
  [import_sdk_order_book.EcdsaSigningScheme.EIP712]: import_sdk_order_book.SigningScheme.EIP712,
74
69
  [import_sdk_order_book.EcdsaSigningScheme.ETHSIGN]: import_sdk_order_book.SigningScheme.ETHSIGN
75
70
  };
76
71
  var GAS_LIMIT_DEFAULT = BigInt(15e4);
72
+ var ERC20_APPROVE_ABI = [
73
+ {
74
+ constant: false,
75
+ inputs: [
76
+ {
77
+ name: "_spender",
78
+ type: "address"
79
+ },
80
+ {
81
+ name: "_value",
82
+ type: "uint256"
83
+ }
84
+ ],
85
+ name: "approve",
86
+ outputs: [
87
+ {
88
+ name: "",
89
+ type: "bool"
90
+ }
91
+ ],
92
+ payable: false,
93
+ stateMutability: "nonpayable",
94
+ type: "function"
95
+ }
96
+ ];
97
+ var ERC20_ALLOWANCE_ABI = [
98
+ {
99
+ constant: true,
100
+ inputs: [
101
+ {
102
+ name: "_owner",
103
+ type: "address"
104
+ },
105
+ {
106
+ name: "_spender",
107
+ type: "address"
108
+ }
109
+ ],
110
+ name: "allowance",
111
+ outputs: [
112
+ {
113
+ name: "",
114
+ type: "uint256"
115
+ }
116
+ ],
117
+ payable: false,
118
+ stateMutability: "view",
119
+ type: "function"
120
+ }
121
+ ];
77
122
 
78
123
  // src/postCoWProtocolTrade.ts
79
124
  var import_sdk_order_signing2 = require("@cowprotocol/sdk-order-signing");
@@ -365,10 +410,18 @@ async function postSellNativeCurrencyOrder(orderBookApi, appData, _params, addit
365
410
  }
366
411
 
367
412
  // src/postCoWProtocolTrade.ts
413
+ var import_sdk_common5 = require("@cowprotocol/sdk-common");
414
+
415
+ // src/utils/resolveSigner.ts
368
416
  var import_sdk_common4 = require("@cowprotocol/sdk-common");
369
- async function postCoWProtocolTrade(orderBookApi, appData, params, additionalParams = {}, paramSigner) {
417
+ function resolveSigner(signer) {
370
418
  const adapter = (0, import_sdk_common4.getGlobalAdapter)();
371
- const signer = paramSigner ? adapter.createSigner(paramSigner) : adapter.signer;
419
+ return signer ? adapter.createSigner(signer) : adapter.signer;
420
+ }
421
+
422
+ // src/postCoWProtocolTrade.ts
423
+ async function postCoWProtocolTrade(orderBookApi, appData, params, additionalParams = {}, paramSigner) {
424
+ const signer = resolveSigner(paramSigner);
372
425
  const { networkCostsAmount = "0", signingScheme: _signingScheme = import_sdk_order_book4.SigningScheme.EIP712 } = additionalParams;
373
426
  const isEthFlow = getIsEthFlowOrder(params);
374
427
  if (isEthFlow) {
@@ -384,7 +437,7 @@ async function postCoWProtocolTrade(orderBookApi, appData, params, additionalPar
384
437
  const chainId = orderBookApi.context.chainId;
385
438
  const from = owner || await signer.getAddress();
386
439
  const orderToSign = getOrderToSign({ chainId, from, networkCostsAmount, isEthFlow }, params, appData.appDataKeccak256);
387
- (0, import_sdk_common4.log)("Signing order...");
440
+ (0, import_sdk_common5.log)("Signing order...");
388
441
  const { signature, signingScheme } = await (async () => {
389
442
  if (_signingScheme === import_sdk_order_book4.SigningScheme.PRESIGN) {
390
443
  return { signature: from, signingScheme: import_sdk_order_book4.SigningScheme.PRESIGN };
@@ -402,24 +455,24 @@ async function postCoWProtocolTrade(orderBookApi, appData, params, additionalPar
402
455
  appData: fullAppData,
403
456
  appDataHash: appDataKeccak256
404
457
  };
405
- (0, import_sdk_common4.log)("Posting order...");
458
+ (0, import_sdk_common5.log)("Posting order...");
406
459
  const orderId = await orderBookApi.sendOrder(orderBody);
407
- (0, import_sdk_common4.log)(`Order created, id: ${orderId}`);
460
+ (0, import_sdk_common5.log)(`Order created, id: ${orderId}`);
408
461
  return { orderId, signature, signingScheme, orderToSign };
409
462
  }
410
463
 
411
464
  // src/getQuote.ts
412
- var import_sdk_common9 = require("@cowprotocol/sdk-common");
413
- var import_sdk_order_book6 = require("@cowprotocol/sdk-order-book");
465
+ var import_sdk_common11 = require("@cowprotocol/sdk-common");
466
+ var import_sdk_order_book7 = require("@cowprotocol/sdk-order-book");
414
467
 
415
468
  // src/appDataUtils.ts
416
469
  var import_sdk_app_data = require("@cowprotocol/sdk-app-data");
417
- var import_sdk_common5 = require("@cowprotocol/sdk-common");
470
+ var import_sdk_common6 = require("@cowprotocol/sdk-common");
418
471
  var import_deepmerge = __toESM(require("deepmerge"));
419
472
  async function buildAppData({ slippageBps, appCode, orderClass: orderClassName, partnerFee }, advancedParams) {
420
473
  const quoteParams = { slippageBips: slippageBps };
421
474
  const orderClass = { orderClass: orderClassName };
422
- const metadataApiSdk = new import_sdk_app_data.MetadataApi((0, import_sdk_common5.getGlobalAdapter)());
475
+ const metadataApiSdk = new import_sdk_app_data.MetadataApi((0, import_sdk_common6.getGlobalAdapter)());
423
476
  const doc = await metadataApiSdk.generateAppDataDoc(
424
477
  (0, import_deepmerge.default)(
425
478
  {
@@ -437,7 +490,7 @@ async function buildAppData({ slippageBps, appCode, orderClass: orderClassName,
437
490
  return { doc, fullAppData, appDataKeccak256 };
438
491
  }
439
492
  async function generateAppDataFromDoc(doc) {
440
- const adapter = (0, import_sdk_common5.getGlobalAdapter)();
493
+ const adapter = (0, import_sdk_common6.getGlobalAdapter)();
441
494
  const fullAppData = await (0, import_sdk_app_data.stringifyDeterministic)(doc);
442
495
  const appDataKeccak256 = adapter.utils.keccak256(adapter.utils.toUtf8Bytes(fullAppData));
443
496
  return { fullAppData, appDataKeccak256 };
@@ -486,12 +539,16 @@ async function getOrderTypedData(chainId, orderToSign) {
486
539
  };
487
540
  }
488
541
 
542
+ // src/resolveSlippageSuggestion.ts
543
+ var import_sdk_common10 = require("@cowprotocol/sdk-common");
544
+ var import_sdk_order_book6 = require("@cowprotocol/sdk-order-book");
545
+
489
546
  // src/suggestSlippageBps.ts
490
- var import_sdk_common8 = require("@cowprotocol/sdk-common");
547
+ var import_sdk_common9 = require("@cowprotocol/sdk-common");
491
548
  var import_sdk_order_book5 = require("@cowprotocol/sdk-order-book");
492
549
 
493
550
  // src/suggestSlippageFromFee.ts
494
- var import_sdk_common6 = require("@cowprotocol/sdk-common");
551
+ var import_sdk_common7 = require("@cowprotocol/sdk-common");
495
552
  function suggestSlippageFromFee(params) {
496
553
  const { feeAmount, multiplyingFactorPercent } = params;
497
554
  if (feeAmount < 0n) {
@@ -500,11 +557,11 @@ function suggestSlippageFromFee(params) {
500
557
  if (multiplyingFactorPercent < 0) {
501
558
  throw new Error("multiplyingFactorPercent must be non-negative: " + multiplyingFactorPercent);
502
559
  }
503
- return (0, import_sdk_common6.applyPercentage)(feeAmount, multiplyingFactorPercent);
560
+ return (0, import_sdk_common7.applyPercentage)(feeAmount, multiplyingFactorPercent);
504
561
  }
505
562
 
506
563
  // src/suggestSlippageFromVolume.ts
507
- var import_sdk_common7 = require("@cowprotocol/sdk-common");
564
+ var import_sdk_common8 = require("@cowprotocol/sdk-common");
508
565
  function suggestSlippageFromVolume(params) {
509
566
  const { sellAmountBeforeNetworkCosts, sellAmountAfterNetworkCosts, isSell, slippagePercent } = params;
510
567
  const sellAmount = isSell ? sellAmountAfterNetworkCosts : sellAmountBeforeNetworkCosts;
@@ -514,7 +571,7 @@ function suggestSlippageFromVolume(params) {
514
571
  if (slippagePercent < 0) {
515
572
  throw new Error("slippagePercent must be non-negative: " + slippagePercent);
516
573
  }
517
- return (0, import_sdk_common7.applyPercentage)(sellAmount, slippagePercent);
574
+ return (0, import_sdk_common8.applyPercentage)(sellAmount, slippagePercent);
518
575
  }
519
576
 
520
577
  // src/suggestSlippageBps.ts
@@ -522,7 +579,13 @@ var MAX_SLIPPAGE_BPS = 1e4;
522
579
  var SLIPPAGE_FEE_MULTIPLIER_PERCENT = 50;
523
580
  var SLIPPAGE_VOLUME_MULTIPLIER_PERCENT = 0.5;
524
581
  function suggestSlippageBps(params) {
525
- const { quote, tradeParameters, trader, isEthFlow } = params;
582
+ const {
583
+ quote,
584
+ tradeParameters,
585
+ trader,
586
+ isEthFlow,
587
+ volumeMultiplierPercent = SLIPPAGE_VOLUME_MULTIPLIER_PERCENT
588
+ } = params;
526
589
  const { sellTokenDecimals, buyTokenDecimals } = tradeParameters;
527
590
  const { isSell, sellAmountBeforeNetworkCosts, sellAmountAfterNetworkCosts } = (0, import_sdk_order_book5.getQuoteAmountsWithCosts)({
528
591
  sellDecimals: sellTokenDecimals,
@@ -539,7 +602,7 @@ function suggestSlippageBps(params) {
539
602
  isSell,
540
603
  sellAmountBeforeNetworkCosts,
541
604
  sellAmountAfterNetworkCosts,
542
- slippagePercent: SLIPPAGE_VOLUME_MULTIPLIER_PERCENT
605
+ slippagePercent: volumeMultiplierPercent
543
606
  });
544
607
  const totalSlippageBps = slippageBpsFromFee + slippageBpsFromVolume;
545
608
  const slippagePercent = getSlippagePercent({
@@ -548,13 +611,57 @@ function suggestSlippageBps(params) {
548
611
  sellAmountAfterNetworkCosts,
549
612
  slippage: totalSlippageBps
550
613
  });
551
- const slippageBps = (0, import_sdk_common8.percentageToBps)(slippagePercent);
552
- return Math.max(Math.min(slippageBps, MAX_SLIPPAGE_BPS), getDefaultSlippageBps(trader.chainId, isEthFlow));
614
+ const slippageBps = (0, import_sdk_common9.percentageToBps)(slippagePercent);
615
+ const lowerCap = isEthFlow ? ETH_FLOW_DEFAULT_SLIPPAGE_BPS[trader.chainId] : 0;
616
+ return Math.max(Math.min(slippageBps, MAX_SLIPPAGE_BPS), lowerCap);
617
+ }
618
+
619
+ // src/resolveSlippageSuggestion.ts
620
+ async function resolveSlippageSuggestion(chainId, tradeParameters, trader, quote, isEthFlow, advancedSettings) {
621
+ const suggestSlippageParams = {
622
+ isEthFlow,
623
+ quote,
624
+ tradeParameters,
625
+ trader,
626
+ advancedSettings
627
+ };
628
+ const getSlippageSuggestion = advancedSettings?.getSlippageSuggestion;
629
+ const priceQuality = advancedSettings?.quoteRequest?.priceQuality ?? import_sdk_order_book6.PriceQuality.OPTIMAL;
630
+ const defaultSuggestion = suggestSlippageBps(suggestSlippageParams);
631
+ if (priceQuality === import_sdk_order_book6.PriceQuality.FAST || !getSlippageSuggestion) {
632
+ return { slippageBps: defaultSuggestion };
633
+ }
634
+ const amountsAndCosts = (0, import_sdk_order_book6.getQuoteAmountsAndCosts)({
635
+ orderParams: quote.quote,
636
+ slippagePercentBps: 0,
637
+ partnerFeeBps: getPartnerFeeBps(tradeParameters.partnerFee),
638
+ sellDecimals: tradeParameters.sellTokenDecimals,
639
+ buyDecimals: tradeParameters.buyTokenDecimals
640
+ });
641
+ try {
642
+ const suggestedSlippage = await getSlippageSuggestion({
643
+ chainId,
644
+ sellToken: tradeParameters.sellToken,
645
+ buyToken: tradeParameters.buyToken,
646
+ sellAmount: amountsAndCosts.afterSlippage.sellAmount,
647
+ buyAmount: amountsAndCosts.afterSlippage.buyAmount
648
+ });
649
+ const suggestedSlippageBps = suggestedSlippage.slippageBps;
650
+ return {
651
+ slippageBps: suggestedSlippageBps ? suggestSlippageBps({
652
+ ...suggestSlippageParams,
653
+ volumeMultiplierPercent: (0, import_sdk_common10.bpsToPercentage)(suggestedSlippageBps)
654
+ }) : defaultSuggestion
655
+ };
656
+ } catch (e) {
657
+ (0, import_sdk_common10.log)(`getSlippageSuggestion() error: ${e.message || String(e)}`);
658
+ return { slippageBps: defaultSuggestion };
659
+ }
553
660
  }
554
661
 
555
662
  // src/getQuote.ts
556
663
  var ETH_FLOW_AUX_QUOTE_PARAMS = {
557
- signingScheme: import_sdk_order_book6.SigningScheme.EIP1271,
664
+ signingScheme: import_sdk_order_book7.SigningScheme.EIP1271,
558
665
  onchainOrder: true,
559
666
  // Ethflow orders are subsidized in the backend.
560
667
  // This means we can assume the verification gas costs are zero for the quote/fee estimation
@@ -574,13 +681,13 @@ async function getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBoo
574
681
  slippageBps,
575
682
  env = "prod"
576
683
  } = tradeParameters;
577
- (0, import_sdk_common9.log)(
684
+ (0, import_sdk_common11.log)(
578
685
  `getQuote for: Swap ${amount} ${sellToken} for ${buyToken} on chain ${chainId} with ${slippageBps !== void 0 ? `${slippageBps} BPS` : "AUTO"} slippage`
579
686
  );
580
- const orderBookApi = _orderBookApi || new import_sdk_order_book6.OrderBookApi({ chainId, env });
687
+ const orderBookApi = _orderBookApi || new import_sdk_order_book7.OrderBookApi({ chainId, env });
581
688
  const receiver = tradeParameters.receiver || from;
582
689
  const isSell = kind === "sell";
583
- (0, import_sdk_common9.log)("Building app data...");
690
+ (0, import_sdk_common11.log)("Building app data...");
584
691
  const defaultSlippageBps = getDefaultSlippageBps(chainId, isEthFlow);
585
692
  const slippageBpsOrDefault = slippageBps ?? defaultSlippageBps;
586
693
  const buildAppDataParams = {
@@ -591,7 +698,7 @@ async function getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBoo
591
698
  };
592
699
  const appDataInfo = await buildAppData(buildAppDataParams, advancedSettings?.appData);
593
700
  const { appDataKeccak256, fullAppData } = appDataInfo;
594
- (0, import_sdk_common9.log)(`App data: appDataKeccak256=${appDataKeccak256} fullAppData=${fullAppData}`);
701
+ (0, import_sdk_common11.log)(`App data: appDataKeccak256=${appDataKeccak256} fullAppData=${fullAppData}`);
595
702
  const quoteRequest = {
596
703
  from,
597
704
  sellToken,
@@ -600,31 +707,32 @@ async function getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBoo
600
707
  validFor,
601
708
  appData: fullAppData,
602
709
  appDataHash: appDataKeccak256,
603
- priceQuality: import_sdk_order_book6.PriceQuality.OPTIMAL,
710
+ priceQuality: import_sdk_order_book7.PriceQuality.OPTIMAL,
604
711
  // Do not change this parameter because we rely on the fact that quote has id
605
- signingScheme: import_sdk_order_book6.SigningScheme.EIP712,
712
+ signingScheme: import_sdk_order_book7.SigningScheme.EIP712,
606
713
  ...isEthFlow ? ETH_FLOW_AUX_QUOTE_PARAMS : {},
607
- ...isSell ? { kind: import_sdk_order_book6.OrderQuoteSideKindSell.SELL, sellAmountBeforeFee: amount } : { kind: import_sdk_order_book6.OrderQuoteSideKindBuy.BUY, buyAmountAfterFee: amount },
714
+ ...isSell ? { kind: import_sdk_order_book7.OrderQuoteSideKindSell.SELL, sellAmountBeforeFee: amount } : { kind: import_sdk_order_book7.OrderQuoteSideKindBuy.BUY, buyAmountAfterFee: amount },
608
715
  ...advancedSettings?.quoteRequest
609
716
  };
610
- (0, import_sdk_common9.log)("Getting quote...");
717
+ (0, import_sdk_common11.log)("Getting quote...");
611
718
  const quote = await orderBookApi.getQuote(quoteRequest);
612
- const suggestedSlippageBps = suggestSlippageBps({
613
- isEthFlow,
614
- quote,
719
+ const { slippageBps: suggestedSlippageBps } = await resolveSlippageSuggestion(
720
+ chainId,
615
721
  tradeParameters,
616
722
  trader,
723
+ quote,
724
+ isEthFlow,
617
725
  advancedSettings
618
- });
726
+ );
619
727
  const commonResult = {
620
728
  isEthFlow,
621
729
  quote,
622
730
  orderBookApi,
623
- suggestedSlippageBps
731
+ suggestedSlippageBps: suggestedSlippageBps || defaultSlippageBps
624
732
  };
625
733
  if (slippageBps === void 0) {
626
- if (suggestedSlippageBps > defaultSlippageBps) {
627
- (0, import_sdk_common9.log)(
734
+ if (suggestedSlippageBps) {
735
+ (0, import_sdk_common11.log)(
628
736
  `Suggested slippage is greater than ${defaultSlippageBps} BPS (default), using the suggested slippage (${suggestedSlippageBps} BPS)`
629
737
  );
630
738
  const newAppDataInfo = await buildAppData(
@@ -634,7 +742,7 @@ async function getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBoo
634
742
  },
635
743
  advancedSettings?.appData
636
744
  );
637
- (0, import_sdk_common9.log)(
745
+ (0, import_sdk_common11.log)(
638
746
  `App data with new suggested slippage: appDataKeccak256=${newAppDataInfo.appDataKeccak256} fullAppData=${newAppDataInfo.fullAppData}`
639
747
  );
640
748
  return {
@@ -644,9 +752,7 @@ async function getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBoo
644
752
  slippageBps: suggestedSlippageBps
645
753
  };
646
754
  } else {
647
- (0, import_sdk_common9.log)(
648
- `Suggested slippage is only ${suggestedSlippageBps} BPS. Using the default slippage (${defaultSlippageBps} BPS)`
649
- );
755
+ (0, import_sdk_common11.log)(`No suggested slippage. Using the default slippage (${defaultSlippageBps} BPS)`);
650
756
  }
651
757
  }
652
758
  return {
@@ -661,7 +767,7 @@ async function getQuote(_tradeParameters, trader, advancedSettings, _orderBookAp
661
767
  const { quote, orderBookApi, tradeParameters, slippageBps, suggestedSlippageBps, appDataInfo, isEthFlow } = await getQuoteRaw(_tradeParameters, trader, advancedSettings, _orderBookApi);
662
768
  const { partnerFee, sellTokenDecimals, buyTokenDecimals } = tradeParameters;
663
769
  const { chainId, account: from } = trader;
664
- const amountsAndCosts = (0, import_sdk_order_book6.getQuoteAmountsAndCosts)({
770
+ const amountsAndCosts = (0, import_sdk_order_book7.getQuoteAmountsAndCosts)({
665
771
  orderParams: quote.quote,
666
772
  slippagePercentBps: slippageBps,
667
773
  partnerFeeBps: getPartnerFeeBps(partnerFee),
@@ -688,7 +794,7 @@ async function getQuote(_tradeParameters, trader, advancedSettings, _orderBookAp
688
794
  };
689
795
  }
690
796
  async function getTrader(swapParameters) {
691
- const signer = (0, import_sdk_common9.getGlobalAdapter)().signerOrNull();
797
+ const signer = (0, import_sdk_common11.getGlobalAdapter)().signerOrNull();
692
798
  const account = swapParameters.owner || await signer?.getAddress();
693
799
  return {
694
800
  chainId: swapParameters.chainId,
@@ -697,8 +803,7 @@ async function getTrader(swapParameters) {
697
803
  };
698
804
  }
699
805
  async function getQuoteWithSigner(swapParameters, advancedSettings, orderBookApi) {
700
- const adapter = (0, import_sdk_common9.getGlobalAdapter)();
701
- const signer = swapParameters.signer ? adapter.createSigner(swapParameters.signer) : adapter.signer;
806
+ const signer = resolveSigner(swapParameters.signer);
702
807
  const trader = await getTrader(swapParameters);
703
808
  const result = await getQuote(swapParameters, trader, advancedSettings, orderBookApi);
704
809
  return {
@@ -754,8 +859,8 @@ async function postSwapOrderFromQuote({
754
859
  }
755
860
 
756
861
  // src/postLimitOrder.ts
757
- var import_sdk_order_book7 = require("@cowprotocol/sdk-order-book");
758
- var import_sdk_common10 = require("@cowprotocol/sdk-common");
862
+ var import_sdk_order_book8 = require("@cowprotocol/sdk-order-book");
863
+ var import_sdk_common12 = require("@cowprotocol/sdk-common");
759
864
  async function postLimitOrder(params, advancedSettings, _orderBookApi) {
760
865
  const appDataSlippage = advancedSettings?.appData?.metadata?.quote?.slippageBips;
761
866
  const partnerFeeOverride = advancedSettings?.appData?.metadata?.partnerFee;
@@ -772,9 +877,9 @@ async function postLimitOrder(params, advancedSettings, _orderBookApi) {
772
877
  params.env = "prod";
773
878
  }
774
879
  const { appCode, chainId, sellToken, buyToken, sellAmount, buyAmount, partnerFee } = params;
775
- (0, import_sdk_common10.log)(`Limit order ${sellAmount} ${sellToken} for ${buyAmount} ${buyToken} on chain ${chainId}`);
776
- const orderBookApi = _orderBookApi || new import_sdk_order_book7.OrderBookApi({ chainId, env: params.env });
777
- (0, import_sdk_common10.log)("Building app data...");
880
+ (0, import_sdk_common12.log)(`Limit order ${sellAmount} ${sellToken} for ${buyAmount} ${buyToken} on chain ${chainId}`);
881
+ const orderBookApi = _orderBookApi || new import_sdk_order_book8.OrderBookApi({ chainId, env: params.env });
882
+ (0, import_sdk_common12.log)("Building app data...");
778
883
  const appDataInfo = await buildAppData(
779
884
  {
780
885
  slippageBps: params.slippageBps,
@@ -787,35 +892,109 @@ async function postLimitOrder(params, advancedSettings, _orderBookApi) {
787
892
  return postCoWProtocolTrade(orderBookApi, appDataInfo, params, advancedSettings?.additionalParams, params.signer);
788
893
  }
789
894
 
790
- // src/getPreSignTransaction.ts
895
+ // src/getSettlementContract.ts
896
+ var import_sdk_common13 = require("@cowprotocol/sdk-common");
791
897
  var import_sdk_config5 = require("@cowprotocol/sdk-config");
792
- var import_sdk_common11 = require("@cowprotocol/sdk-common");
793
- async function getPreSignTransaction(signer, chainId, account, orderId) {
794
- const contract = import_sdk_common11.ContractFactory.createSettlementContract(account, signer);
795
- const settlementContractAddress = import_sdk_config5.COW_PROTOCOL_SETTLEMENT_CONTRACT_ADDRESS[chainId];
898
+ function getSettlementContract(chainId, signer) {
899
+ return import_sdk_common13.ContractFactory.createSettlementContract(import_sdk_config5.COW_PROTOCOL_SETTLEMENT_CONTRACT_ADDRESS[chainId], signer);
900
+ }
901
+
902
+ // src/getPreSignTransaction.ts
903
+ async function getPreSignTransaction(signer, chainId, orderId) {
904
+ const contract = getSettlementContract(chainId, signer);
796
905
  const preSignatureCall = contract.interface.encodeFunctionData("setPreSignature", [orderId, true]);
797
906
  const gas = await contract.estimateGas.setPreSignature?.(orderId, true).catch(() => GAS_LIMIT_DEFAULT) || GAS_LIMIT_DEFAULT;
798
907
  return {
799
908
  data: preSignatureCall,
800
909
  gasLimit: "0x" + calculateGasMargin(gas).toString(16),
801
- to: settlementContractAddress,
802
- // Para onde enviar a transação
910
+ to: contract.address,
803
911
  value: "0"
804
912
  };
805
913
  }
806
914
 
807
915
  // src/tradingSdk.ts
808
- var import_sdk_common12 = require("@cowprotocol/sdk-common");
809
- var import_sdk_common13 = require("@cowprotocol/sdk-common");
916
+ var import_sdk_common14 = require("@cowprotocol/sdk-common");
917
+ var import_sdk_order_signing4 = require("@cowprotocol/sdk-order-signing");
918
+
919
+ // src/onChainCancellation.ts
920
+ var CANCELLATION_GAS_LIMIT_DEFAULT = 150000n;
921
+ async function getEthFlowCancellation(ethFlowContract, order) {
922
+ const cancelOrderParams = {
923
+ buyToken: order.buyToken,
924
+ receiver: order.receiver || order.owner,
925
+ sellAmount: order.sellAmount,
926
+ buyAmount: order.buyAmount,
927
+ appData: order.appData.toString(),
928
+ feeAmount: order.feeAmount,
929
+ validTo: order.validTo.toString(),
930
+ partiallyFillable: false,
931
+ quoteId: 0
932
+ // value doesn't matter, set to 0 for reducing gas costs
933
+ };
934
+ return getOnChainCancellation(ethFlowContract, cancelOrderParams);
935
+ }
936
+ async function getSettlementCancellation(settlementContract, order) {
937
+ const cancelOrderParams = order.uid;
938
+ return getOnChainCancellation(settlementContract, cancelOrderParams);
939
+ }
940
+ async function getOnChainCancellation(contract, cancelOrderParams) {
941
+ const estimatedGas = await (async () => {
942
+ try {
943
+ if (contract.estimateGas.invalidateOrder) {
944
+ const estimated = await contract.estimateGas.invalidateOrder(cancelOrderParams);
945
+ return BigInt(estimated.toHexString ? estimated.toHexString() : `0x${estimated.toString(16)}`);
946
+ }
947
+ return CANCELLATION_GAS_LIMIT_DEFAULT;
948
+ } catch (error) {
949
+ console.error(error);
950
+ return CANCELLATION_GAS_LIMIT_DEFAULT;
951
+ }
952
+ })();
953
+ const data = contract.interface.encodeFunctionData("invalidateOrder", [cancelOrderParams]);
954
+ return {
955
+ estimatedGas,
956
+ transaction: {
957
+ data,
958
+ gasLimit: "0x" + estimatedGas.toString(16),
959
+ to: contract.address,
960
+ value: "0x0"
961
+ }
962
+ };
963
+ }
964
+
965
+ // src/utils/resolveOrderBookApi.ts
966
+ var import_sdk_order_book9 = require("@cowprotocol/sdk-order-book");
967
+ var orderBookApiCache = /* @__PURE__ */ new Map([
968
+ ["prod", /* @__PURE__ */ new Map()],
969
+ ["staging", /* @__PURE__ */ new Map()]
970
+ ]);
971
+ function resolveOrderBookApi(chainId, env, existingOrderBookApi) {
972
+ if (existingOrderBookApi) {
973
+ existingOrderBookApi.context.chainId = chainId;
974
+ existingOrderBookApi.context.env = env;
975
+ return existingOrderBookApi;
976
+ }
977
+ const envCache = orderBookApiCache.get(env) ?? /* @__PURE__ */ new Map();
978
+ const cached = envCache.get(chainId);
979
+ if (cached)
980
+ return cached;
981
+ const orderBookApi = new import_sdk_order_book9.OrderBookApi({ chainId, env });
982
+ envCache.set(chainId, orderBookApi);
983
+ orderBookApiCache.set(env, envCache);
984
+ return orderBookApi;
985
+ }
986
+
987
+ // src/tradingSdk.ts
988
+ var import_sdk_config6 = require("@cowprotocol/sdk-config");
810
989
  var TradingSdk = class {
811
990
  constructor(traderParams = {}, options = {}, adapter) {
812
991
  this.traderParams = traderParams;
813
992
  this.options = options;
814
993
  if (options.enableLogging !== void 0) {
815
- (0, import_sdk_common12.enableLogging)(options.enableLogging);
994
+ (0, import_sdk_common14.enableLogging)(options.enableLogging);
816
995
  }
817
996
  if (adapter) {
818
- (0, import_sdk_common13.setGlobalAdapter)(adapter);
997
+ (0, import_sdk_common14.setGlobalAdapter)(adapter);
819
998
  }
820
999
  }
821
1000
  setTraderParams(params) {
@@ -847,7 +1026,7 @@ var TradingSdk = class {
847
1026
  }),
848
1027
  // It's important to get a fresh instance of the signer
849
1028
  // Because quote might be called with another signer
850
- signer: (0, import_sdk_common12.getGlobalAdapter)().signer
1029
+ signer: (0, import_sdk_common14.getGlobalAdapter)().signer
851
1030
  }
852
1031
  },
853
1032
  advancedSettings2
@@ -908,16 +1087,123 @@ var TradingSdk = class {
908
1087
  );
909
1088
  }
910
1089
  async getPreSignTransaction(params) {
911
- const adapter = (0, import_sdk_common12.getGlobalAdapter)();
912
1090
  const traderParams = this.mergeParams(params);
913
- const signer = traderParams.signer ? adapter.createSigner(traderParams.signer) : adapter.signer;
914
- return getPreSignTransaction(signer, traderParams.chainId, params.account, params.orderId);
1091
+ const signer = resolveSigner(traderParams.signer);
1092
+ return getPreSignTransaction(signer, traderParams.chainId, params.orderUid);
1093
+ }
1094
+ async getOrder(params) {
1095
+ const orderBookApi = this.resolveOrderBookApi(params);
1096
+ return orderBookApi.getOrder(params.orderUid);
1097
+ }
1098
+ async offChainCancelOrder(params) {
1099
+ const orderBookApi = this.resolveOrderBookApi(params);
1100
+ const signer = resolveSigner(params.signer);
1101
+ const { orderUid } = params;
1102
+ const chainId = params.chainId || this.traderParams.chainId;
1103
+ if (!chainId) {
1104
+ throw new Error("Chain ID is missing in offChainCancelOrder() call");
1105
+ }
1106
+ const orderCancellationSigning = await import_sdk_order_signing4.OrderSigningUtils.signOrderCancellations([orderUid], chainId, signer);
1107
+ await orderBookApi.sendSignedOrderCancellations({
1108
+ ...orderCancellationSigning,
1109
+ orderUids: [orderUid]
1110
+ });
1111
+ return true;
1112
+ }
1113
+ async onChainCancelOrder(params, _order) {
1114
+ const chainId = params.chainId || this.traderParams.chainId;
1115
+ if (!chainId) {
1116
+ throw new Error("Chain ID is missing in offChainCancelOrder() call");
1117
+ }
1118
+ const order = _order ?? await this.getOrder(params);
1119
+ const isEthFlowOrder = !!order.onchainOrderData;
1120
+ const signer = params.signer ? (0, import_sdk_common14.getGlobalAdapter)().createSigner(params.signer) : (0, import_sdk_common14.getGlobalAdapter)().signer;
1121
+ const { transaction } = await (isEthFlowOrder ? getEthFlowCancellation(getEthFlowContract(signer, chainId, params.env ?? this.traderParams.env), order) : getSettlementCancellation(getSettlementContract(chainId, signer), order));
1122
+ const txReceipt = await signer.sendTransaction(transaction);
1123
+ return txReceipt.hash;
1124
+ }
1125
+ /**
1126
+ * Checks the current allowance for the CoW Protocol Vault Relayer to spend an ERC-20 token.
1127
+ *
1128
+ * @param params - Parameters including token address and owner address
1129
+ * @returns Promise resolving to the current allowance amount as a bigint
1130
+ *
1131
+ * @example
1132
+ * ```typescript
1133
+ * const params = {
1134
+ * tokenAddress: '0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48', // USDC
1135
+ * owner: '0x123...',
1136
+ * chainId: 1,
1137
+ * }
1138
+ *
1139
+ * const allowance = await sdk.getCowProtocolAllowance(params)
1140
+ * console.log('Current allowance:', allowance.toString())
1141
+ * ```
1142
+ */
1143
+ async getCowProtocolAllowance(params) {
1144
+ const chainId = params.chainId || this.traderParams.chainId;
1145
+ if (!chainId) {
1146
+ throw new Error("Chain ID is missing in getCowProtocolAllowance() call");
1147
+ }
1148
+ const adapter = (0, import_sdk_common14.getGlobalAdapter)();
1149
+ const vaultRelayerAddress = import_sdk_config6.COW_PROTOCOL_VAULT_RELAYER_ADDRESS[chainId];
1150
+ return await adapter.readContract({
1151
+ address: params.tokenAddress,
1152
+ abi: ERC20_ALLOWANCE_ABI,
1153
+ functionName: "allowance",
1154
+ args: [params.owner, vaultRelayerAddress]
1155
+ });
1156
+ }
1157
+ /**
1158
+ * Approves the CoW Protocol Vault Relayer to spend a specified amount of an ERC-20 token.
1159
+ * This method creates an on-chain approval transaction.
1160
+ *
1161
+ * @param params - Parameters including token address and amount to approve
1162
+ * @returns Promise resolving to the transaction hash of the approval transaction
1163
+ *
1164
+ * @example
1165
+ * ```typescript
1166
+ * const params = {
1167
+ * tokenAddress: '0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48', // USDC
1168
+ * amount: '1000000000', // 1000 USDC (6 decimals)
1169
+ * chainId: 1,
1170
+ * }
1171
+ *
1172
+ * const txHash = await sdk.approveCowProtocol(params)
1173
+ * console.log('Approval transaction:', txHash)
1174
+ * ```
1175
+ */
1176
+ async approveCowProtocol(params) {
1177
+ const chainId = params.chainId || this.traderParams.chainId;
1178
+ if (!chainId) {
1179
+ throw new Error("Chain ID is missing in approveCowProtocol() call");
1180
+ }
1181
+ const adapter = (0, import_sdk_common14.getGlobalAdapter)();
1182
+ const signer = resolveSigner(params.signer);
1183
+ const vaultRelayerAddress = import_sdk_config6.COW_PROTOCOL_VAULT_RELAYER_ADDRESS[chainId];
1184
+ const txParams = {
1185
+ to: params.tokenAddress,
1186
+ data: adapter.utils.encodeFunction(ERC20_APPROVE_ABI, "approve", [
1187
+ vaultRelayerAddress,
1188
+ "0x" + params.amount.toString(16)
1189
+ ])
1190
+ };
1191
+ const txReceipt = await signer.sendTransaction(txParams);
1192
+ return txReceipt.hash;
1193
+ }
1194
+ resolveOrderBookApi(params) {
1195
+ const chainId = params.chainId ?? this.traderParams.chainId;
1196
+ const env = params.env ?? this.traderParams.env ?? "prod";
1197
+ if (!chainId) {
1198
+ throw new Error("Chain ID is missing in getOrder() call");
1199
+ }
1200
+ return resolveOrderBookApi(chainId, env);
915
1201
  }
916
1202
  mergeParams(params) {
917
1203
  const { chainId, signer, appCode, env } = params;
918
1204
  const traderParams = {
919
1205
  chainId: chainId || this.traderParams.chainId,
920
- signer: signer || this.traderParams.signer || (0, import_sdk_common12.getGlobalAdapter)().signer,
1206
+ signer: signer || this.traderParams.signer || (0, import_sdk_common14.getGlobalAdapter)().signer,
921
1207
  appCode: appCode || this.traderParams.appCode,
922
1208
  env: env || this.traderParams.env
923
1209
  };