@subwallet/extension-base 1.3.78-0 → 1.3.79-1

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 (41) hide show
  1. package/background/KoniTypes.d.ts +3 -3
  2. package/cjs/core/logic-validation/index.js +0 -12
  3. package/cjs/koni/background/handlers/Extension.js +7 -2
  4. package/cjs/packageInfo.js +1 -1
  5. package/cjs/services/balance-service/transfer/xcm/utils.js +9 -9
  6. package/cjs/services/earning-service/handlers/native-staking/dtao.js +13 -13
  7. package/cjs/services/earning-service/handlers/native-staking/tao.js +16 -10
  8. package/cjs/services/earning-service/handlers/special.js +9 -2
  9. package/cjs/services/swap-service/handler/asset-hub/handler.js +7 -4
  10. package/cjs/services/swap-service/handler/asset-hub/router.js +2 -66
  11. package/cjs/services/swap-service/handler/base-handler.js +4 -3
  12. package/cjs/services/swap-service/handler/hydradx-handler.js +9 -5
  13. package/cjs/services/swap-service/index.js +5 -4
  14. package/cjs/types/swap/index.js +4 -9
  15. package/cjs/utils/account/common.js +44 -8
  16. package/core/logic-validation/index.d.ts +0 -1
  17. package/core/logic-validation/index.js +0 -1
  18. package/koni/background/handlers/Extension.d.ts +3 -0
  19. package/koni/background/handlers/Extension.js +7 -2
  20. package/package.json +5 -10
  21. package/packageInfo.js +1 -1
  22. package/services/balance-service/transfer/xcm/utils.js +9 -9
  23. package/services/earning-service/handlers/native-staking/dtao.js +12 -13
  24. package/services/earning-service/handlers/native-staking/tao.d.ts +2 -1
  25. package/services/earning-service/handlers/native-staking/tao.js +15 -10
  26. package/services/earning-service/handlers/special.js +9 -2
  27. package/services/swap-service/handler/asset-hub/handler.js +7 -4
  28. package/services/swap-service/handler/asset-hub/router.d.ts +0 -4
  29. package/services/swap-service/handler/asset-hub/router.js +1 -64
  30. package/services/swap-service/handler/base-handler.js +4 -3
  31. package/services/swap-service/handler/hydradx-handler.js +9 -5
  32. package/services/swap-service/index.js +5 -4
  33. package/types/swap/index.d.ts +7 -35
  34. package/types/swap/index.js +3 -8
  35. package/types/yield/actions/join/step.d.ts +1 -0
  36. package/types/yield/actions/join/submit.d.ts +2 -1
  37. package/utils/account/common.d.ts +22 -1
  38. package/utils/account/common.js +44 -8
  39. package/cjs/core/logic-validation/swap.js +0 -235
  40. package/core/logic-validation/swap.d.ts +0 -26
  41. package/core/logic-validation/swap.js +0 -219
@@ -3,7 +3,28 @@ import { ChainType } from '@subwallet/extension-base/background/KoniTypes';
3
3
  import { AccountChainType, AccountJson } from '@subwallet/extension-base/types';
4
4
  export declare function isAccountAll(address?: string): boolean;
5
5
  export declare function reformatAddress(address: string, networkPrefix?: number, isEthereum?: boolean, ignoreError?: boolean): string;
6
- export declare const _reformatAddressWithChain: (address: string, chainInfo: _ChainInfo) => string;
6
+ /**
7
+ * @private
8
+ * Reformats a wallet address based on the provided chain information.
9
+ *
10
+ * This function checks the chain type (Substrate, TON, Cardano, or others)
11
+ * and applies the corresponding formatting logic:
12
+ * 1. **Substrate**: Reformats the Substrate address using the chain's specific prefix.
13
+ * If the current `address` is an EVM address, it attempts to use the `alternativeAddress`
14
+ * (which is currently **always** expected to be the Substrate address) for Substrate
15
+ * formatting, as direct EVM-to-Substrate reformatting is not possible here.
16
+ * 2. **TON/Cardano**: Uses a simple prefix logic based on whether the chain is a testnet or a mainnet.
17
+ * 3. **Default (EVM/Others)**: Returns the original address without reformatting.
18
+ *
19
+ * @param address The current wallet address string.
20
+ * @param chainInfo An object containing chain details (e.g., chain type, testnet status, prefix).
21
+ * @param alternativeAddress An optional alternative address, which is currently expected to be the Substrate
22
+ * address associated with the account. It is used as a fallback for Substrate formatting when the main `address` is EVM.
23
+ * @returns The reformatted wallet address, or the original address if no reformatting is needed or possible.
24
+ *
25
+ * @todo This function currently lacks logic to reformat a Substrate address into an EVM address format.
26
+ */
27
+ export declare const _reformatAddressWithChain: (address: string, chainInfo: _ChainInfo, alternativeAddress?: string) => string;
7
28
  export declare const getAccountChainTypeForAddress: (address: string) => AccountChainType;
