@subwallet/extension-base 1.3.39-0 → 1.3.41-0

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.
Files changed (55) hide show
  1. package/cjs/constants/environment.js +4 -2
  2. package/cjs/koni/background/handlers/Extension.js +114 -105
  3. package/cjs/packageInfo.js +1 -1
  4. package/cjs/services/balance-service/helpers/subscribe/evm.js +6 -1
  5. package/cjs/services/balance-service/transfer/xcm/index.js +26 -29
  6. package/cjs/services/balance-service/transfer/xcm/utils.js +52 -56
  7. package/cjs/services/chain-service/constants.js +6 -5
  8. package/cjs/services/chain-service/handler/CardanoApi.js +25 -35
  9. package/cjs/services/chain-service/index.js +4 -0
  10. package/cjs/services/chain-service/utils/patch.js +1 -1
  11. package/cjs/services/earning-service/handlers/native-staking/tao.js +4 -38
  12. package/cjs/services/earning-service/handlers/special.js +28 -36
  13. package/cjs/services/swap-service/handler/base-handler.js +58 -53
  14. package/cjs/services/swap-service/handler/chainflip-handler.js +29 -18
  15. package/cjs/services/swap-service/handler/kyber-handler.js +46 -34
  16. package/cjs/services/swap-service/handler/simpleswap-handler.js +79 -43
  17. package/cjs/services/swap-service/handler/uniswap-handler.js +5 -12
  18. package/cjs/services/swap-service/utils.js +48 -37
  19. package/cjs/types/environment.js +19 -0
  20. package/cjs/utils/environment.js +30 -2
  21. package/cjs/utils/fee/transfer.js +41 -33
  22. package/constants/environment.d.ts +1 -0
  23. package/constants/environment.js +2 -1
  24. package/koni/background/handlers/Extension.js +52 -43
  25. package/package.json +12 -7
  26. package/packageInfo.js +1 -1
  27. package/services/balance-service/helpers/subscribe/evm.js +6 -1
  28. package/services/balance-service/transfer/xcm/index.d.ts +1 -2
  29. package/services/balance-service/transfer/xcm/index.js +23 -26
  30. package/services/balance-service/transfer/xcm/utils.d.ts +38 -6
  31. package/services/balance-service/transfer/xcm/utils.js +51 -55
  32. package/services/chain-service/constants.d.ts +1 -0
  33. package/services/chain-service/constants.js +6 -5
  34. package/services/chain-service/handler/CardanoApi.d.ts +1 -5
  35. package/services/chain-service/handler/CardanoApi.js +26 -34
  36. package/services/chain-service/index.js +4 -0
  37. package/services/chain-service/utils/patch.js +1 -1
  38. package/services/earning-service/handlers/native-staking/tao.d.ts +0 -11
  39. package/services/earning-service/handlers/native-staking/tao.js +4 -24
  40. package/services/earning-service/handlers/special.js +12 -20
  41. package/services/swap-service/handler/base-handler.js +11 -6
  42. package/services/swap-service/handler/chainflip-handler.d.ts +0 -2
  43. package/services/swap-service/handler/chainflip-handler.js +25 -13
  44. package/services/swap-service/handler/kyber-handler.d.ts +0 -1
  45. package/services/swap-service/handler/kyber-handler.js +46 -33
  46. package/services/swap-service/handler/simpleswap-handler.d.ts +0 -1
  47. package/services/swap-service/handler/simpleswap-handler.js +80 -43
  48. package/services/swap-service/handler/uniswap-handler.js +6 -13
  49. package/services/swap-service/utils.d.ts +0 -13
  50. package/services/swap-service/utils.js +48 -34
  51. package/types/environment.d.ts +9 -0
  52. package/types/environment.js +13 -0
  53. package/utils/environment.d.ts +2 -0
  54. package/utils/environment.js +27 -1
  55. package/utils/fee/transfer.js +11 -3
@@ -10,9 +10,10 @@ var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
10
10
  var _constants = require("@subwallet/extension-base/constants");
11
11
  var _utils = require("@subwallet/extension-base/koni/api/yield/helper/utils");
12
12
  var _xcm = require("@subwallet/extension-base/services/balance-service/transfer/xcm");
13
- var _utils2 = require("@subwallet/extension-base/services/chain-service/utils");
13
+ var _utils2 = require("@subwallet/extension-base/services/balance-service/transfer/xcm/utils");
14
+ var _utils3 = require("@subwallet/extension-base/services/chain-service/utils");
14
15
  var _types = require("@subwallet/extension-base/types");
15
- var _utils3 = require("@subwallet/extension-base/utils");
16
+ var _utils4 = require("@subwallet/extension-base/utils");
16
17
  var _getId = require("@subwallet/extension-base/utils/getId");
17
18
  var _bignumber = _interopRequireDefault(require("bignumber.js"));
18
19
  var _i18next = require("i18next");
