@sodax/sdk 0.0.1-rc.1 → 0.0.1-rc.11
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/README.md +84 -9
- package/dist/index.cjs +12073 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +7078 -0
- package/dist/index.d.ts +7078 -10
- package/dist/index.mjs +11915 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +21 -6
- package/dist/abis/asset-manager.abi.d.ts +0 -418
- package/dist/abis/asset-manager.abi.d.ts.map +0 -1
- package/dist/abis/asset-manager.abi.js +0 -542
- package/dist/abis/asset-manager.abi.js.map +0 -1
- package/dist/abis/connection.abi.d.ts +0 -72
- package/dist/abis/connection.abi.d.ts.map +0 -1
- package/dist/abis/connection.abi.js +0 -92
- package/dist/abis/connection.abi.js.map +0 -1
- package/dist/abis/erc20.abi.d.ts +0 -236
- package/dist/abis/erc20.abi.d.ts.map +0 -1
- package/dist/abis/erc20.abi.js +0 -311
- package/dist/abis/erc20.abi.js.map +0 -1
- package/dist/abis/index.d.ts +0 -10
- package/dist/abis/index.d.ts.map +0 -1
- package/dist/abis/index.js +0 -10
- package/dist/abis/index.js.map +0 -1
- package/dist/abis/intents.abi.d.ts +0 -901
- package/dist/abis/intents.abi.d.ts.map +0 -1
- package/dist/abis/intents.abi.js +0 -1158
- package/dist/abis/intents.abi.js.map +0 -1
- package/dist/abis/pool.abi.d.ts +0 -626
- package/dist/abis/pool.abi.d.ts.map +0 -1
- package/dist/abis/pool.abi.js +0 -812
- package/dist/abis/pool.abi.js.map +0 -1
- package/dist/abis/spokeAssetManager.abi.d.ts +0 -169
- package/dist/abis/spokeAssetManager.abi.d.ts.map +0 -1
- package/dist/abis/spokeAssetManager.abi.js +0 -217
- package/dist/abis/spokeAssetManager.abi.js.map +0 -1
- package/dist/abis/uiPoolData.abi.d.ts +0 -369
- package/dist/abis/uiPoolData.abi.d.ts.map +0 -1
- package/dist/abis/uiPoolData.abi.js +0 -476
- package/dist/abis/uiPoolData.abi.js.map +0 -1
- package/dist/abis/vaultToken.abi.d.ts +0 -816
- package/dist/abis/vaultToken.abi.d.ts.map +0 -1
- package/dist/abis/vaultToken.abi.js +0 -1062
- package/dist/abis/vaultToken.abi.js.map +0 -1
- package/dist/abis/walletFactory.abi.d.ts +0 -20
- package/dist/abis/walletFactory.abi.d.ts.map +0 -1
- package/dist/abis/walletFactory.abi.js +0 -27
- package/dist/abis/walletFactory.abi.js.map +0 -1
- package/dist/constants.d.ts +0 -565
- package/dist/constants.d.ts.map +0 -1
- package/dist/constants.js +0 -1196
- package/dist/constants.js.map +0 -1
- package/dist/constants.test.d.ts +0 -2
- package/dist/constants.test.d.ts.map +0 -1
- package/dist/constants.test.js +0 -128
- package/dist/constants.test.js.map +0 -1
- package/dist/entities/Providers.d.ts +0 -61
- package/dist/entities/Providers.d.ts.map +0 -1
- package/dist/entities/Providers.js +0 -51
- package/dist/entities/Providers.js.map +0 -1
- package/dist/entities/Sodax.d.ts +0 -23
- package/dist/entities/Sodax.d.ts.map +0 -1
- package/dist/entities/Sodax.js +0 -29
- package/dist/entities/Sodax.js.map +0 -1
- package/dist/entities/Sodax.test.d.ts +0 -2
- package/dist/entities/Sodax.test.d.ts.map +0 -1
- package/dist/entities/Sodax.test.js +0 -376
- package/dist/entities/Sodax.test.js.map +0 -1
- package/dist/entities/cosmos/CW20Token.d.ts +0 -39
- package/dist/entities/cosmos/CW20Token.d.ts.map +0 -1
- package/dist/entities/cosmos/CW20Token.js +0 -65
- package/dist/entities/cosmos/CW20Token.js.map +0 -1
- package/dist/entities/cosmos/CWSpokeProvider.d.ts +0 -91
- package/dist/entities/cosmos/CWSpokeProvider.d.ts.map +0 -1
- package/dist/entities/cosmos/CWSpokeProvider.js +0 -143
- package/dist/entities/cosmos/CWSpokeProvider.js.map +0 -1
- package/dist/entities/cosmos/CosmosWalletProvider.d.ts +0 -28
- package/dist/entities/cosmos/CosmosWalletProvider.d.ts.map +0 -1
- package/dist/entities/cosmos/CosmosWalletProvider.js +0 -102
- package/dist/entities/cosmos/CosmosWalletProvider.js.map +0 -1
- package/dist/entities/cosmos/InjectiveWalletProvider.d.ts +0 -25
- package/dist/entities/cosmos/InjectiveWalletProvider.d.ts.map +0 -1
- package/dist/entities/cosmos/InjectiveWalletProvider.js +0 -76
- package/dist/entities/cosmos/InjectiveWalletProvider.js.map +0 -1
- package/dist/entities/icon/HanaWalletConnector.d.ts +0 -36
- package/dist/entities/icon/HanaWalletConnector.d.ts.map +0 -1
- package/dist/entities/icon/HanaWalletConnector.js +0 -92
- package/dist/entities/icon/HanaWalletConnector.js.map +0 -1
- package/dist/entities/icon/IconSpokeProvider.d.ts +0 -8
- package/dist/entities/icon/IconSpokeProvider.d.ts.map +0 -1
- package/dist/entities/icon/IconSpokeProvider.js +0 -9
- package/dist/entities/icon/IconSpokeProvider.js.map +0 -1
- package/dist/entities/icon/IconWalletProvider.d.ts +0 -12
- package/dist/entities/icon/IconWalletProvider.d.ts.map +0 -1
- package/dist/entities/icon/IconWalletProvider.js +0 -34
- package/dist/entities/icon/IconWalletProvider.js.map +0 -1
- package/dist/entities/icon/index.d.ts +0 -5
- package/dist/entities/icon/index.d.ts.map +0 -1
- package/dist/entities/icon/index.js +0 -5
- package/dist/entities/icon/index.js.map +0 -1
- package/dist/entities/icon/utils.d.ts +0 -3
- package/dist/entities/icon/utils.d.ts.map +0 -1
- package/dist/entities/icon/utils.js +0 -4
- package/dist/entities/icon/utils.js.map +0 -1
- package/dist/entities/index.d.ts +0 -8
- package/dist/entities/index.d.ts.map +0 -1
- package/dist/entities/index.js +0 -8
- package/dist/entities/index.js.map +0 -1
- package/dist/entities/solana/Configs.d.ts +0 -10
- package/dist/entities/solana/Configs.d.ts.map +0 -1
- package/dist/entities/solana/Configs.js +0 -50
- package/dist/entities/solana/Configs.js.map +0 -1
- package/dist/entities/solana/SolanaSpokeProvider.d.ts +0 -9
- package/dist/entities/solana/SolanaSpokeProvider.d.ts.map +0 -1
- package/dist/entities/solana/SolanaSpokeProvider.js +0 -9
- package/dist/entities/solana/SolanaSpokeProvider.js.map +0 -1
- package/dist/entities/solana/SolanaWalletProvider.d.ts +0 -20
- package/dist/entities/solana/SolanaWalletProvider.d.ts.map +0 -1
- package/dist/entities/solana/SolanaWalletProvider.js +0 -53
- package/dist/entities/solana/SolanaWalletProvider.js.map +0 -1
- package/dist/entities/solana/index.d.ts +0 -4
- package/dist/entities/solana/index.d.ts.map +0 -1
- package/dist/entities/solana/index.js +0 -4
- package/dist/entities/solana/index.js.map +0 -1
- package/dist/entities/solana/pda/pda.d.ts +0 -45
- package/dist/entities/solana/pda/pda.d.ts.map +0 -1
- package/dist/entities/solana/pda/pda.js +0 -44
- package/dist/entities/solana/pda/pda.js.map +0 -1
- package/dist/entities/solana/types/asset_manager.d.ts +0 -919
- package/dist/entities/solana/types/asset_manager.d.ts.map +0 -1
- package/dist/entities/solana/types/asset_manager.js +0 -2
- package/dist/entities/solana/types/asset_manager.js.map +0 -1
- package/dist/entities/solana/types/connection.d.ts +0 -446
- package/dist/entities/solana/types/connection.d.ts.map +0 -1
- package/dist/entities/solana/types/connection.js +0 -2
- package/dist/entities/solana/types/connection.js.map +0 -1
- package/dist/entities/solana/types/rate_limit_contract.d.ts +0 -348
- package/dist/entities/solana/types/rate_limit_contract.d.ts.map +0 -1
- package/dist/entities/solana/types/rate_limit_contract.js +0 -2
- package/dist/entities/solana/types/rate_limit_contract.js.map +0 -1
- package/dist/entities/solana/utils/utils.d.ts +0 -6
- package/dist/entities/solana/utils/utils.d.ts.map +0 -1
- package/dist/entities/solana/utils/utils.js +0 -17
- package/dist/entities/solana/utils/utils.js.map +0 -1
- package/dist/entities/stellar/StellarSpokeProvider.d.ts +0 -24
- package/dist/entities/stellar/StellarSpokeProvider.d.ts.map +0 -1
- package/dist/entities/stellar/StellarSpokeProvider.js +0 -129
- package/dist/entities/stellar/StellarSpokeProvider.js.map +0 -1
- package/dist/entities/sui/SuiSpokeProvider.d.ts +0 -34
- package/dist/entities/sui/SuiSpokeProvider.d.ts.map +0 -1
- package/dist/entities/sui/SuiSpokeProvider.js +0 -143
- package/dist/entities/sui/SuiSpokeProvider.js.map +0 -1
- package/dist/entities/sui/SuiWalletProvider.d.ts +0 -15
- package/dist/entities/sui/SuiWalletProvider.d.ts.map +0 -1
- package/dist/entities/sui/SuiWalletProvider.js +0 -43
- package/dist/entities/sui/SuiWalletProvider.js.map +0 -1
- package/dist/errors.d.ts +0 -2
- package/dist/errors.d.ts.map +0 -1
- package/dist/errors.js +0 -2
- package/dist/errors.js.map +0 -1
- package/dist/guards.d.ts +0 -25
- package/dist/guards.d.ts.map +0 -1
- package/dist/guards.js +0 -110
- package/dist/guards.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -10
- package/dist/index.js.map +0 -1
- package/dist/interfaces.d.ts +0 -8
- package/dist/interfaces.d.ts.map +0 -1
- package/dist/interfaces.js +0 -2
- package/dist/interfaces.js.map +0 -1
- package/dist/services/hub/EvmAssetManagerService.d.ts +0 -60
- package/dist/services/hub/EvmAssetManagerService.d.ts.map +0 -1
- package/dist/services/hub/EvmAssetManagerService.js +0 -103
- package/dist/services/hub/EvmAssetManagerService.js.map +0 -1
- package/dist/services/hub/EvmVaultTokenService.d.ts +0 -81
- package/dist/services/hub/EvmVaultTokenService.d.ts.map +0 -1
- package/dist/services/hub/EvmVaultTokenService.js +0 -159
- package/dist/services/hub/EvmVaultTokenService.js.map +0 -1
- package/dist/services/hub/EvmWalletAbstraction.d.ts +0 -8
- package/dist/services/hub/EvmWalletAbstraction.d.ts.map +0 -1
- package/dist/services/hub/EvmWalletAbstraction.js +0 -14
- package/dist/services/hub/EvmWalletAbstraction.js.map +0 -1
- package/dist/services/hub/index.d.ts +0 -4
- package/dist/services/hub/index.d.ts.map +0 -1
- package/dist/services/hub/index.js +0 -4
- package/dist/services/hub/index.js.map +0 -1
- package/dist/services/index.d.ts +0 -7
- package/dist/services/index.d.ts.map +0 -1
- package/dist/services/index.js +0 -7
- package/dist/services/index.js.map +0 -1
- package/dist/services/intentRelay/IntentRelayApiService.d.ts +0 -111
- package/dist/services/intentRelay/IntentRelayApiService.d.ts.map +0 -1
- package/dist/services/intentRelay/IntentRelayApiService.js +0 -160
- package/dist/services/intentRelay/IntentRelayApiService.js.map +0 -1
- package/dist/services/intentRelay/IntentRelayApiService.test.d.ts +0 -2
- package/dist/services/intentRelay/IntentRelayApiService.test.d.ts.map +0 -1
- package/dist/services/intentRelay/IntentRelayApiService.test.js +0 -134
- package/dist/services/intentRelay/IntentRelayApiService.test.js.map +0 -1
- package/dist/services/intentRelay/index.d.ts +0 -2
- package/dist/services/intentRelay/index.d.ts.map +0 -1
- package/dist/services/intentRelay/index.js +0 -2
- package/dist/services/intentRelay/index.js.map +0 -1
- package/dist/services/moneyMarket/MoneyMarketService.d.ts +0 -321
- package/dist/services/moneyMarket/MoneyMarketService.d.ts.map +0 -1
- package/dist/services/moneyMarket/MoneyMarketService.js +0 -604
- package/dist/services/moneyMarket/MoneyMarketService.js.map +0 -1
- package/dist/services/moneyMarket/MoneyMarketService.test.d.ts +0 -2
- package/dist/services/moneyMarket/MoneyMarketService.test.d.ts.map +0 -1
- package/dist/services/moneyMarket/MoneyMarketService.test.js +0 -245
- package/dist/services/moneyMarket/MoneyMarketService.test.js.map +0 -1
- package/dist/services/moneyMarket/index.d.ts +0 -2
- package/dist/services/moneyMarket/index.d.ts.map +0 -1
- package/dist/services/moneyMarket/index.js +0 -2
- package/dist/services/moneyMarket/index.js.map +0 -1
- package/dist/services/shared/Erc20Service.d.ts +0 -41
- package/dist/services/shared/Erc20Service.d.ts.map +0 -1
- package/dist/services/shared/Erc20Service.js +0 -107
- package/dist/services/shared/Erc20Service.js.map +0 -1
- package/dist/services/shared/index.d.ts +0 -2
- package/dist/services/shared/index.d.ts.map +0 -1
- package/dist/services/shared/index.js +0 -2
- package/dist/services/shared/index.js.map +0 -1
- package/dist/services/solver/EvmSolverService.d.ts +0 -125
- package/dist/services/solver/EvmSolverService.d.ts.map +0 -1
- package/dist/services/solver/EvmSolverService.js +0 -166
- package/dist/services/solver/EvmSolverService.js.map +0 -1
- package/dist/services/solver/SolverApiService.d.ts +0 -40
- package/dist/services/solver/SolverApiService.d.ts.map +0 -1
- package/dist/services/solver/SolverApiService.js +0 -157
- package/dist/services/solver/SolverApiService.js.map +0 -1
- package/dist/services/solver/SolverApiService.test.d.ts +0 -2
- package/dist/services/solver/SolverApiService.test.d.ts.map +0 -1
- package/dist/services/solver/SolverApiService.test.js +0 -180
- package/dist/services/solver/SolverApiService.test.js.map +0 -1
- package/dist/services/solver/SolverService.d.ts +0 -194
- package/dist/services/solver/SolverService.d.ts.map +0 -1
- package/dist/services/solver/SolverService.js +0 -324
- package/dist/services/solver/SolverService.js.map +0 -1
- package/dist/services/solver/SolverService.test.d.ts +0 -2
- package/dist/services/solver/SolverService.test.d.ts.map +0 -1
- package/dist/services/solver/SolverService.test.js +0 -493
- package/dist/services/solver/SolverService.test.js.map +0 -1
- package/dist/services/solver/index.d.ts +0 -3
- package/dist/services/solver/index.d.ts.map +0 -1
- package/dist/services/solver/index.js +0 -3
- package/dist/services/solver/index.js.map +0 -1
- package/dist/services/spoke/CWSpokeService.d.ts +0 -67
- package/dist/services/spoke/CWSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/CWSpokeService.js +0 -75
- package/dist/services/spoke/CWSpokeService.js.map +0 -1
- package/dist/services/spoke/EvmSpokeService.d.ts +0 -61
- package/dist/services/spoke/EvmSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/EvmSpokeService.js +0 -118
- package/dist/services/spoke/EvmSpokeService.js.map +0 -1
- package/dist/services/spoke/IconSpokeService.d.ts +0 -55
- package/dist/services/spoke/IconSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/IconSpokeService.js +0 -111
- package/dist/services/spoke/IconSpokeService.js.map +0 -1
- package/dist/services/spoke/SolanaSpokeService.d.ts +0 -45
- package/dist/services/spoke/SolanaSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/SolanaSpokeService.js +0 -170
- package/dist/services/spoke/SolanaSpokeService.js.map +0 -1
- package/dist/services/spoke/SpokeService.d.ts +0 -33
- package/dist/services/spoke/SpokeService.d.ts.map +0 -1
- package/dist/services/spoke/SpokeService.js +0 -102
- package/dist/services/spoke/SpokeService.js.map +0 -1
- package/dist/services/spoke/StellarSpokeService.d.ts +0 -35
- package/dist/services/spoke/StellarSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/StellarSpokeService.js +0 -39
- package/dist/services/spoke/StellarSpokeService.js.map +0 -1
- package/dist/services/spoke/SuiSpokeService.d.ts +0 -69
- package/dist/services/spoke/SuiSpokeService.d.ts.map +0 -1
- package/dist/services/spoke/SuiSpokeService.js +0 -74
- package/dist/services/spoke/SuiSpokeService.js.map +0 -1
- package/dist/services/spoke/index.d.ts +0 -3
- package/dist/services/spoke/index.d.ts.map +0 -1
- package/dist/services/spoke/index.js +0 -3
- package/dist/services/spoke/index.js.map +0 -1
- package/dist/tests/services/hub/EvmAssetManagerService.test.d.ts +0 -2
- package/dist/tests/services/hub/EvmAssetManagerService.test.d.ts.map +0 -1
- package/dist/tests/services/hub/EvmAssetManagerService.test.js +0 -123
- package/dist/tests/services/hub/EvmAssetManagerService.test.js.map +0 -1
- package/dist/tests/services/hub/EvmMoneyMarketService.test.d.ts +0 -2
- package/dist/tests/services/hub/EvmMoneyMarketService.test.d.ts.map +0 -1
- package/dist/tests/services/hub/EvmMoneyMarketService.test.js +0 -121
- package/dist/tests/services/hub/EvmMoneyMarketService.test.js.map +0 -1
- package/dist/tests/services/hub/EvmVaultTokenService.test.d.ts +0 -2
- package/dist/tests/services/hub/EvmVaultTokenService.test.d.ts.map +0 -1
- package/dist/tests/services/hub/EvmVaultTokenService.test.js +0 -98
- package/dist/tests/services/hub/EvmVaultTokenService.test.js.map +0 -1
- package/dist/tests/services/spoke/EvmSpokeService.test.d.ts +0 -2
- package/dist/tests/services/spoke/EvmSpokeService.test.d.ts.map +0 -1
- package/dist/tests/services/spoke/EvmSpokeService.test.js +0 -197
- package/dist/tests/services/spoke/EvmSpokeService.test.js.map +0 -1
- package/dist/types.d.ts +0 -395
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -30
- package/dist/types.js.map +0 -1
- package/dist/utils/evm-utils.d.ts +0 -10
- package/dist/utils/evm-utils.d.ts.map +0 -1
- package/dist/utils/evm-utils.js +0 -15
- package/dist/utils/evm-utils.js.map +0 -1
- package/dist/utils/index.d.ts +0 -3
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -3
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/shared-utils.d.ts +0 -19
- package/dist/utils/shared-utils.d.ts.map +0 -1
- package/dist/utils/shared-utils.js +0 -66
- package/dist/utils/shared-utils.js.map +0 -1
- package/dist/utils/shared-utils.test.d.ts +0 -2
- package/dist/utils/shared-utils.test.d.ts.map +0 -1
- package/dist/utils/shared-utils.test.js +0 -63
- package/dist/utils/shared-utils.test.js.map +0 -1
|
@@ -1,245 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
-
import { isMoneyMarketReserveAsset, MoneyMarketService, moneyMarketReserveAssets, EvmHubProvider, getHubChainConfig, SONIC_MAINNET_CHAIN_ID, BSC_MAINNET_CHAIN_ID, EvmSpokeProvider, spokeChainConfig, getSupportedMoneyMarketTokens, EvmWalletAbstraction, SpokeService, } from '../../index.js';
|
|
3
|
-
import * as IntentRelayApiService from '../intentRelay/IntentRelayApiService.js';
|
|
4
|
-
describe('MoneyMarketService', () => {
|
|
5
|
-
const mockEvmWalletProvider = {
|
|
6
|
-
sendTransaction: vi.fn(),
|
|
7
|
-
getWalletAddress: vi.fn().mockReturnValue('0x9999999999999999999999999999999999999999'),
|
|
8
|
-
getWalletAddressBytes: vi.fn().mockReturnValue('0x9999999999999999999999999999999999999999'),
|
|
9
|
-
waitForTransactionReceipt: vi.fn(),
|
|
10
|
-
};
|
|
11
|
-
const mockBscSpokeProvider = new EvmSpokeProvider(mockEvmWalletProvider, spokeChainConfig[BSC_MAINNET_CHAIN_ID]);
|
|
12
|
-
const supportedTokens = getSupportedMoneyMarketTokens(BSC_MAINNET_CHAIN_ID);
|
|
13
|
-
const hubConfig = {
|
|
14
|
-
hubRpcUrl: 'https://rpc.soniclabs.com',
|
|
15
|
-
chainConfig: getHubChainConfig(SONIC_MAINNET_CHAIN_ID),
|
|
16
|
-
};
|
|
17
|
-
const moneyMarket = new MoneyMarketService({
|
|
18
|
-
partnerFee: {
|
|
19
|
-
address: '0x9999999999999999999999999999999999999999',
|
|
20
|
-
percentage: 100,
|
|
21
|
-
},
|
|
22
|
-
}, new EvmHubProvider(hubConfig));
|
|
23
|
-
it('should have supported tokens', () => {
|
|
24
|
-
expect(supportedTokens.length).toBeGreaterThan(0);
|
|
25
|
-
});
|
|
26
|
-
it('should supply a token', async () => {
|
|
27
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
28
|
-
vi.spyOn(moneyMarket, 'supplyData').mockReturnValueOnce('0x');
|
|
29
|
-
vi.spyOn(SpokeService, 'deposit').mockResolvedValueOnce('0x');
|
|
30
|
-
const result = await moneyMarket.supply({
|
|
31
|
-
token: supportedTokens[0]?.address,
|
|
32
|
-
amount: 1000000000000000000n,
|
|
33
|
-
}, mockBscSpokeProvider, false);
|
|
34
|
-
expect(result.ok).toBe(true);
|
|
35
|
-
if (result.ok) {
|
|
36
|
-
expect(result.value).toBe('0x');
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
|
-
it('should supply a token raw', async () => {
|
|
40
|
-
const rawEvmTx = {
|
|
41
|
-
from: mockEvmWalletProvider.getWalletAddressBytes(),
|
|
42
|
-
to: '0x348BE44F63A458be9C1b13D6fD8e99048F297Bc3',
|
|
43
|
-
value: 1000000000000000000n,
|
|
44
|
-
data: '0xc6b4180b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000de0b6b3a764000000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000001499999999999999999999999999999999999999990000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
45
|
-
};
|
|
46
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
47
|
-
vi.spyOn(moneyMarket, 'supplyData').mockReturnValueOnce('0x');
|
|
48
|
-
const result = await moneyMarket.supply({
|
|
49
|
-
token: supportedTokens[0]?.address,
|
|
50
|
-
amount: rawEvmTx.value,
|
|
51
|
-
}, mockBscSpokeProvider, true);
|
|
52
|
-
expect(result.ok).toBe(true);
|
|
53
|
-
if (result.ok) {
|
|
54
|
-
expect(result.value).toEqual(rawEvmTx);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
it('should supply a token and submit', async () => {
|
|
58
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
59
|
-
vi.spyOn(moneyMarket, 'supply').mockReturnValueOnce({
|
|
60
|
-
ok: true,
|
|
61
|
-
value: '0x',
|
|
62
|
-
});
|
|
63
|
-
vi.spyOn(IntentRelayApiService, 'relayTxAndWaitPacket').mockResolvedValueOnce({
|
|
64
|
-
ok: true,
|
|
65
|
-
value: {
|
|
66
|
-
dst_tx_hash: '0x',
|
|
67
|
-
},
|
|
68
|
-
});
|
|
69
|
-
const result = await moneyMarket.supplyAndSubmit({
|
|
70
|
-
token: supportedTokens[0]?.address,
|
|
71
|
-
amount: 1000000000000000000n,
|
|
72
|
-
}, mockBscSpokeProvider);
|
|
73
|
-
expect(result.ok).toBe(true);
|
|
74
|
-
if (result.ok) {
|
|
75
|
-
expect(result.value).toEqual(['0x', '0x']);
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
it('should borrow a token', async () => {
|
|
79
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
80
|
-
vi.spyOn(moneyMarket, 'borrowData').mockReturnValueOnce('0x');
|
|
81
|
-
vi.spyOn(SpokeService, 'callWallet').mockResolvedValueOnce('0x');
|
|
82
|
-
const result = await moneyMarket.borrow({
|
|
83
|
-
token: supportedTokens[0]?.address,
|
|
84
|
-
amount: 1000000000000000000n,
|
|
85
|
-
}, mockBscSpokeProvider, false);
|
|
86
|
-
expect(result.ok).toBe(true);
|
|
87
|
-
if (result.ok) {
|
|
88
|
-
expect(result.value).toBe('0x');
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
it('should borrow a token raw', async () => {
|
|
92
|
-
const rawEvmTx = {
|
|
93
|
-
from: mockEvmWalletProvider.getWalletAddressBytes(),
|
|
94
|
-
to: '0x348BE44F63A458be9C1b13D6fD8e99048F297Bc3',
|
|
95
|
-
value: 1000000000000000000n,
|
|
96
|
-
data: '0xc6b4180b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000de0b6b3a764000000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000001499999999999999999999999999999999999999990000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
97
|
-
};
|
|
98
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
99
|
-
vi.spyOn(moneyMarket, 'borrowData').mockReturnValueOnce('0x');
|
|
100
|
-
vi.spyOn(SpokeService, 'callWallet').mockResolvedValueOnce(rawEvmTx);
|
|
101
|
-
const result = await moneyMarket.borrow({
|
|
102
|
-
token: supportedTokens[0]?.address,
|
|
103
|
-
amount: rawEvmTx.value,
|
|
104
|
-
}, mockBscSpokeProvider, true);
|
|
105
|
-
expect(result.ok).toBe(true);
|
|
106
|
-
if (result.ok) {
|
|
107
|
-
expect(result.value).toEqual(rawEvmTx);
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
it('should borrow a token and submit', async () => {
|
|
111
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
112
|
-
vi.spyOn(moneyMarket, 'borrow').mockReturnValueOnce({
|
|
113
|
-
ok: true,
|
|
114
|
-
value: '0x',
|
|
115
|
-
});
|
|
116
|
-
vi.spyOn(IntentRelayApiService, 'relayTxAndWaitPacket').mockResolvedValueOnce({
|
|
117
|
-
ok: true,
|
|
118
|
-
value: {
|
|
119
|
-
dst_tx_hash: '0x',
|
|
120
|
-
},
|
|
121
|
-
});
|
|
122
|
-
const result = await moneyMarket.borrowAndSubmit({
|
|
123
|
-
token: supportedTokens[0]?.address,
|
|
124
|
-
amount: 1000000000000000000n,
|
|
125
|
-
}, mockBscSpokeProvider);
|
|
126
|
-
expect(result.ok).toBe(true);
|
|
127
|
-
if (result.ok) {
|
|
128
|
-
expect(result.value).toEqual(['0x', '0x']);
|
|
129
|
-
}
|
|
130
|
-
});
|
|
131
|
-
it('should withdraw a token', async () => {
|
|
132
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
133
|
-
vi.spyOn(moneyMarket, 'withdrawData').mockReturnValueOnce('0x');
|
|
134
|
-
vi.spyOn(SpokeService, 'callWallet').mockResolvedValueOnce('0x');
|
|
135
|
-
const result = await moneyMarket.withdraw({
|
|
136
|
-
token: supportedTokens[0]?.address,
|
|
137
|
-
amount: 1000000000000000000n,
|
|
138
|
-
}, mockBscSpokeProvider, false);
|
|
139
|
-
expect(result.ok).toBe(true);
|
|
140
|
-
if (result.ok) {
|
|
141
|
-
expect(result.value).toBe('0x');
|
|
142
|
-
}
|
|
143
|
-
});
|
|
144
|
-
it('should withdraw a token raw', async () => {
|
|
145
|
-
const rawEvmTx = {
|
|
146
|
-
from: mockEvmWalletProvider.getWalletAddressBytes(),
|
|
147
|
-
to: '0x348BE44F63A458be9C1b13D6fD8e99048F297Bc3',
|
|
148
|
-
value: 1000000000000000000n,
|
|
149
|
-
data: '0xc6b4180b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000de0b6b3a764000000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000001499999999999999999999999999999999999999990000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
150
|
-
};
|
|
151
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
152
|
-
vi.spyOn(moneyMarket, 'withdrawData').mockReturnValueOnce('0x');
|
|
153
|
-
vi.spyOn(SpokeService, 'callWallet').mockResolvedValueOnce(rawEvmTx);
|
|
154
|
-
const result = await moneyMarket.withdraw({
|
|
155
|
-
token: supportedTokens[0]?.address,
|
|
156
|
-
amount: rawEvmTx.value,
|
|
157
|
-
}, mockBscSpokeProvider, true);
|
|
158
|
-
expect(result.ok).toBe(true);
|
|
159
|
-
if (result.ok) {
|
|
160
|
-
expect(result.value).toEqual(rawEvmTx);
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
it('should withdraw a token and submit', async () => {
|
|
164
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
165
|
-
vi.spyOn(moneyMarket, 'withdraw').mockReturnValueOnce({
|
|
166
|
-
ok: true,
|
|
167
|
-
value: '0x',
|
|
168
|
-
});
|
|
169
|
-
vi.spyOn(IntentRelayApiService, 'relayTxAndWaitPacket').mockResolvedValueOnce({
|
|
170
|
-
ok: true,
|
|
171
|
-
value: {
|
|
172
|
-
dst_tx_hash: '0x',
|
|
173
|
-
},
|
|
174
|
-
});
|
|
175
|
-
const result = await moneyMarket.withdrawAndSubmit({
|
|
176
|
-
token: supportedTokens[0]?.address,
|
|
177
|
-
amount: 1000000000000000000n,
|
|
178
|
-
}, mockBscSpokeProvider);
|
|
179
|
-
expect(result.ok).toBe(true);
|
|
180
|
-
if (result.ok) {
|
|
181
|
-
expect(result.value).toEqual(['0x', '0x']);
|
|
182
|
-
}
|
|
183
|
-
});
|
|
184
|
-
it('should repay a token', async () => {
|
|
185
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
186
|
-
vi.spyOn(moneyMarket, 'repayData').mockReturnValueOnce('0x');
|
|
187
|
-
vi.spyOn(SpokeService, 'deposit').mockResolvedValueOnce('0x');
|
|
188
|
-
const result = await moneyMarket.repay({
|
|
189
|
-
token: supportedTokens[0]?.address,
|
|
190
|
-
amount: 1000000000000000000n,
|
|
191
|
-
}, mockBscSpokeProvider, false);
|
|
192
|
-
expect(result.ok).toBe(true);
|
|
193
|
-
if (result.ok) {
|
|
194
|
-
expect(result.value).toBe('0x');
|
|
195
|
-
}
|
|
196
|
-
});
|
|
197
|
-
it('should repay a token raw', async () => {
|
|
198
|
-
const rawEvmTx = {
|
|
199
|
-
from: mockEvmWalletProvider.getWalletAddressBytes(),
|
|
200
|
-
to: '0x348BE44F63A458be9C1b13D6fD8e99048F297Bc3',
|
|
201
|
-
value: 1000000000000000000n,
|
|
202
|
-
data: '0xc6b4180b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000de0b6b3a764000000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000001499999999999999999999999999999999999999990000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
203
|
-
};
|
|
204
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
205
|
-
vi.spyOn(moneyMarket, 'repayData').mockReturnValueOnce('0x');
|
|
206
|
-
vi.spyOn(SpokeService, 'deposit').mockResolvedValueOnce(rawEvmTx);
|
|
207
|
-
const result = await moneyMarket.repay({
|
|
208
|
-
token: supportedTokens[0]?.address,
|
|
209
|
-
amount: rawEvmTx.value,
|
|
210
|
-
}, mockBscSpokeProvider, true);
|
|
211
|
-
expect(result.ok).toBe(true);
|
|
212
|
-
if (result.ok) {
|
|
213
|
-
expect(result.value).toEqual(rawEvmTx);
|
|
214
|
-
}
|
|
215
|
-
});
|
|
216
|
-
it('should repay a token and submit', async () => {
|
|
217
|
-
vi.spyOn(EvmWalletAbstraction, 'getUserHubWalletAddress').mockResolvedValueOnce(mockEvmWalletProvider.getWalletAddressBytes());
|
|
218
|
-
vi.spyOn(moneyMarket, 'repay').mockReturnValueOnce({
|
|
219
|
-
ok: true,
|
|
220
|
-
value: '0x',
|
|
221
|
-
});
|
|
222
|
-
vi.spyOn(IntentRelayApiService, 'relayTxAndWaitPacket').mockResolvedValueOnce({
|
|
223
|
-
ok: true,
|
|
224
|
-
value: {
|
|
225
|
-
dst_tx_hash: '0x',
|
|
226
|
-
},
|
|
227
|
-
});
|
|
228
|
-
const result = await moneyMarket.repayAndSubmit({
|
|
229
|
-
token: supportedTokens[0]?.address,
|
|
230
|
-
amount: 1000000000000000000n,
|
|
231
|
-
}, mockBscSpokeProvider);
|
|
232
|
-
expect(result.ok).toBe(true);
|
|
233
|
-
if (result.ok) {
|
|
234
|
-
expect(result.value).toEqual(['0x', '0x']);
|
|
235
|
-
}
|
|
236
|
-
});
|
|
237
|
-
it('should be defined', () => {
|
|
238
|
-
expect(MoneyMarketService).toBeDefined();
|
|
239
|
-
const testAsset = moneyMarketReserveAssets[0];
|
|
240
|
-
const wrongAsset = '0x0000000000000000000000000000000000000000';
|
|
241
|
-
expect(isMoneyMarketReserveAsset(testAsset)).toBe(true);
|
|
242
|
-
expect(isMoneyMarketReserveAsset(wrongAsset)).toBe(false);
|
|
243
|
-
});
|
|
244
|
-
});
|
|
245
|
-
//# sourceMappingURL=MoneyMarketService.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MoneyMarketService.test.js","sourceRoot":"","sources":["../../../src/services/moneyMarket/MoneyMarketService.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/moneyMarket/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/moneyMarket/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { type Address } from 'viem';
|
|
2
|
-
import type { EvmContractCall, EvmRawTransactionReceipt, Result } from '../../types.js';
|
|
3
|
-
import type { EvmSpokeProvider } from '../../entities/Providers.js';
|
|
4
|
-
export declare class Erc20Service {
|
|
5
|
-
private constructor();
|
|
6
|
-
/**
|
|
7
|
-
* Check if spender has enough ERC20 allowance for given amount
|
|
8
|
-
* @param token - ERC20 token address
|
|
9
|
-
* @param amount - Amount to check allowance for
|
|
10
|
-
* @param from - User wallet address
|
|
11
|
-
* @param to - Address to check allowance for
|
|
12
|
-
* @param spokeProvider - EVM Spoke provider
|
|
13
|
-
* @return - True if spender is allowed to spend amount on behalf of owner
|
|
14
|
-
*/
|
|
15
|
-
static isAllowanceValid(token: Address, amount: bigint, owner: Address, spender: Address, spokeProvider: EvmSpokeProvider): Promise<Result<boolean>>;
|
|
16
|
-
/**
|
|
17
|
-
* Approve ERC20 amount spending
|
|
18
|
-
* @param token - ERC20 token address
|
|
19
|
-
* @param amount - Amount to approve
|
|
20
|
-
* @param address - Address to approve spending for
|
|
21
|
-
* @param provider - EVM Provider
|
|
22
|
-
*/
|
|
23
|
-
static approve(token: Address, amount: bigint, address: Address, spokeProvider: EvmSpokeProvider): Promise<Result<EvmRawTransactionReceipt>>;
|
|
24
|
-
/**
|
|
25
|
-
* Encodes a transfer transaction for a token.
|
|
26
|
-
* @param token - The address of the token.
|
|
27
|
-
* @param to - The address to transfer the token to.
|
|
28
|
-
* @param amount - The amount of the token to transfer.
|
|
29
|
-
* @returns The encoded contract call.
|
|
30
|
-
*/
|
|
31
|
-
static encodeTansfer(token: Address, to: Address, amount: bigint): EvmContractCall;
|
|
32
|
-
/**
|
|
33
|
-
* Encodes an approval transaction for a token.
|
|
34
|
-
* @param token - The address of the token.
|
|
35
|
-
* @param to - The address to approve the token to.
|
|
36
|
-
* @param amount - The amount of the token to approve.
|
|
37
|
-
* @returns The encoded contract call.
|
|
38
|
-
*/
|
|
39
|
-
static encodeApprove(token: Address, to: Address, amount: bigint): EvmContractCall;
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=Erc20Service.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Erc20Service.d.ts","sourceRoot":"","sources":["../../../src/services/shared/Erc20Service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,KAAK,OAAO,EAAE,MAAM,MAAM,CAAC;AAClE,OAAO,KAAK,EAAE,eAAe,EAAE,wBAAwB,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAEpE,qBAAa,YAAY;IACvB,OAAO;IAEP;;;;;;;;OAQG;WACU,gBAAgB,CAC3B,KAAK,EAAE,OAAO,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,OAAO,EACd,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,gBAAgB,GAC9B,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IA4B3B;;;;;;OAMG;WACU,OAAO,CAClB,KAAK,EAAE,OAAO,EACd,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,gBAAgB,GAC9B,OAAO,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC;IAyB5C;;;;;;OAMG;WACW,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe;IAYzF;;;;;;OAMG;WACW,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe;CAW1F"}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { encodeFunctionData, erc20Abi } from 'viem';
|
|
2
|
-
export class Erc20Service {
|
|
3
|
-
constructor() { }
|
|
4
|
-
/**
|
|
5
|
-
* Check if spender has enough ERC20 allowance for given amount
|
|
6
|
-
* @param token - ERC20 token address
|
|
7
|
-
* @param amount - Amount to check allowance for
|
|
8
|
-
* @param from - User wallet address
|
|
9
|
-
* @param to - Address to check allowance for
|
|
10
|
-
* @param spokeProvider - EVM Spoke provider
|
|
11
|
-
* @return - True if spender is allowed to spend amount on behalf of owner
|
|
12
|
-
*/
|
|
13
|
-
static async isAllowanceValid(token, amount, owner, spender, spokeProvider) {
|
|
14
|
-
try {
|
|
15
|
-
if (token.toLowerCase() === spokeProvider.chainConfig.nativeToken.toLowerCase()) {
|
|
16
|
-
return {
|
|
17
|
-
ok: true,
|
|
18
|
-
value: true,
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
const allowedAmount = await spokeProvider.publicClient.readContract({
|
|
22
|
-
address: token,
|
|
23
|
-
abi: erc20Abi,
|
|
24
|
-
functionName: 'allowance',
|
|
25
|
-
args: [owner, spender],
|
|
26
|
-
});
|
|
27
|
-
return {
|
|
28
|
-
ok: true,
|
|
29
|
-
value: allowedAmount >= amount,
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
catch (e) {
|
|
33
|
-
return {
|
|
34
|
-
ok: false,
|
|
35
|
-
error: e,
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Approve ERC20 amount spending
|
|
41
|
-
* @param token - ERC20 token address
|
|
42
|
-
* @param amount - Amount to approve
|
|
43
|
-
* @param address - Address to approve spending for
|
|
44
|
-
* @param provider - EVM Provider
|
|
45
|
-
*/
|
|
46
|
-
static async approve(token, amount, address, spokeProvider) {
|
|
47
|
-
try {
|
|
48
|
-
const hash = await spokeProvider.walletProvider.sendTransaction({
|
|
49
|
-
from: spokeProvider.walletProvider.getWalletAddress(),
|
|
50
|
-
to: token,
|
|
51
|
-
value: 0n,
|
|
52
|
-
data: encodeFunctionData({
|
|
53
|
-
abi: erc20Abi,
|
|
54
|
-
functionName: 'approve',
|
|
55
|
-
args: [address, amount],
|
|
56
|
-
}),
|
|
57
|
-
});
|
|
58
|
-
return {
|
|
59
|
-
ok: true,
|
|
60
|
-
value: await spokeProvider.walletProvider.waitForTransactionReceipt(hash),
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
catch (e) {
|
|
64
|
-
return {
|
|
65
|
-
ok: false,
|
|
66
|
-
error: e,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Encodes a transfer transaction for a token.
|
|
72
|
-
* @param token - The address of the token.
|
|
73
|
-
* @param to - The address to transfer the token to.
|
|
74
|
-
* @param amount - The amount of the token to transfer.
|
|
75
|
-
* @returns The encoded contract call.
|
|
76
|
-
*/
|
|
77
|
-
static encodeTansfer(token, to, amount) {
|
|
78
|
-
return {
|
|
79
|
-
address: token,
|
|
80
|
-
value: 0n,
|
|
81
|
-
data: encodeFunctionData({
|
|
82
|
-
abi: erc20Abi,
|
|
83
|
-
functionName: 'transfer',
|
|
84
|
-
args: [to, amount],
|
|
85
|
-
}),
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Encodes an approval transaction for a token.
|
|
90
|
-
* @param token - The address of the token.
|
|
91
|
-
* @param to - The address to approve the token to.
|
|
92
|
-
* @param amount - The amount of the token to approve.
|
|
93
|
-
* @returns The encoded contract call.
|
|
94
|
-
*/
|
|
95
|
-
static encodeApprove(token, to, amount) {
|
|
96
|
-
return {
|
|
97
|
-
address: token,
|
|
98
|
-
value: 0n,
|
|
99
|
-
data: encodeFunctionData({
|
|
100
|
-
abi: erc20Abi,
|
|
101
|
-
functionName: 'approve',
|
|
102
|
-
args: [to, amount],
|
|
103
|
-
}),
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
//# sourceMappingURL=Erc20Service.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Erc20Service.js","sourceRoot":"","sources":["../../../src/services/shared/Erc20Service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAgB,MAAM,MAAM,CAAC;AAIlE,MAAM,OAAO,YAAY;IACvB,gBAAuB,CAAC;IAExB;;;;;;;;OAQG;IACH,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAC3B,KAAc,EACd,MAAc,EACd,KAAc,EACd,OAAgB,EAChB,aAA+B;QAE/B,IAAI,CAAC;YACH,IAAI,KAAK,CAAC,WAAW,EAAE,KAAK,aAAa,CAAC,WAAW,CAAC,WAAW,CAAC,WAAW,EAAE,EAAE,CAAC;gBAChF,OAAO;oBACL,EAAE,EAAE,IAAI;oBACR,KAAK,EAAE,IAAI;iBACZ,CAAC;YACJ,CAAC;YAED,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,YAAY,CAAC,YAAY,CAAC;gBAClE,OAAO,EAAE,KAAK;gBACd,GAAG,EAAE,QAAQ;gBACb,YAAY,EAAE,WAAW;gBACzB,IAAI,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;aACvB,CAAC,CAAC;YAEH,OAAO;gBACL,EAAE,EAAE,IAAI;gBACR,KAAK,EAAE,aAAa,IAAI,MAAM;aAC/B,CAAC;QACJ,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO;gBACL,EAAE,EAAE,KAAK;gBACT,KAAK,EAAE,CAAC;aACT,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO,CAClB,KAAc,EACd,MAAc,EACd,OAAgB,EAChB,aAA+B;QAE/B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,aAAa,CAAC,cAAc,CAAC,eAAe,CAAC;gBAC9D,IAAI,EAAE,aAAa,CAAC,cAAc,CAAC,gBAAgB,EAAE;gBACrD,EAAE,EAAE,KAAK;gBACT,KAAK,EAAE,EAAE;gBACT,IAAI,EAAE,kBAAkB,CAAC;oBACvB,GAAG,EAAE,QAAQ;oBACb,YAAY,EAAE,SAAS;oBACvB,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC;iBACxB,CAAC;aACH,CAAC,CAAC;YAEH,OAAO;gBACL,EAAE,EAAE,IAAI;gBACR,KAAK,EAAE,MAAM,aAAa,CAAC,cAAc,CAAC,yBAAyB,CAAC,IAAI,CAAC;aAC1E,CAAC;QACJ,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO;gBACL,EAAE,EAAE,KAAK;gBACT,KAAK,EAAE,CAAC;aACT,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,aAAa,CAAC,KAAc,EAAE,EAAW,EAAE,MAAc;QACrE,OAAO;YACL,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,kBAAkB,CAAC;gBACvB,GAAG,EAAE,QAAQ;gBACb,YAAY,EAAE,UAAU;gBACxB,IAAI,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC;aACnB,CAAC;SACH,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,aAAa,CAAC,KAAc,EAAE,EAAW,EAAE,MAAc;QACrE,OAAO;YACL,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,kBAAkB,CAAC;gBACvB,GAAG,EAAE,QAAQ;gBACb,YAAY,EAAE,SAAS;gBACvB,IAAI,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC;aACnB,CAAC;SACH,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/shared/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
import { type Address, type GetLogsReturnType } from 'viem';
|
|
2
|
-
import { type EvmContractCall, type EvmHubProvider, type Hash, type Hex, type PartnerFee, type SolverConfig } from '../../index.js';
|
|
3
|
-
import { type CreateIntentParams, type Intent } from '../index.js';
|
|
4
|
-
export declare const IntentCreatedEventAbi: {
|
|
5
|
-
readonly type: "event";
|
|
6
|
-
readonly name: "IntentCreated";
|
|
7
|
-
readonly inputs: readonly [{
|
|
8
|
-
readonly name: "intentHash";
|
|
9
|
-
readonly type: "bytes32";
|
|
10
|
-
readonly indexed: false;
|
|
11
|
-
readonly internalType: "bytes32";
|
|
12
|
-
}, {
|
|
13
|
-
readonly name: "intent";
|
|
14
|
-
readonly type: "tuple";
|
|
15
|
-
readonly indexed: false;
|
|
16
|
-
readonly internalType: "struct Intents.Intent";
|
|
17
|
-
readonly components: readonly [{
|
|
18
|
-
readonly name: "intentId";
|
|
19
|
-
readonly type: "uint256";
|
|
20
|
-
readonly internalType: "uint256";
|
|
21
|
-
}, {
|
|
22
|
-
readonly name: "creator";
|
|
23
|
-
readonly type: "address";
|
|
24
|
-
readonly internalType: "address";
|
|
25
|
-
}, {
|
|
26
|
-
readonly name: "inputToken";
|
|
27
|
-
readonly type: "address";
|
|
28
|
-
readonly internalType: "address";
|
|
29
|
-
}, {
|
|
30
|
-
readonly name: "outputToken";
|
|
31
|
-
readonly type: "address";
|
|
32
|
-
readonly internalType: "address";
|
|
33
|
-
}, {
|
|
34
|
-
readonly name: "inputAmount";
|
|
35
|
-
readonly type: "uint256";
|
|
36
|
-
readonly internalType: "uint256";
|
|
37
|
-
}, {
|
|
38
|
-
readonly name: "minOutputAmount";
|
|
39
|
-
readonly type: "uint256";
|
|
40
|
-
readonly internalType: "uint256";
|
|
41
|
-
}, {
|
|
42
|
-
readonly name: "deadline";
|
|
43
|
-
readonly type: "uint256";
|
|
44
|
-
readonly internalType: "uint256";
|
|
45
|
-
}, {
|
|
46
|
-
readonly name: "allowPartialFill";
|
|
47
|
-
readonly type: "bool";
|
|
48
|
-
readonly internalType: "bool";
|
|
49
|
-
}, {
|
|
50
|
-
readonly name: "srcChain";
|
|
51
|
-
readonly type: "uint256";
|
|
52
|
-
readonly internalType: "uint256";
|
|
53
|
-
}, {
|
|
54
|
-
readonly name: "dstChain";
|
|
55
|
-
readonly type: "uint256";
|
|
56
|
-
readonly internalType: "uint256";
|
|
57
|
-
}, {
|
|
58
|
-
readonly name: "srcAddress";
|
|
59
|
-
readonly type: "bytes";
|
|
60
|
-
readonly internalType: "bytes";
|
|
61
|
-
}, {
|
|
62
|
-
readonly name: "dstAddress";
|
|
63
|
-
readonly type: "bytes";
|
|
64
|
-
readonly internalType: "bytes";
|
|
65
|
-
}, {
|
|
66
|
-
readonly name: "solver";
|
|
67
|
-
readonly type: "address";
|
|
68
|
-
readonly internalType: "address";
|
|
69
|
-
}, {
|
|
70
|
-
readonly name: "data";
|
|
71
|
-
readonly type: "bytes";
|
|
72
|
-
readonly internalType: "bytes";
|
|
73
|
-
}];
|
|
74
|
-
}];
|
|
75
|
-
readonly anonymous: false;
|
|
76
|
-
};
|
|
77
|
-
export type IntentCreatedEventLog = GetLogsReturnType<typeof IntentCreatedEventAbi>[number];
|
|
78
|
-
export declare class EvmSolverService {
|
|
79
|
-
private constructor();
|
|
80
|
-
/**
|
|
81
|
-
* Constructs the create intent data for EVM Hub chain
|
|
82
|
-
* @param {CreateIntentParams} createIntentParams - The create intent parameters
|
|
83
|
-
* @param {Address} creatorHubWalletAddress - The creator hub wallet address
|
|
84
|
-
* @param {SolverConfig} solverConfig - The intent configuration
|
|
85
|
-
* @param {PartnerFee} fee - The partner fee configuration
|
|
86
|
-
* @returns {Promise<[Hex, Intent, bigint]>} The encoded contract call, intent and fee amount
|
|
87
|
-
*/
|
|
88
|
-
static constructCreateIntentData(createIntentParams: CreateIntentParams, creatorHubWalletAddress: Address, solverConfig: SolverConfig, fee: PartnerFee | undefined): [Hex, Intent, bigint];
|
|
89
|
-
/**
|
|
90
|
-
* Creates encoded fee data for an intent
|
|
91
|
-
* @param fee The partner fee configuration
|
|
92
|
-
* @param inputAmount The input amount to calculate percentage-based fee from
|
|
93
|
-
* @returns A tuple containing [encoded fee data, fee amount]. Fee amount will be 0n if no fee.
|
|
94
|
-
*/
|
|
95
|
-
static createIntentFeeData(fee: PartnerFee | undefined, inputAmount: bigint): [Hex, bigint];
|
|
96
|
-
/**
|
|
97
|
-
* Gets an intent from a transaction hash
|
|
98
|
-
* @param {Hash} txHash - The transaction hash
|
|
99
|
-
* @param {SolverConfig} solverConfig - The solver configuration
|
|
100
|
-
* @param {EvmHubProvider} hubProvider - The EVM hub provider
|
|
101
|
-
* @returns {Promise<Intent>} The intent
|
|
102
|
-
*/
|
|
103
|
-
static getIntent(txHash: Hash, solverConfig: SolverConfig, hubProvider: EvmHubProvider): Promise<Intent>;
|
|
104
|
-
/**
|
|
105
|
-
* Gets the keccak256 hash of an intent. Hash serves as the intent id on Hub chain.
|
|
106
|
-
* @param {Intent} intent - The intent
|
|
107
|
-
* @returns {Hex} The keccak256 hash of the intent
|
|
108
|
-
*/
|
|
109
|
-
static getIntentHash(intent: Intent): Hex;
|
|
110
|
-
/**
|
|
111
|
-
* Encodes a createIntent transaction
|
|
112
|
-
* @param {Intent} intent - The intent to create
|
|
113
|
-
* @param {Address} intentsContract - The address of the intents contract
|
|
114
|
-
* @returns {EvmContractCall} The encoded contract call
|
|
115
|
-
*/
|
|
116
|
-
static encodeCreateIntent(intent: Intent, intentsContract: Address): EvmContractCall;
|
|
117
|
-
/**
|
|
118
|
-
* Encodes a cancelIntent transaction
|
|
119
|
-
* @param {Intent} intent - The intent to cancel
|
|
120
|
-
* @param {Address} intentsContract - The address of the intents contract
|
|
121
|
-
* @returns {EvmContractCall} The encoded contract call
|
|
122
|
-
*/
|
|
123
|
-
static encodeCancelIntent(intent: Intent, intentsContract: Address): EvmContractCall;
|
|
124
|
-
}
|
|
125
|
-
//# sourceMappingURL=EvmSolverService.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"EvmSolverService.d.ts","sourceRoot":"","sources":["../../../src/services/solver/EvmSolverService.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,OAAO,EACZ,KAAK,iBAAiB,EAOvB,MAAM,MAAM,CAAC;AACd,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EAEnB,KAAK,IAAI,EACT,KAAK,GAAG,EAER,KAAK,UAAU,EACf,KAAK,YAAY,EASlB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,KAAK,kBAAkB,EAGvB,KAAK,MAAM,EAGZ,MAAM,aAAa,CAAC;AAErB,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAyD,CAAC;AAC5F,MAAM,MAAM,qBAAqB,GAAG,iBAAiB,CAAC,OAAO,qBAAqB,CAAC,CAAC,MAAM,CAAC,CAAC;AAE5F,qBAAa,gBAAgB;IAC3B,OAAO;IAEP;;;;;;;OAOG;WACW,yBAAyB,CACrC,kBAAkB,EAAE,kBAAkB,EACtC,uBAAuB,EAAE,OAAO,EAChC,YAAY,EAAE,YAAY,EAC1B,GAAG,EAAE,UAAU,GAAG,SAAS,GAC1B,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC;IAmCxB;;;;;OAKG;WACW,mBAAmB,CAAC,GAAG,EAAE,UAAU,GAAG,SAAS,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC;IA6ClG;;;;;;OAMG;WACiB,SAAS,CAC3B,MAAM,EAAE,IAAI,EACZ,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,cAAc,GAC1B,OAAO,CAAC,MAAM,CAAC;IAyClB;;;;OAIG;WACW,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG;IAIhD;;;;;OAKG;WACW,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,OAAO,GAAG,eAAe;IAY3F;;;;;OAKG;WACW,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,OAAO,GAAG,eAAe;CAW5F"}
|