8
29
  declare type AddressesByChainType = {
9
30
  [key in ChainType]: string[];
@@ -40,17 +40,53 @@ export function reformatAddress(address, networkPrefix = 42, isEthereum = false,
40
40
  return address;
41
41
  }
42
42
  }
43
- export const _reformatAddressWithChain = (address, chainInfo) => {
43
+
44
+ /**
45
+ * @private
46
+ * Reformats a wallet address based on the provided chain information.
47
+ *
48
+ * This function checks the chain type (Substrate, TON, Cardano, or others)
49
+ * and applies the corresponding formatting logic:
50
+ * 1. **Substrate**: Reformats the Substrate address using the chain's specific prefix.
51
+ * If the current `address` is an EVM address, it attempts to use the `alternativeAddress`
52
+ * (which is currently **always** expected to be the Substrate address) for Substrate
53
+ * formatting, as direct EVM-to-Substrate reformatting is not possible here.
54
+ * 2. **TON/Cardano**: Uses a simple prefix logic based on whether the chain is a testnet or a mainnet.
55
+ * 3. **Default (EVM/Others)**: Returns the original address without reformatting.
56
+ *
57
+ * @param address The current wallet address string.
58
+ * @param chainInfo An object containing chain details (e.g., chain type, testnet status, prefix).
59
+ * @param alternativeAddress An optional alternative address, which is currently expected to be the Substrate
60
+ * address associated with the account. It is used as a fallback for Substrate formatting when the main `address` is EVM.
61
+ * @returns The reformatted wallet address, or the original address if no reformatting is needed or possible.
62
+ *
63
+ * @todo This function currently lacks logic to reformat a Substrate address into an EVM address format.
64
+ */
65
+ export const _reformatAddressWithChain = (address, chainInfo, alternativeAddress) => {
44
66
  const chainType = _chainInfoToAccountChainType(chainInfo);
45
67
  if (chainType === AccountChainType.SUBSTRATE) {
46
- return reformatAddress(address, _getChainSubstrateAddressPrefix(chainInfo));
47
- } else if (chainType === AccountChainType.TON || chainType === AccountChainType.CARDANO) {
48
- const isTestnet = chainInfo.isTestnet;
49
- return reformatAddress(address, isTestnet ? 0 : 1);
50
- } else {
51
- // EVM, Bitcoin
52
- return address;
68
+ const addressPrefix = _getChainSubstrateAddressPrefix(chainInfo);
69
+ if (addressPrefix < 0) {
70
+ // not a valid address prefix for substrate chain type
71
+ return address;
72
+ }
73
+ if (isEthereumAddress(address)) {
74
+ if (alternativeAddress) {
75
+ // reformat using alternativeAddress of that account. Because can not reformat from evm address to substrate address
76
+ return reformatAddress(alternativeAddress, addressPrefix);
77
+ }
78
+
79
+ // can not reformat without substrateAddress info
80
+ return address;
81
+ }
82
+
83
+ // reformat as usual with substrate address
84
+ return reformatAddress(address, addressPrefix);
85
+ }
86
+ if (chainType === AccountChainType.TON || chainType === AccountChainType.CARDANO) {
87
+ return reformatAddress(address, chainInfo.isTestnet ? 0 : 1);
53
88
  }
89
+ return address;
54
90
  };
55
91
  export const getAccountChainTypeForAddress = address => {
56
92
  const type = getKeypairTypeByAddress(address);
@@ -1,235 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports._getChainflipEarlyValidationError = _getChainflipEarlyValidationError;
8
- exports._getEarlyAssetHubValidationError = _getEarlyAssetHubValidationError;
9
- exports._getEarlyHydradxValidationError = _getEarlyHydradxValidationError;
10
- exports._getSimpleSwapEarlyValidationError = _getSimpleSwapEarlyValidationError;
11
- exports._validateBalanceToSwap = _validateBalanceToSwap;
12
- exports._validateBalanceToSwapOnAssetHub = _validateBalanceToSwapOnAssetHub;
13
- exports._validateBalanceToSwapV2 = _validateBalanceToSwapV2;
14
- exports._validateQuoteV2 = _validateQuoteV2;
15
- exports._validateSwapRecipient = _validateSwapRecipient;
16
- exports._validateSwapRecipientV2 = _validateSwapRecipientV2;
17
- var _SwapError = require("@subwallet/extension-base/background/errors/SwapError");
18
- var _TransactionError = require("@subwallet/extension-base/background/errors/TransactionError");
19
- var _utils = require("@subwallet/extension-base/services/chain-service/utils");
20
- var _types = require("@subwallet/extension-base/types");
21
- var _swap = require("@subwallet/extension-base/types/swap");
22
- var _utils2 = require("@subwallet/extension-base/utils");
23
- var _bignumber = _interopRequireDefault(require("bignumber.js"));
24
- var _utilCrypto = require("@polkadot/util-crypto");
25
- // Copyright 2019-2022 @subwallet/extension-base
26
- // SPDX-License-Identifier: Apache-2.0
27
-
28
- function _validateBalanceToSwapOnAssetHub(fromToken, feeToken, feeTokenChainInfo, feeAmount, fromTokenBalance, feeTokenBalance, swapAmount, isXcmOk, minSwap) {
29
- const bnFromTokenBalance = new _bignumber.default(fromTokenBalance);
30
- if (!(0, _utils._isNativeToken)(fromToken) && bnFromTokenBalance.minus(swapAmount).lt((0, _utils._getTokenMinAmount)(fromToken))) {
31
- const parsedMaxBalanceSwap = (0, _utils2.formatNumber)(bnFromTokenBalance.minus((0, _utils._getTokenMinAmount)(fromToken)), (0, _utils._getAssetDecimals)(fromToken));
32
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
33
- }
34
- if (new _bignumber.default(feeTokenBalance).lte(feeAmount)) {
35
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${feeTokenChainInfo.name}) to pay transaction fee`);
36
- }
37
- if (!(0, _utils._isNativeToken)(fromToken) && fromToken.slug === feeToken.slug) {
38
- // todo: need review and refactor
39
- if (bnFromTokenBalance.lte(new _bignumber.default(feeAmount).plus(swapAmount))) {
40
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
41
- }
42
- }
43
- if (isXcmOk) {
44
- // assume that the swap is valid if XCM is in the process and it was successful
45
- return undefined;
46
- }
47
- if (minSwap) {
48
- if (bnFromTokenBalance.lte(minSwap)) {
49
- const parsedMinSwapValue = (0, _utils2.formatNumber)(minSwap, (0, _utils._getAssetDecimals)(fromToken));
50
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
51
- }
52
- }
53
- if (new _bignumber.default(swapAmount).gte(fromTokenBalance)) {
54
- const parsedMaxBalanceSwap = (0, _utils2.formatNumber)(fromTokenBalance, (0, _utils._getAssetDecimals)(fromToken));
55
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
56
- }
57
- return undefined;
58
- }
59
- function _validateBalanceToSwap(fromToken, feeToken, feeTokenChainInfo, feeAmount, fromTokenBalance, feeTokenBalance, swapAmount, isXcmOk, minSwap) {
60
- const bnFromTokenBalance = new _bignumber.default(fromTokenBalance);
61
- if (new _bignumber.default(feeTokenBalance).lte(feeAmount)) {
62
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${feeTokenChainInfo.name}) to pay transaction fee`);
63
- }
64
- if (fromToken.slug === feeToken.slug) {
65
- // todo: need review and refactor
66
- if (bnFromTokenBalance.lte(new _bignumber.default(feeAmount).plus(swapAmount))) {
67
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
68
- }
69
- }
70
- if (isXcmOk) {
71
- // assume that the swap is valid if XCM is in the process and it was successful
72
- return undefined;
73
- }
74
- if (minSwap) {
75
- if (bnFromTokenBalance.lte(minSwap)) {
76
- const parsedMinSwapValue = (0, _utils2.formatNumber)(minSwap, (0, _utils._getAssetDecimals)(fromToken));
77
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
78
- }
79
- }
80
- if (new _bignumber.default(swapAmount).gte(fromTokenBalance)) {
81
- const parsedMaxBalanceSwap = (0, _utils2.formatNumber)(fromTokenBalance, (0, _utils._getAssetDecimals)(fromToken));
82
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
83
- }
84
- return undefined;
85
- }
86
- function _validateSwapRecipient(destChainInfo, recipient) {
87
- const isEvmAddress = (0, _utilCrypto.isEthereumAddress)(recipient);
88
- const isEvmDestChain = (0, _utils._isChainEvmCompatible)(destChainInfo);
89
- if (isEvmAddress && !isEvmDestChain || !isEvmAddress && isEvmDestChain) {
90
- return new _TransactionError.TransactionError(_swap.SwapErrorType.INVALID_RECIPIENT);
91
- }
92
- return undefined;
93
- }
94
- function _getChainflipEarlyValidationError(error, metadata) {
95
- // todo: support more providers
96
- switch (error) {
97
- case _swap.SwapErrorType.NOT_MEET_MIN_SWAP:
98
- {
99
- const parsedMinSwapValue = (0, _utils2.formatNumber)(metadata.minSwap.value, metadata.minSwap.decimals);
100
- const message = `Amount too low. Increase your amount above ${parsedMinSwapValue} ${metadata.minSwap.symbol} and try again`;
101
- return new _SwapError.SwapError(error, message);
102
- }
103
- case _swap.SwapErrorType.SWAP_EXCEED_ALLOWANCE:
104
- {
105
- if (metadata.maxSwap) {
106
- const parsedMaxSwapValue = (0, _utils2.formatNumber)(metadata.maxSwap.value, metadata.maxSwap.decimals);
107
- return new _SwapError.SwapError(error, `Amount too high. Lower your amount below ${parsedMaxSwapValue} ${metadata.maxSwap.symbol} and try again`);
108
- } else {
109
- return new _SwapError.SwapError(error, 'Amount too high. Lower your amount and try again');
110
- }
111
- }
112
- case _swap.SwapErrorType.ASSET_NOT_SUPPORTED:
113
- return new _SwapError.SwapError(error, 'This swap pair is not supported');
114
- case _swap.SwapErrorType.UNKNOWN:
115
- return new _SwapError.SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
116
- case _swap.SwapErrorType.ERROR_FETCHING_QUOTE:
117
- return new _SwapError.SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
118
- default:
119
- return new _SwapError.SwapError(error);
120
- }
121
- }
122
- function _getEarlyHydradxValidationError(error, metadata) {
123
- switch (error) {
124
- case _swap.SwapErrorType.AMOUNT_CANNOT_BE_ZERO:
125
- {
126
- return new _SwapError.SwapError(error, 'Amount too low. Increase your amount above 0 and try again');
127
- }
128
- case _swap.SwapErrorType.ASSET_NOT_SUPPORTED:
129
- return new _SwapError.SwapError(error, 'This swap pair is not supported');
130
- case _swap.SwapErrorType.UNKNOWN:
131
- return new _SwapError.SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
132
- case _swap.SwapErrorType.ERROR_FETCHING_QUOTE:
133
- return new _SwapError.SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
134
- default:
135
- return new _SwapError.SwapError(error);
136
- }
137
- }
138
- function _getEarlyAssetHubValidationError(error, metadata) {
139
- switch (error) {
140
- case _swap.SwapErrorType.AMOUNT_CANNOT_BE_ZERO:
141
- return new _SwapError.SwapError(error, 'Amount too low. Increase your amount above 0 and try again');
142
- case _swap.SwapErrorType.ASSET_NOT_SUPPORTED:
143
- return new _SwapError.SwapError(error, 'This swap pair is not supported');
144
- case _swap.SwapErrorType.UNKNOWN:
145
- return new _SwapError.SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
146
- case _swap.SwapErrorType.ERROR_FETCHING_QUOTE:
147
- return new _SwapError.SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
148
- case _swap.SwapErrorType.MAKE_POOL_NOT_ENOUGH_EXISTENTIAL_DEPOSIT:
149
- return new _SwapError.SwapError(error, 'You swap too much. It make pool not enough existential deposit');
150
- // TODO: i18n this
151
- default:
152
- return new _SwapError.SwapError(error);
153
- }
154
- }
155
- function _getSimpleSwapEarlyValidationError(error, metadata) {
156
- // todo: support more providers
157
- switch (error) {
158
- case _swap.SwapErrorType.NOT_MEET_MIN_SWAP:
159
- {
160
- const message = `Amount too low. Increase your amount above ${metadata.minSwap.value} ${metadata.minSwap.symbol} and try again`;
161
- return new _SwapError.SwapError(error, message);
162
- }
163
- case _swap.SwapErrorType.SWAP_EXCEED_ALLOWANCE:
164
- {
165
- if (metadata.maxSwap) {
166
- return new _SwapError.SwapError(error, `Amount too high. Lower your amount below ${metadata.maxSwap.value} ${metadata.maxSwap.symbol} and try again`);
167
- } else {
168
- return new _SwapError.SwapError(error, 'Amount too high. Lower your amount and try again');
169
- }
170
- }
171
- case _swap.SwapErrorType.ASSET_NOT_SUPPORTED:
172
- return new _SwapError.SwapError(error, 'This swap pair is not supported');
173
- case _swap.SwapErrorType.UNKNOWN:
174
- return new _SwapError.SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
175
- case _swap.SwapErrorType.ERROR_FETCHING_QUOTE:
176
- return new _SwapError.SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
177
- default:
178
- return new _SwapError.SwapError(error);
179
- }
180
- }
181
- function _validateQuoteV2(selectedQuote) {
182
- if (!selectedQuote) {
183
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.INTERNAL_ERROR);
184
- }
185
-
186
- // Check swapQuote alive
187
- if (selectedQuote.aliveUntil <= +Date.now()) {
188
- return new _TransactionError.TransactionError(_swap.SwapErrorType.QUOTE_TIMEOUT);
189
- }
190
- return undefined;
191
- }
192
- function _validateBalanceToSwapV2(request) {
193
- const {
194
- chainInfo,
195
- feeAmount,
196
- feeToken,
197
- feeTokenBalance,
198
- fromToken,
199
- fromTokenBalance,
200
- minSwapAmount,
201
- swapAmount
202
- } = request;
203
- const bnFromTokenBalance = (0, _bignumber.default)(fromTokenBalance);
204
- if (new _bignumber.default(feeTokenBalance).lte(feeAmount)) {
205
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${chainInfo.name}) to pay transaction fee`);
206
- }
207
- if (fromToken.slug === feeToken.slug) {
208
- // todo: need review and refactor
209
- if (bnFromTokenBalance.lte((0, _bignumber.default)(feeAmount).plus(swapAmount))) {
210
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
211
- }
212
- } else {
213
- if (bnFromTokenBalance.lt(swapAmount)) {
214
- return new _TransactionError.TransactionError(_types.BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
215
- }
216
- }
217
- if (minSwapAmount) {
218
- if (bnFromTokenBalance.lte(minSwapAmount)) {
219
- const parsedMinSwapValue = (0, _utils2.formatNumber)(minSwapAmount, (0, _utils._getAssetDecimals)(fromToken));
220
- return new _TransactionError.TransactionError(_swap.SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
221
- }
222
- }
223
- return undefined;
224
- }
225
- function _validateSwapRecipientV2(destChainInfo, recipient) {
226
- if (!recipient) {
227
- return undefined;
228
- }
229
- const isEvmAddress = (0, _utilCrypto.isEthereumAddress)(recipient);
230
- const isEvmDestChain = (0, _utils._isChainEvmCompatible)(destChainInfo);
231
- if (isEvmAddress && !isEvmDestChain || !isEvmAddress && isEvmDestChain) {
232
- return new _TransactionError.TransactionError(_swap.SwapErrorType.INVALID_RECIPIENT);
233
- }
234
- return undefined;
235
- }
@@ -1,26 +0,0 @@
1
- import { _ChainAsset, _ChainInfo } from '@subwallet/chain-list/types';
2
- import { SwapError } from '@subwallet/extension-base/background/errors/SwapError';
3
- import { TransactionError } from '@subwallet/extension-base/background/errors/TransactionError';
4
- import { SwapQuote } from '@subwallet/extension-base/types';
5
- import { AssetHubPreValidationMetadata, ChainflipPreValidationMetadata, HydradxPreValidationMetadata, SimpleSwapValidationMetadata, SwapErrorType } from '@subwallet/extension-base/types/swap';
6
- interface RequestValidateSwap {
7
- chainInfo: _ChainInfo;
8
- fromToken: _ChainAsset;
9
- fromTokenBalance: string;
10
- feeToken: _ChainAsset;
11
- feeTokenBalance: string;
12
- feeAmount: string;
13
- swapAmount: string;
14
- minSwapAmount?: string;
15
- }
16
- export declare function _validateBalanceToSwapOnAssetHub(fromToken: _ChainAsset, feeToken: _ChainAsset, feeTokenChainInfo: _ChainInfo, feeAmount: string, fromTokenBalance: string, feeTokenBalance: string, swapAmount: string, isXcmOk: boolean, minSwap?: string): TransactionError | undefined;
17
- export declare function _validateBalanceToSwap(fromToken: _ChainAsset, feeToken: _ChainAsset, feeTokenChainInfo: _ChainInfo, feeAmount: string, fromTokenBalance: string, feeTokenBalance: string, swapAmount: string, isXcmOk: boolean, minSwap?: string): TransactionError | undefined;
18
- export declare function _validateSwapRecipient(destChainInfo: _ChainInfo, recipient: string): TransactionError | undefined;
19
- export declare function _getChainflipEarlyValidationError(error: SwapErrorType, metadata: ChainflipPreValidationMetadata): SwapError;
20
- export declare function _getEarlyHydradxValidationError(error: SwapErrorType, metadata: HydradxPreValidationMetadata): SwapError;
21
- export declare function _getEarlyAssetHubValidationError(error: SwapErrorType, metadata: AssetHubPreValidationMetadata): SwapError;
22
- export declare function _getSimpleSwapEarlyValidationError(error: SwapErrorType, metadata: SimpleSwapValidationMetadata): SwapError;
23
- export declare function _validateQuoteV2(selectedQuote: SwapQuote): TransactionError | undefined;
24
- export declare function _validateBalanceToSwapV2(request: RequestValidateSwap): TransactionError | undefined;
25
- export declare function _validateSwapRecipientV2(destChainInfo: _ChainInfo, recipient: string | undefined): TransactionError | undefined;
26
- export {};
@@ -1,219 +0,0 @@
1
- // Copyright 2019-2022 @subwallet/extension-base
2
- // SPDX-License-Identifier: Apache-2.0
3
-
4
- import { SwapError } from '@subwallet/extension-base/background/errors/SwapError';
5
- import { TransactionError } from '@subwallet/extension-base/background/errors/TransactionError';
6
- import { _getAssetDecimals, _getTokenMinAmount, _isChainEvmCompatible, _isNativeToken } from '@subwallet/extension-base/services/chain-service/utils';
7
- import { BasicTxErrorType } from '@subwallet/extension-base/types';
8
- import { SwapErrorType } from '@subwallet/extension-base/types/swap';
9
- import { formatNumber } from '@subwallet/extension-base/utils';
10
- import BigN from 'bignumber.js';
11
- import { isEthereumAddress } from '@polkadot/util-crypto';
12
- export function _validateBalanceToSwapOnAssetHub(fromToken, feeToken, feeTokenChainInfo, feeAmount, fromTokenBalance, feeTokenBalance, swapAmount, isXcmOk, minSwap) {
13
- const bnFromTokenBalance = new BigN(fromTokenBalance);
14
- if (!_isNativeToken(fromToken) && bnFromTokenBalance.minus(swapAmount).lt(_getTokenMinAmount(fromToken))) {
15
- const parsedMaxBalanceSwap = formatNumber(bnFromTokenBalance.minus(_getTokenMinAmount(fromToken)), _getAssetDecimals(fromToken));
16
- return new TransactionError(SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
17
- }
18
- if (new BigN(feeTokenBalance).lte(feeAmount)) {
19
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${feeTokenChainInfo.name}) to pay transaction fee`);
20
- }
21
- if (!_isNativeToken(fromToken) && fromToken.slug === feeToken.slug) {
22
- // todo: need review and refactor
23
- if (bnFromTokenBalance.lte(new BigN(feeAmount).plus(swapAmount))) {
24
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
25
- }
26
- }
27
- if (isXcmOk) {
28
- // assume that the swap is valid if XCM is in the process and it was successful
29
- return undefined;
30
- }
31
- if (minSwap) {
32
- if (bnFromTokenBalance.lte(minSwap)) {
33
- const parsedMinSwapValue = formatNumber(minSwap, _getAssetDecimals(fromToken));
34
- return new TransactionError(SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
35
- }
36
- }
37
- if (new BigN(swapAmount).gte(fromTokenBalance)) {
38
- const parsedMaxBalanceSwap = formatNumber(fromTokenBalance, _getAssetDecimals(fromToken));
39
- return new TransactionError(SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
40
- }
41
- return undefined;
42
- }
43
- export function _validateBalanceToSwap(fromToken, feeToken, feeTokenChainInfo, feeAmount, fromTokenBalance, feeTokenBalance, swapAmount, isXcmOk, minSwap) {
44
- const bnFromTokenBalance = new BigN(fromTokenBalance);
45
- if (new BigN(feeTokenBalance).lte(feeAmount)) {
46
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${feeTokenChainInfo.name}) to pay transaction fee`);
47
- }
48
- if (fromToken.slug === feeToken.slug) {
49
- // todo: need review and refactor
50
- if (bnFromTokenBalance.lte(new BigN(feeAmount).plus(swapAmount))) {
51
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
52
- }
53
- }
54
- if (isXcmOk) {
55
- // assume that the swap is valid if XCM is in the process and it was successful
56
- return undefined;
57
- }
58
- if (minSwap) {
59
- if (bnFromTokenBalance.lte(minSwap)) {
60
- const parsedMinSwapValue = formatNumber(minSwap, _getAssetDecimals(fromToken));
61
- return new TransactionError(SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
62
- }
63
- }
64
- if (new BigN(swapAmount).gte(fromTokenBalance)) {
65
- const parsedMaxBalanceSwap = formatNumber(fromTokenBalance, _getAssetDecimals(fromToken));
66
- return new TransactionError(SwapErrorType.SWAP_EXCEED_ALLOWANCE, `Amount too high. Lower your amount ${bnFromTokenBalance.gt(0) ? `below ${parsedMaxBalanceSwap} ${fromToken.symbol}` : ''} and try again`);
67
- }
68
- return undefined;
69
- }
70
- export function _validateSwapRecipient(destChainInfo, recipient) {
71
- const isEvmAddress = isEthereumAddress(recipient);
72
- const isEvmDestChain = _isChainEvmCompatible(destChainInfo);
73
- if (isEvmAddress && !isEvmDestChain || !isEvmAddress && isEvmDestChain) {
74
- return new TransactionError(SwapErrorType.INVALID_RECIPIENT);
75
- }
76
- return undefined;
77
- }
78
- export function _getChainflipEarlyValidationError(error, metadata) {
79
- // todo: support more providers
80
- switch (error) {
81
- case SwapErrorType.NOT_MEET_MIN_SWAP:
82
- {
83
- const parsedMinSwapValue = formatNumber(metadata.minSwap.value, metadata.minSwap.decimals);
84
- const message = `Amount too low. Increase your amount above ${parsedMinSwapValue} ${metadata.minSwap.symbol} and try again`;
85
- return new SwapError(error, message);
86
- }
87
- case SwapErrorType.SWAP_EXCEED_ALLOWANCE:
88
- {
89
- if (metadata.maxSwap) {
90
- const parsedMaxSwapValue = formatNumber(metadata.maxSwap.value, metadata.maxSwap.decimals);
91
- return new SwapError(error, `Amount too high. Lower your amount below ${parsedMaxSwapValue} ${metadata.maxSwap.symbol} and try again`);
92
- } else {
93
- return new SwapError(error, 'Amount too high. Lower your amount and try again');
94
- }
95
- }
96
- case SwapErrorType.ASSET_NOT_SUPPORTED:
97
- return new SwapError(error, 'This swap pair is not supported');
98
- case SwapErrorType.UNKNOWN:
99
- return new SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
100
- case SwapErrorType.ERROR_FETCHING_QUOTE:
101
- return new SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
102
- default:
103
- return new SwapError(error);
104
- }
105
- }
106
- export function _getEarlyHydradxValidationError(error, metadata) {
107
- switch (error) {
108
- case SwapErrorType.AMOUNT_CANNOT_BE_ZERO:
109
- {
110
- return new SwapError(error, 'Amount too low. Increase your amount above 0 and try again');
111
- }
112
- case SwapErrorType.ASSET_NOT_SUPPORTED:
113
- return new SwapError(error, 'This swap pair is not supported');
114
- case SwapErrorType.UNKNOWN:
115
- return new SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
116
- case SwapErrorType.ERROR_FETCHING_QUOTE:
117
- return new SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
118
- default:
119
- return new SwapError(error);
120
- }
121
- }
122
- export function _getEarlyAssetHubValidationError(error, metadata) {
123
- switch (error) {
124
- case SwapErrorType.AMOUNT_CANNOT_BE_ZERO:
125
- return new SwapError(error, 'Amount too low. Increase your amount above 0 and try again');
126
- case SwapErrorType.ASSET_NOT_SUPPORTED:
127
- return new SwapError(error, 'This swap pair is not supported');
128
- case SwapErrorType.UNKNOWN:
129
- return new SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
130
- case SwapErrorType.ERROR_FETCHING_QUOTE:
131
- return new SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
132
- case SwapErrorType.MAKE_POOL_NOT_ENOUGH_EXISTENTIAL_DEPOSIT:
133
- return new SwapError(error, 'You swap too much. It make pool not enough existential deposit');
134
- // TODO: i18n this
135
- default:
136
- return new SwapError(error);
137
- }
138
- }
139
- export function _getSimpleSwapEarlyValidationError(error, metadata) {
140
- // todo: support more providers
141
- switch (error) {
142
- case SwapErrorType.NOT_MEET_MIN_SWAP:
143
- {
144
- const message = `Amount too low. Increase your amount above ${metadata.minSwap.value} ${metadata.minSwap.symbol} and try again`;
145
- return new SwapError(error, message);
146
- }
147
- case SwapErrorType.SWAP_EXCEED_ALLOWANCE:
148
- {
149
- if (metadata.maxSwap) {
150
- return new SwapError(error, `Amount too high. Lower your amount below ${metadata.maxSwap.value} ${metadata.maxSwap.symbol} and try again`);
151
- } else {
152
- return new SwapError(error, 'Amount too high. Lower your amount and try again');
153
- }
154
- }
155
- case SwapErrorType.ASSET_NOT_SUPPORTED:
156
- return new SwapError(error, 'This swap pair is not supported');
157
- case SwapErrorType.UNKNOWN:
158
- return new SwapError(error, `Undefined error. Check your Internet and ${metadata.chain.slug} connection or contact support`);
159
- case SwapErrorType.ERROR_FETCHING_QUOTE:
160
- return new SwapError(error, 'No swap quote found. Change your network endpoint or adjust amount and try again');
161
- default:
162
- return new SwapError(error);
163
- }
164
- }
165
- export function _validateQuoteV2(selectedQuote) {
166
- if (!selectedQuote) {
167
- return new TransactionError(BasicTxErrorType.INTERNAL_ERROR);
168
- }
169
-
170
- // Check swapQuote alive
171
- if (selectedQuote.aliveUntil <= +Date.now()) {
172
- return new TransactionError(SwapErrorType.QUOTE_TIMEOUT);
173
- }
174
- return undefined;
175
- }
176
- export function _validateBalanceToSwapV2(request) {
177
- const {
178
- chainInfo,
179
- feeAmount,
180
- feeToken,
181
- feeTokenBalance,
182
- fromToken,
183
- fromTokenBalance,
184
- minSwapAmount,
185
- swapAmount
186
- } = request;
187
- const bnFromTokenBalance = BigN(fromTokenBalance);
188
- if (new BigN(feeTokenBalance).lte(feeAmount)) {
189
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `You don't have enough ${feeToken.symbol} (${chainInfo.name}) to pay transaction fee`);
190
- }
191
- if (fromToken.slug === feeToken.slug) {
192
- // todo: need review and refactor
193
- if (bnFromTokenBalance.lte(BigN(feeAmount).plus(swapAmount))) {
194
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
195
- }
196
- } else {
197
- if (bnFromTokenBalance.lt(swapAmount)) {
198
- return new TransactionError(BasicTxErrorType.NOT_ENOUGH_BALANCE, `Insufficient balance. Deposit ${fromToken.symbol} and try again.`);
199
- }
200
- }
201
- if (minSwapAmount) {
202
- if (bnFromTokenBalance.lte(minSwapAmount)) {
203
- const parsedMinSwapValue = formatNumber(minSwapAmount, _getAssetDecimals(fromToken));
204
- return new TransactionError(SwapErrorType.SWAP_NOT_ENOUGH_BALANCE, `Insufficient balance. You need more than ${parsedMinSwapValue} ${fromToken.symbol} to start swapping. Deposit ${fromToken.symbol} and try again.`); // todo: min swap or amount?
205
- }
206
- }
207
- return undefined;
208
- }
209
- export function _validateSwapRecipientV2(destChainInfo, recipient) {
210
- if (!recipient) {
211
- return undefined;
212
- }
213
- const isEvmAddress = isEthereumAddress(recipient);
214
- const isEvmDestChain = _isChainEvmCompatible(destChainInfo);
215
- if (isEvmAddress && !isEvmDestChain || !isEvmAddress && isEvmDestChain) {
216
- return new TransactionError(SwapErrorType.INVALID_RECIPIENT);
217
- }
218
- return undefined;
219
- }