@@ -28,7 +29,7 @@ class BaseSpecialStakingPoolHandler extends _base.default {
28
29
  rate = 0;
29
30
  constructor(state, chain) {
30
31
  super(state, chain);
31
- this.exchangeRatePromise = (0, _utils3.createPromiseHandler)();
32
+ this.exchangeRatePromise = (0, _utils4.createPromiseHandler)();
32
33
  }
33
34
  get metadataInfo() {
34
35
  return {
@@ -85,20 +86,20 @@ class BaseSpecialStakingPoolHandler extends _base.default {
85
86
  const bnMinJoinPool = new _util.BN(poolInfo.statistic.earningThreshold.join);
86
87
  const inputTokenInfo = this.state.chainService.getAssetBySlug(this.inputAsset);
87
88
  const altInputTokenInfo = this.state.chainService.getAssetBySlug(this.altInputAsset);
88
- const existentialDeposit = new _util.BN((0, _utils2._getAssetExistentialDeposit)(altInputTokenInfo));
89
+ const existentialDeposit = new _util.BN((0, _utils3._getAssetExistentialDeposit)(altInputTokenInfo));
89
90
  const bnAltInputAssetBalance = new _util.BN(altInputAssetBalance.value);
90
91
  if (bnInputAssetBalance.add(bnAltInputAssetBalance).lt(bnMinJoinPool)) {
91
92
  const missingAmount = bnMinJoinPool.sub(bnInputAssetBalance).sub(bnAltInputAssetBalance);
92
93
  const isTheSame = missingAmount.toString() === bnMinJoinPool.toString();
93
94
  const originChain = this.state.getChainInfo(inputTokenInfo.originChain);
94
95
  const altChain = this.state.getChainInfo(altInputTokenInfo.originChain);
95
- const originSymbol = (0, _utils2._getAssetSymbol)(inputTokenInfo);
96
- const altSymbol = (0, _utils2._getAssetSymbol)(altInputTokenInfo);
96
+ const originSymbol = (0, _utils3._getAssetSymbol)(inputTokenInfo);
97
+ const altSymbol = (0, _utils3._getAssetSymbol)(altInputTokenInfo);
97
98
  const originName = originChain.name;
98
99
  const altName = altChain.name;
99
- const parsedMinJoinPool = (0, _utils3.formatNumber)(missingAmount.toString(), inputAssetInfo.decimals || 0);
100
+ const parsedMinJoinPool = (0, _utils4.formatNumber)(missingAmount.toString(), inputAssetInfo.decimals || 0);
100
101
  const formatparsedMinJoinPool = isTheSame ? parsedMinJoinPool : Number(parsedMinJoinPool) + 0.01;
101
- const parsedMinAltJoinPool = (0, _utils3.formatNumber)(missingAmount.add(existentialDeposit).toString(), inputAssetInfo.decimals || 0);
102
+ const parsedMinAltJoinPool = (0, _utils4.formatNumber)(missingAmount.add(existentialDeposit).toString(), inputAssetInfo.decimals || 0);
102
103
  const formatParsedMinAltJoinPool = isTheSame ? parsedMinAltJoinPool : Number(parsedMinAltJoinPool) + 0.01;
103
104
  return {
104
105
  passed: false,
@@ -224,35 +225,26 @@ class BaseSpecialStakingPoolHandler extends _base.default {
224
225
  const altChainInfo = this.state.getChainInfo(altInputTokenInfo.originChain);
225
226
  const symbol = altInputTokenInfo.symbol;
226
227
  const networkName = altChainInfo.name;
227
- const xcmOriginSubstrateApi = await this.state.getSubstrateApi(altInputTokenInfo.originChain).isReady;
228
- const id = (0, _getId.getId)();
229
- const feeInfo = await this.state.feeService.subscribeChainFee(id, altChainInfo.slug, 'substrate');
230
- const xcmRequest = {
231
- sender: address,
232
- originTokenInfo: altInputTokenInfo,
233
- destinationTokenInfo: inputTokenInfo,
234
- sendingValue: bnAmount.toString(),
235
- recipient: address,
236
- destinationChain: this.chainInfo,
237
- originChain: altChainInfo,
238
- substrateApi: xcmOriginSubstrateApi,
239
- feeInfo
240
- };
241
228
 
242
229
  // TODO: calculate fee for destination chain
243
- let xcmFee;
244
- const xcmFeeByDryRun = await (0, _xcm.dryRunXcmExtrinsicV2)(xcmRequest);
245
- if (xcmFeeByDryRun.fee) {
246
- xcmFee = (0, _bignumber.default)(xcmFeeByDryRun.fee).multipliedBy(_constants.XCM_MIN_AMOUNT_RATIO).toFixed(0, 1);
247
- } else {
230
+ const xcmFeeInfo = await (0, _utils2.estimateXcmFee)({
231
+ fromChainInfo: altChainInfo,
232
+ fromTokenInfo: altInputTokenInfo,
233
+ toChainInfo: this.chainInfo,
234
+ recipient: address,
235
+ sender: address,
236
+ value: bnAmount.toString()
237
+ });
238
+ if (!xcmFeeInfo) {
248
239
  throw new Error('Error estimating XCM fee');
249
240
  }
241
+ const xcmFee = (0, _bignumber.default)(xcmFeeInfo.origin.fee).multipliedBy(_constants.XCM_MIN_AMOUNT_RATIO).toFixed(0, 1);
250
242
  const fee = {
251
243
  slug: altInputTokenSlug,
252
244
  amount: xcmFee
253
245
  };
254
246
  let bnTransferAmount = bnAmount.sub(bnInputTokenBalance);
255
- if ((0, _utils2._isNativeToken)(altInputTokenInfo)) {
247
+ if ((0, _utils3._isNativeToken)(altInputTokenInfo)) {
256
248
  const bnXcmFee = new _util.BN(fee.amount || 0); // xcm fee is paid in native token but swap token is not always native token
257
249
 
258
250
  bnTransferAmount = bnTransferAmount.add(bnXcmFee);
@@ -316,14 +308,14 @@ class BaseSpecialStakingPoolHandler extends _base.default {
316
308
  processValidation.ok = false;
317
309
  processValidation.status = _types.YieldValidationStatus.NOT_ENOUGH_BALANCE;
318
310
  const bnMaxXCM = new _util.BN(altInputTokenBalance.value).sub(xcmFee.mul(new _util.BN(_constants.XCM_FEE_RATIO)));
319
- const inputTokenDecimal = (0, _utils2._getAssetDecimals)(inputTokenInfo);
311
+ const inputTokenDecimal = (0, _utils3._getAssetDecimals)(inputTokenInfo);
320
312
  const maxBn = bnInputTokenBalance.add(new _util.BN(altInputTokenBalance.value)).sub(xcmFee).sub(xcmFee);
321
- const maxValue = (0, _utils3.formatNumber)(maxBn.toString(), inputTokenInfo.decimals || 0);
322
- const maxXCMValue = (0, _utils3.formatNumber)(bnMaxXCM.toString(), inputTokenDecimal);
323
- const symbol = (0, _utils2._getAssetSymbol)(altInputTokenInfo);
313
+ const maxValue = (0, _utils4.formatNumber)(maxBn.toString(), inputTokenInfo.decimals || 0);
314
+ const maxXCMValue = (0, _utils4.formatNumber)(bnMaxXCM.toString(), inputTokenDecimal);
315
+ const symbol = (0, _utils3._getAssetSymbol)(altInputTokenInfo);
324
316
  const inputNetworkName = this.chainInfo.name;
325
- const altNetworkName = (0, _utils2._getAssetName)(altInputTokenInfo);
326
- const currentValue = (0, _utils3.formatNumber)(bnInputTokenBalance.toString(), inputTokenDecimal);
317
+ const altNetworkName = (0, _utils3._getAssetName)(altInputTokenInfo);
318
+ const currentValue = (0, _utils4.formatNumber)(bnInputTokenBalance.toString(), inputTokenDecimal);
327
319
  processValidation.message = (0, _i18next.t)('You can only enter a maximum of {{maxValue}} {{symbol}}, which is {{currentValue}} {{symbol}} ({{inputNetworkName}}) and {{maxXCMValue}} {{symbol}} ({{altNetworkName}}). Lower your amount and try again.', {
328
320
  replace: {
329
321
  symbol,
@@ -379,7 +371,7 @@ class BaseSpecialStakingPoolHandler extends _base.default {
379
371
  processValidation.failedStep = path.steps[id];
380
372
  processValidation.ok = false;
381
373
  processValidation.status = _types.YieldValidationStatus.NOT_ENOUGH_BALANCE;
382
- const maxString = (0, _utils3.formatNumber)(bnInputTokenBalance.toString(), inputTokenInfo.decimals || 0);
374
+ const maxString = (0, _utils4.formatNumber)(bnInputTokenBalance.toString(), inputTokenInfo.decimals || 0);
383
375
  if (maxString !== '0') {
384
376
  processValidation.message = (0, _i18next.t)('Amount must be equal or less than {{number}}', {
385
377
  replace: {
@@ -443,7 +435,7 @@ class BaseSpecialStakingPoolHandler extends _base.default {
443
435
  const altInputTokenSlug = this.altInputAsset || '';
444
436
  const altInputTokenInfo = this.state.getAssetBySlug(altInputTokenSlug);
445
437
  const originChainInfo = this.state.getChainInfo(altInputTokenInfo.originChain);
446
- const originTokenSlug = (0, _utils2._getChainNativeTokenSlug)(originChainInfo);
438
+ const originTokenSlug = (0, _utils3._getChainNativeTokenSlug)(originChainInfo);
447
439
  const originTokenInfo = this.state.getAssetBySlug(originTokenSlug);
448
440
  const destinationTokenInfo = this.state.getAssetBySlug(destinationTokenSlug);
449
441
  const substrateApi = this.state.getSubstrateApi(originChainInfo.slug);
@@ -13,12 +13,13 @@ var _xcmParser = require("@subwallet/extension-base/core/substrate/xcm-parser");
13
13
  var _utils = require("@subwallet/extension-base/core/utils");
14
14
  var _xcm = require("@subwallet/extension-base/services/balance-service/transfer/xcm");
15
15
  var _acrossBridge = require("@subwallet/extension-base/services/balance-service/transfer/xcm/acrossBridge");
16
- var _utils2 = require("@subwallet/extension-base/services/chain-service/utils");
17
- var _utils3 = require("@subwallet/extension-base/services/swap-service/utils");
16
+ var _utils2 = require("@subwallet/extension-base/services/balance-service/transfer/xcm/utils");
17
+ var _utils3 = require("@subwallet/extension-base/services/chain-service/utils");
18
+ var _utils4 = require("@subwallet/extension-base/services/swap-service/utils");
18
19
  var _types = require("@subwallet/extension-base/types");
19
20
  var _serviceBase = require("@subwallet/extension-base/types/service-base");
20
21
  var _swap = require("@subwallet/extension-base/types/swap");
21
- var _utils4 = require("@subwallet/extension-base/utils");
22
+ var _utils5 = require("@subwallet/extension-base/utils");
22
23
  var _getId = require("@subwallet/extension-base/utils/getId");
23
24
  var _bignumber = _interopRequireDefault(require("bignumber.js"));
24
25
  var _i18next = require("i18next");
@@ -97,12 +98,12 @@ class SwapBaseHandler {
97
98
  throw Error('Token or chain not found');
98
99
  }
99
100
  let recipientAddress;
100
- const senderAddress = (0, _utils4._reformatAddressWithChain)(address, fromChainInfo);
101
+ const senderAddress = (0, _utils5._reformatAddressWithChain)(address, fromChainInfo);
101
102
  if (stepIndex === 0) {
102
- recipientAddress = (0, _utils4._reformatAddressWithChain)(address, toChainInfo);
103
+ recipientAddress = (0, _utils5._reformatAddressWithChain)(address, toChainInfo);
103
104
  } else {
104
105
  // bridge after swap
105
- recipientAddress = (0, _utils4._reformatAddressWithChain)(recipient || address, toChainInfo);
106
+ recipientAddress = (0, _utils5._reformatAddressWithChain)(recipient || address, toChainInfo);
106
107
  }
107
108
  if (!(0, _xcmParser._isXcmWithinSameConsensus)(fromChainInfo, toChainInfo) || (0, _xcmParser._isSnowBridgeXcm)(fromChainInfo, toChainInfo) || (0, _xcmParser._isAcrossBridgeXcm)(fromChainInfo, toChainInfo)) {
108
109
  return undefined;
@@ -129,21 +130,25 @@ class SwapBaseHandler {
129
130
  };
130
131
 
131
132
  // TODO: calculate fee for destination chain
132
- const bridgeFeeByDryRun = await (0, _xcm.dryRunXcmExtrinsicV2)(xcmRequest);
133
- if (!bridgeFeeByDryRun.fee) {
134
- return undefined;
135
- }
136
- const estimatedBridgeFee = (0, _bignumber.default)(bridgeFeeByDryRun.fee).multipliedBy(_utils3.FEE_RATE_MULTIPLIER.medium).toFixed(0, 1);
133
+ const xcmFeeInfo = await (0, _utils2.estimateXcmFee)({
134
+ fromChainInfo: xcmRequest.originChain,
135
+ fromTokenInfo: xcmRequest.originTokenInfo,
136
+ toChainInfo: xcmRequest.destinationChain,
137
+ recipient: xcmRequest.recipient,
138
+ sender: xcmRequest.sender,
139
+ value: xcmRequest.sendingValue
140
+ });
141
+ const estimatedBridgeFee = (0, _bignumber.default)((xcmFeeInfo === null || xcmFeeInfo === void 0 ? void 0 : xcmFeeInfo.origin.fee) || '0').multipliedBy(_utils4.FEE_RATE_MULTIPLIER.medium).toFixed(0, 1);
137
142
  const fee = {
138
143
  feeComponent: [{
139
144
  feeType: _swap.SwapFeeType.NETWORK_FEE,
140
145
  amount: estimatedBridgeFee,
141
- tokenSlug: (0, _utils2._getChainNativeTokenSlug)(fromChainInfo)
146
+ tokenSlug: (0, _utils3._getChainNativeTokenSlug)(fromChainInfo)
142
147
  }],
143
- defaultFeeToken: (0, _utils2._getChainNativeTokenSlug)(fromChainInfo),
144
- feeOptions: [(0, _utils2._getChainNativeTokenSlug)(fromChainInfo)]
148
+ defaultFeeToken: (0, _utils3._getChainNativeTokenSlug)(fromChainInfo),
149
+ feeOptions: [(0, _utils3._getChainNativeTokenSlug)(fromChainInfo)]
145
150
  };
146
- const isBridgeNativeToken = (0, _utils2._isNativeToken)(fromTokenInfo);
151
+ const isBridgeNativeToken = (0, _utils3._isNativeToken)(fromTokenInfo);
147
152
  let bnSendingValue;
148
153
  let expectedReceive;
149
154
  const actionList = JSON.stringify(path.map(step => step.action));
@@ -156,30 +161,30 @@ class SwapBaseHandler {
156
161
  expectedReceive = fromAmount;
157
162
  bnSendingValue = (0, _bignumber.default)(fromAmount);
158
163
  if (needEditAmount) {
159
- bnSendingValue = bnSendingValue.multipliedBy(_utils3.DEFAULT_EXCESS_AMOUNT_WEIGHT);
164
+ bnSendingValue = bnSendingValue.multipliedBy(_utils4.DEFAULT_EXCESS_AMOUNT_WEIGHT);
160
165
  expectedReceive = bnSendingValue.toFixed(0, 1);
161
166
  }
162
167
  if (isBridgeNativeToken) {
163
168
  bnSendingValue = bnSendingValue.plus((0, _bignumber.default)(estimatedBridgeFee));
164
169
  } else {
165
- bnSendingValue = bnSendingValue.plus((0, _bignumber.default)((0, _utils2._getTokenMinAmount)(toTokenInfo)).multipliedBy(_utils3.FEE_RATE_MULTIPLIER.medium)).plus((0, _utils2._getTokenMinAmount)(toTokenInfo));
170
+ bnSendingValue = bnSendingValue.plus((0, _bignumber.default)((0, _utils3._getTokenMinAmount)(toTokenInfo)).multipliedBy(_utils4.FEE_RATE_MULTIPLIER.medium)).plus((0, _utils3._getTokenMinAmount)(toTokenInfo));
166
171
  }
167
172
  if ((0, _bignumber.default)(toTokenBalance.value).lte(0)) {
168
- bnSendingValue = bnSendingValue.plus((0, _utils2._getTokenMinAmount)(toTokenInfo));
173
+ bnSendingValue = bnSendingValue.plus((0, _utils3._getTokenMinAmount)(toTokenInfo));
169
174
  }
170
175
  } else {
171
176
  // bridge after swap
172
177
  expectedReceive = selectedQuote.toAmount;
173
178
  if (needEditAmount) {
174
- bnSendingValue = (0, _bignumber.default)(selectedQuote.toAmount).multipliedBy(_utils3.DEFAULT_EXCESS_AMOUNT_WEIGHT); // need to round
179
+ bnSendingValue = (0, _bignumber.default)(selectedQuote.toAmount).multipliedBy(_utils4.DEFAULT_EXCESS_AMOUNT_WEIGHT); // need to round
175
180
  } else {
176
181
  // todo: remove
177
182
  console.log('The code cannot run into here, if it runs into here, pls ask dev to check');
178
183
  bnSendingValue = (0, _bignumber.default)(selectedQuote.toAmount);
179
184
  }
180
185
  }
181
- if (toTokenInfo.originChain === 'mythos' && (0, _utils2._isNativeToken)(toTokenInfo)) {
182
- bnSendingValue = bnSendingValue.plus((0, _bignumber.default)(2.5).shiftedBy((0, _utils2._getAssetDecimals)(toTokenInfo)));
186
+ if (toTokenInfo.originChain === 'mythos' && (0, _utils3._isNativeToken)(toTokenInfo)) {
187
+ bnSendingValue = bnSendingValue.plus((0, _bignumber.default)(2.5).shiftedBy((0, _utils3._getAssetDecimals)(toTokenInfo)));
183
188
  }
184
189
  const step = {
185
190
  // @ts-ignore
@@ -248,7 +253,7 @@ class SwapBaseHandler {
248
253
  return {
249
254
  txChain: originAsset.originChain,
250
255
  extrinsic,
251
- transferNativeAmount: (0, _utils2._isNativeToken)(originAsset) ? briefXcmStep.sendingValue : '0',
256
+ transferNativeAmount: (0, _utils3._isNativeToken)(originAsset) ? briefXcmStep.sendingValue : '0',
252
257
  extrinsicType: _KoniTypes.ExtrinsicType.TRANSFER_XCM,
253
258
  chainType: _KoniTypes.ChainType.SUBSTRATE,
254
259
  txData: xcmData
@@ -291,7 +296,7 @@ class SwapBaseHandler {
291
296
  return {
292
297
  txChain: originTokenInfo.originChain,
293
298
  extrinsic: tx,
294
- transferNativeAmount: (0, _utils2._isNativeToken)(originTokenInfo) ? bridgeStep.sendingValue : '0',
299
+ transferNativeAmount: (0, _utils3._isNativeToken)(originTokenInfo) ? bridgeStep.sendingValue : '0',
295
300
  extrinsicType: _KoniTypes.ExtrinsicType.TRANSFER_XCM,
296
301
  chainType: _KoniTypes.ChainType.EVM,
297
302
  txData: txData
@@ -313,14 +318,14 @@ class SwapBaseHandler {
313
318
  return [];
314
319
  }
315
320
  async validateBridgeStep(receiver, fromToken, toToken, selectedFeeToken, toChainNativeToken, bnBridgeAmount, bnFromTokenBalance, bnBridgeFeeAmount, bnFeeTokenBalance, bnBridgeDeliveryFee) {
316
- const minBridgeAmountRequired = new _bignumber.default((0, _utils2._getTokenMinAmount)(toToken)).multipliedBy(_utils3.FEE_RATE_MULTIPLIER.high);
321
+ const minBridgeAmountRequired = new _bignumber.default((0, _utils3._getTokenMinAmount)(toToken)).multipliedBy(_utils4.FEE_RATE_MULTIPLIER.high);
317
322
  const spendingAndFeePaymentValidation = (0, _logicValidation.validateSpendingAndFeePayment)(fromToken, selectedFeeToken, bnBridgeAmount, bnFromTokenBalance, bnBridgeFeeAmount, bnFeeTokenBalance);
318
323
  if (spendingAndFeePaymentValidation.length > 0) {
319
324
  return spendingAndFeePaymentValidation;
320
325
  }
321
326
  if (bnBridgeAmount.lte(minBridgeAmountRequired.plus(bnBridgeDeliveryFee))) {
322
- const atLeastStr = (0, _utils4.formatNumber)(minBridgeAmountRequired.plus(bnBridgeDeliveryFee), (0, _utils2._getAssetDecimals)(toToken), _utils4.balanceFormatter, {
323
- maxNumberFormat: (0, _utils2._getAssetDecimals)(toToken) || 6
327
+ const atLeastStr = (0, _utils5.formatNumber)(minBridgeAmountRequired.plus(bnBridgeDeliveryFee), (0, _utils3._getAssetDecimals)(toToken), _utils5.balanceFormatter, {
328
+ maxNumberFormat: (0, _utils3._getAssetDecimals)(toToken) || 6
324
329
  });
325
330
  return [new _TransactionError.TransactionError(_types.TransferTxErrorType.RECEIVER_NOT_ENOUGH_EXISTENTIAL_DEPOSIT, (0, _i18next.t)('You must transfer at least {{amount}} {{symbol}} to keep the destination account alive', {
326
331
  replace: {
@@ -329,7 +334,7 @@ class SwapBaseHandler {
329
334
  }
330
335
  }))];
331
336
  }
332
- const isAcrossBridge = (0, _acrossBridge._isAcrossChainBridge)((0, _utils2._getAssetOriginChain)(fromToken), (0, _utils2._getAssetOriginChain)(toToken));
337
+ const isAcrossBridge = (0, _acrossBridge._isAcrossChainBridge)((0, _utils3._getAssetOriginChain)(fromToken), (0, _utils3._getAssetOriginChain)(toToken));
333
338
  if (!isAcrossBridge) {
334
339
  // By here, we know that the user is receiving a valid amount of toToken
335
340
  const toChainApi = this.chainService.getSubstrateApi(toToken.originChain);
@@ -340,7 +345,7 @@ class SwapBaseHandler {
340
345
 
341
346
  // Only need to check if account is alive with the receiving toToken
342
347
  const isToTokenSufficient = await (0, _utils._isSufficientToken)(toToken, toChainApi, sufficientChain);
343
- if (!isToTokenSufficient && !(0, _utils2._isNativeToken)(toToken)) {
348
+ if (!isToTokenSufficient && !(0, _utils3._isNativeToken)(toToken)) {
344
349
  // sending token cannot keep account alive, must check with native token
345
350
  const toChainNativeTokenBalance = await this.balanceService.getTotalBalance(receiver, toToken.originChain, toChainNativeToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_BALANCE);
346
351
  if (!(0, _systemPallet._isAccountActive)(toChainNativeTokenBalance.metadata)) {
@@ -361,20 +366,20 @@ class SwapBaseHandler {
361
366
  if (spendingAndFeePaymentValidation.length > 0) {
362
367
  return spendingAndFeePaymentValidation;
363
368
  }
364
- if (bnExpectedReceivingAmount.lte((0, _utils2._getTokenMinAmount)(receivingToken))) {
365
- const atLeastStr = (0, _utils4.formatNumber)((0, _utils2._getTokenMinAmount)(receivingToken), (0, _utils2._getAssetDecimals)(receivingToken), _utils4.balanceFormatter, {
366
- maxNumberFormat: (0, _utils2._getAssetDecimals)(receivingToken) || 6
369
+ if (bnExpectedReceivingAmount.lte((0, _utils3._getTokenMinAmount)(receivingToken))) {
370
+ const atLeastStr = (0, _utils5.formatNumber)((0, _utils3._getTokenMinAmount)(receivingToken), (0, _utils3._getAssetDecimals)(receivingToken), _utils5.balanceFormatter, {
371
+ maxNumberFormat: (0, _utils3._getAssetDecimals)(receivingToken) || 6
367
372
  });
368
373
  return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)('You can\'t receive less than {{number}} {{symbol}}', {
369
374
  replace: {
370
375
  number: atLeastStr,
371
- symbol: (0, _utils2._getAssetSymbol)(receivingToken)
376
+ symbol: (0, _utils3._getAssetSymbol)(receivingToken)
372
377
  }
373
378
  }))];
374
379
  }
375
380
  if (recipient) {
376
381
  const isEvmAddress = (0, _utilCrypto.isEthereumAddress)(recipient);
377
- const isEvmDestChain = (0, _utils2._isChainEvmCompatible)(swapToChain);
382
+ const isEvmDestChain = (0, _utils3._isChainEvmCompatible)(swapToChain);
378
383
  if (isEvmAddress !== isEvmDestChain) {
379
384
  // todo: update condition if support swap chain # EVM or Substrate
380
385
  return [new _TransactionError.TransactionError(_swap.SwapErrorType.INVALID_RECIPIENT)];
@@ -442,8 +447,8 @@ class SwapBaseHandler {
442
447
  const bridgeSelectedFeeToken = this.chainService.getAssetBySlug(currentFee.selectedFeeToken || currentFee.defaultFeeToken);
443
448
  const bnBridgeDeliveryFee = (0, _bignumber.default)(0); // todo
444
449
 
445
- const bridgeSender = (0, _utils4._reformatAddressWithChain)(xcmMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
446
- const bridgeReceiver = (0, _utils4._reformatAddressWithChain)((_xcmMetadata$receiver = xcmMetadata.receiver) !== null && _xcmMetadata$receiver !== void 0 ? _xcmMetadata$receiver : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
450
+ const bridgeSender = (0, _utils5._reformatAddressWithChain)(xcmMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
451
+ const bridgeReceiver = (0, _utils5._reformatAddressWithChain)((_xcmMetadata$receiver = xcmMetadata.receiver) !== null && _xcmMetadata$receiver !== void 0 ? _xcmMetadata$receiver : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
447
452
  const [bridgeFromTokenBalance, bridgeFeeTokenBalance] = await Promise.all([this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeFromToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM), this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeSelectedFeeToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM)]);
448
453
 
449
454
  // Native token balance has already accounted for ED aka strict mode
@@ -487,11 +492,11 @@ class SwapBaseHandler {
487
492
  if (bnSwapValue.gt(bnBridgeAmount)) {
488
493
  return [new _TransactionError.TransactionError(_types.BasicTxErrorType.INTERNAL_ERROR)];
489
494
  }
490
- if (bnSwapValue.lte((0, _utils2._getTokenMinAmount)(swapToken))) {
491
- const atLeastString = (0, _utils4.formatNumber)((0, _utils2._getTokenMinAmount)(swapToken), (0, _utils2._getAssetDecimals)(swapToken), _utils4.balanceFormatter, {
492
- maxNumberFormat: (0, _utils2._getAssetDecimals)(swapToken) || 6
495
+ if (bnSwapValue.lte((0, _utils3._getTokenMinAmount)(swapToken))) {
496
+ const atLeastString = (0, _utils5.formatNumber)((0, _utils3._getTokenMinAmount)(swapToken), (0, _utils3._getAssetDecimals)(swapToken), _utils5.balanceFormatter, {
497
+ maxNumberFormat: (0, _utils3._getAssetDecimals)(swapToken) || 6
493
498
  });
494
- return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils2._getAssetSymbol)(swapToken)} and try again`))];
499
+ return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils3._getAssetSymbol)(swapToken)} and try again`))];
495
500
  }
496
501
  const swapFeeToken = this.chainService.getAssetBySlug(swapFee.selectedFeeToken || swapFee.defaultFeeToken);
497
502
  const swapToChain = this.chainService.getChainInfoByKey(swapMetadata.destinationTokenInfo.originChain);
@@ -530,11 +535,11 @@ class SwapBaseHandler {
530
535
  const bnSwapReceivingAmount = (0, _bignumber.default)(swapMetadata.expectedReceive);
531
536
  const bnSwapValue = (0, _bignumber.default)(swapMetadata.sendingValue);
532
537
  const bnSwapFeeAmount = (0, _bignumber.default)(swapNetworkFee.amount);
533
- if (bnSwapValue.lte((0, _utils2._getTokenMinAmount)(swapToken))) {
534
- const atLeastString = (0, _utils4.formatNumber)((0, _utils2._getTokenMinAmount)(swapToken), (0, _utils2._getAssetDecimals)(swapToken), _utils4.balanceFormatter, {
535
- maxNumberFormat: (0, _utils2._getAssetDecimals)(swapToken) || 6
538
+ if (bnSwapValue.lte((0, _utils3._getTokenMinAmount)(swapToken))) {
539
+ const atLeastString = (0, _utils5.formatNumber)((0, _utils3._getTokenMinAmount)(swapToken), (0, _utils3._getAssetDecimals)(swapToken), _utils5.balanceFormatter, {
540
+ maxNumberFormat: (0, _utils3._getAssetDecimals)(swapToken) || 6
536
541
  });
537
- return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils2._getAssetSymbol)(swapToken)} and try again`))];
542
+ return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils3._getAssetSymbol)(swapToken)} and try again`))];
538
543
  }
539
544
  const swapFeeToken = this.chainService.getAssetBySlug(swapFee.selectedFeeToken || swapFee.defaultFeeToken);
540
545
  const swapToChain = this.chainService.getChainInfoByKey(swapMetadata.destinationTokenInfo.originChain);
@@ -573,8 +578,8 @@ class SwapBaseHandler {
573
578
  const bridgeSelectedFeeToken = this.chainService.getAssetBySlug(currentFee.selectedFeeToken || currentFee.defaultFeeToken);
574
579
  const bnBridgeDeliveryFee = (0, _bignumber.default)(0); // todo
575
580
 
576
- const bridgeSender = (0, _utils4._reformatAddressWithChain)(xcmMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
577
- const bridgeReceiver = (0, _utils4._reformatAddressWithChain)((_xcmMetadata$receiver2 = xcmMetadata.receiver) !== null && _xcmMetadata$receiver2 !== void 0 ? _xcmMetadata$receiver2 : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
581
+ const bridgeSender = (0, _utils5._reformatAddressWithChain)(xcmMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
582
+ const bridgeReceiver = (0, _utils5._reformatAddressWithChain)((_xcmMetadata$receiver2 = xcmMetadata.receiver) !== null && _xcmMetadata$receiver2 !== void 0 ? _xcmMetadata$receiver2 : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
578
583
  const [bridgeFromTokenBalance, bridgeFeeTokenBalance] = await Promise.all([this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeFromToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM), this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeSelectedFeeToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM)]);
579
584
 
580
585
  // Native token balance has already accounted for ED aka strict mode
@@ -612,8 +617,8 @@ class SwapBaseHandler {
612
617
  const bridgeSelectedFeeToken = this.chainService.getAssetBySlug(bridgeFee.selectedFeeToken || bridgeFee.defaultFeeToken);
613
618
  const bnBridgeDeliveryFee = (0, _bignumber.default)(0); // todo
614
619
 
615
- const bridgeSender = (0, _utils4._reformatAddressWithChain)(bridgeMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
616
- const bridgeReceiver = (0, _utils4._reformatAddressWithChain)((_bridgeMetadata$recei = bridgeMetadata.receiver) !== null && _bridgeMetadata$recei !== void 0 ? _bridgeMetadata$recei : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
620
+ const bridgeSender = (0, _utils5._reformatAddressWithChain)(bridgeMetadata.sender, this.chainService.getChainInfoByKey(bridgeFromToken.originChain));
621
+ const bridgeReceiver = (0, _utils5._reformatAddressWithChain)((_bridgeMetadata$recei = bridgeMetadata.receiver) !== null && _bridgeMetadata$recei !== void 0 ? _bridgeMetadata$recei : bridgeSender, this.chainService.getChainInfoByKey(bridgeToToken.originChain));
617
622
  const [bridgeFromTokenBalance, bridgeFeeTokenBalance] = await Promise.all([this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeFromToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM), this.balanceService.getTransferableBalance(bridgeSender, bridgeFromToken.originChain, bridgeSelectedFeeToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM)]);
618
623
 
619
624
  // Native token balance has already accounted for ED aka strict mode
@@ -657,11 +662,11 @@ class SwapBaseHandler {
657
662
  if (bnSwapValue.gt(bnBridgeAmount)) {
658
663
  return [new _TransactionError.TransactionError(_types.BasicTxErrorType.INTERNAL_ERROR)];
659
664
  }
660
- if (bnSwapValue.lte((0, _utils2._getTokenMinAmount)(swapToken))) {
661
- const atLeastString = (0, _utils4.formatNumber)((0, _utils2._getTokenMinAmount)(swapToken), (0, _utils2._getAssetDecimals)(swapToken), _utils4.balanceFormatter, {
662
- maxNumberFormat: (0, _utils2._getAssetDecimals)(swapToken) || 6
665
+ if (bnSwapValue.lte((0, _utils3._getTokenMinAmount)(swapToken))) {
666
+ const atLeastString = (0, _utils5.formatNumber)((0, _utils3._getTokenMinAmount)(swapToken), (0, _utils3._getAssetDecimals)(swapToken), _utils5.balanceFormatter, {
667
+ maxNumberFormat: (0, _utils3._getAssetDecimals)(swapToken) || 6
663
668
  });
664
- return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils2._getAssetSymbol)(swapToken)} and try again`))];
669
+ return [new _TransactionError.TransactionError(_swap.SwapErrorType.NOT_MEET_MIN_SWAP, (0, _i18next.t)(`Swap amount too small. Increase to more than ${atLeastString} ${(0, _utils3._getAssetSymbol)(swapToken)} and try again`))];
665
670
  }
666
671
  const swapFeeToken = this.chainService.getAssetBySlug(swapFee.selectedFeeToken || swapFee.defaultFeeToken);
667
672
  const swapToChain = this.chainService.getChainInfoByKey(swapMetadata.destinationTokenInfo.originChain);
@@ -700,8 +705,8 @@ class SwapBaseHandler {
700
705
  const transitSelectedFeeToken = this.chainService.getAssetBySlug(transitTotalFee.selectedFeeToken || transitTotalFee.defaultFeeToken);
701
706
  const bnTransitDeliveryFee = (0, _bignumber.default)(0); // todo
702
707
 
703
- const transitSender = (0, _utils4._reformatAddressWithChain)(transitMetadata.sender, this.chainService.getChainInfoByKey(transitFromToken.originChain));
704
- const transitReceiver = (0, _utils4._reformatAddressWithChain)((_transitMetadata$rece = transitMetadata.receiver) !== null && _transitMetadata$rece !== void 0 ? _transitMetadata$rece : transitSender, this.chainService.getChainInfoByKey(transitToToken.originChain));
708
+ const transitSender = (0, _utils5._reformatAddressWithChain)(transitMetadata.sender, this.chainService.getChainInfoByKey(transitFromToken.originChain));
709
+ const transitReceiver = (0, _utils5._reformatAddressWithChain)((_transitMetadata$rece = transitMetadata.receiver) !== null && _transitMetadata$rece !== void 0 ? _transitMetadata$rece : transitSender, this.chainService.getChainInfoByKey(transitToToken.originChain));
705
710
  const [transitFromTokenBalance, transitFeeTokenBalance] = await Promise.all([this.balanceService.getTransferableBalance(transitSender, transitFromToken.originChain, transitFromToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM), this.balanceService.getTransferableBalance(transitSender, transitFromToken.originChain, transitSelectedFeeToken.slug, _KoniTypes.ExtrinsicType.TRANSFER_XCM)]);
706
711
 
707
712
  // Native token balance has already accounted for ED aka strict mode
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.ChainflipSwapHandler = exports.CHAINFLIP_BROKER_API = void 0;
7
+ exports.ChainflipSwapHandler = void 0;
8
8
  var _chainList = require("@subwallet/chain-list");
9
9
  var _TransactionError = require("@subwallet/extension-base/background/errors/TransactionError");
10
10
  var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
@@ -12,9 +12,9 @@ var _smartContract = require("@subwallet/extension-base/services/balance-service
12
12
  var _token = require("@subwallet/extension-base/services/balance-service/transfer/token");
13
13
  var _utils = require("@subwallet/extension-base/services/chain-service/utils");
14
14
  var _baseHandler = require("@subwallet/extension-base/services/swap-service/handler/base-handler");
15
- var _utils2 = require("@subwallet/extension-base/services/swap-service/utils");
16
15
  var _types = require("@subwallet/extension-base/types");
17
- var _utils3 = require("@subwallet/extension-base/utils");
16
+ var _environment = require("@subwallet/extension-base/types/environment");
17
+ var _utils2 = require("@subwallet/extension-base/utils");
18
18
  var _getId = require("@subwallet/extension-base/utils/getId");
19
19
  var _bignumber = _interopRequireDefault(require("bignumber.js"));
20
20
  // Copyright 2019-2022 @subwallet/extension-base
@@ -22,9 +22,10 @@ var _bignumber = _interopRequireDefault(require("bignumber.js"));
22
22
 
23
23
  const INTERMEDIARY_MAINNET_ASSET_SLUG = _chainList.COMMON_ASSETS.USDC_ETHEREUM;
24
24
  const INTERMEDIARY_TESTNET_ASSET_SLUG = _chainList.COMMON_ASSETS.USDC_SEPOLIA;
25
- const CHAINFLIP_BROKER_API = process.env.CHAINFLIP_BROKER_API || '';
26
- exports.CHAINFLIP_BROKER_API = CHAINFLIP_BROKER_API;
27
25
  class ChainflipSwapHandler {
26
+ // private baseUrl: string;
27
+ // private assetsUrl: string;
28
+
28
29
  constructor(chainService, balanceService, feeService) {
29
30
  let isTestnet = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
30
31
  this.swapBaseHandler = new _baseHandler.SwapBaseHandler({
@@ -36,8 +37,10 @@ class ChainflipSwapHandler {
36
37
  });
37
38
  this.isTestnet = isTestnet;
38
39
  this.providerSlug = isTestnet ? _types.SwapProviderId.CHAIN_FLIP_TESTNET : _types.SwapProviderId.CHAIN_FLIP_MAINNET;
39
- this.baseUrl = (0, _utils2.getChainflipSwap)(isTestnet);
40
+ // this.baseUrl = getChainflipSwap(isTestnet);
41
+ // this.assetsUrl = getAssetsUrl(isTestnet);
40
42
  }
43
+
41
44
  get chainService() {
42
45
  return this.swapBaseHandler.chainService;
43
46
  }
@@ -73,7 +76,7 @@ class ChainflipSwapHandler {
73
76
  const chainInfo = this.chainService.getChainInfoByKey(fromAsset.originChain);
74
77
  const toChainInfo = this.chainService.getChainInfoByKey(fromAsset.originChain);
75
78
  const chainType = (0, _utils._isChainSubstrateCompatible)(chainInfo) ? _KoniTypes.ChainType.SUBSTRATE : _KoniTypes.ChainType.EVM;
76
- const receiver = (0, _utils3._reformatAddressWithChain)(recipient !== null && recipient !== void 0 ? recipient : address, toChainInfo);
79
+ const receiver = (0, _utils2._reformatAddressWithChain)(recipient !== null && recipient !== void 0 ? recipient : address, toChainInfo);
77
80
  const fromAssetId = (0, _utils._getAssetSymbol)(fromAsset);
78
81
  const toAssetId = (0, _utils._getAssetSymbol)(toAsset);
79
82
  const minReceive = new _bignumber.default(quote.rate).times(1 - slippage).toString();
@@ -85,23 +88,31 @@ class ChainflipSwapHandler {
85
88
  if (processMetadata.destChain !== quoteMetadata.destChain || processMetadata.srcChain !== quoteMetadata.srcChain) {
86
89
  throw new Error('Metadata for Chainflip not found');
87
90
  }
91
+ const assetsResponse = await (0, _utils2.fetchFromProxyService)(_environment.ProxyServiceRoute.CHAINFLIP, '/assets', {
92
+ method: 'GET'
93
+ }, this.isTestnet);
94
+ const _allAssets = await assetsResponse.json();
95
+ const allAssets = _allAssets.assets;
96
+ const sourceAsset = allAssets.find(asset => asset.network === processMetadata.srcChain && asset.ticker === fromAssetId);
97
+ const destinationAsset = allAssets.find(asset => asset.network === processMetadata.destChain && asset.ticker === toAssetId);
98
+ if (!sourceAsset || !destinationAsset) {
99
+ throw new Error('Error get Chainflip data');
100
+ }
88
101
  const depositParams = {
89
- sourceChain: processMetadata.srcChain,
90
102
  destinationAddress: receiver,
91
- destinationAsset: toAssetId,
92
- destinationChain: processMetadata.destChain,
103
+ destinationAsset: destinationAsset.id,
104
+ sourceAsset: sourceAsset.id,
93
105
  minimumPrice: minReceive,
94
106
  // minimum accepted price for swaps through the channel
95
107
  refundAddress: address,
96
108
  // address to which assets are refunded
97
- retryDurationInBlocks: '100',
98
- // 100 blocks * 6 seconds = 10 minutes before deposits are refunded
99
- sourceAsset: fromAssetId
109
+ retryDurationInBlocks: '100' // 100 blocks * 6 seconds = 10 minutes before deposits are refunded
100
110
  };
101
- const url = `${this.baseUrl}&${new URLSearchParams(depositParams).toString()}`;
102
- const response = await fetch(url, {
111
+
112
+ const path = `/swap?${new URLSearchParams(depositParams).toString()}`;
113
+ const response = await (0, _utils2.fetchFromProxyService)(_environment.ProxyServiceRoute.CHAINFLIP, path, {
103
114
  method: 'GET'
104
- });
115
+ }, this.isTestnet);
105
116
  const data = await response.json();
106
117
  if (!data.id || !data.address || data.address === '' || !data.issuedBlock || !data.network || !data.channelId) {
107
118
  throw new Error('Error get Chainflip data');
@@ -208,8 +219,8 @@ class ChainflipSwapHandler {
208
219
  expectedReceive: params.selectedQuote.toAmount,
209
220
  originTokenInfo,
210
221
  destinationTokenInfo,
211
- sender: (0, _utils3._reformatAddressWithChain)(params.request.address, originChain),
212
- receiver: (0, _utils3._reformatAddressWithChain)(params.request.recipient || params.request.address, destinationChain),
222
+ sender: (0, _utils2._reformatAddressWithChain)(params.request.address, originChain),
223
+ receiver: (0, _utils2._reformatAddressWithChain)(params.request.recipient || params.request.address, destinationChain),
213
224
  srcChain: metadata.srcChain,
214
225
  destChain: metadata.destChain,
215
226
  version: 2