@mento-protocol/mento-sdk 3.0.0-beta.2 → 3.0.0-beta.21
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 +34 -0
- package/dist/cache/routes.d.ts +13 -0
- package/dist/cache/routes.d.ts.map +1 -0
- package/dist/cache/routes.js +130 -0
- package/dist/cache/routes.js.map +1 -0
- package/dist/cache/tokens.d.ts +67 -0
- package/dist/cache/tokens.d.ts.map +1 -0
- package/dist/cache/tokens.js +379 -0
- package/dist/cache/tokens.js.map +1 -0
- package/dist/core/abis/activePool.d.ts +2 -0
- package/dist/core/abis/activePool.d.ts.map +1 -0
- package/dist/core/abis/activePool.js +14 -0
- package/dist/core/abis/activePool.js.map +1 -0
- package/dist/core/abis/addressesRegistry.d.ts +2 -0
- package/dist/core/abis/addressesRegistry.d.ts.map +1 -0
- package/dist/core/abis/addressesRegistry.js +26 -0
- package/dist/core/abis/addressesRegistry.js.map +1 -0
- package/dist/core/abis/borrowerOperations.d.ts +9 -0
- package/dist/core/abis/borrowerOperations.d.ts.map +1 -0
- package/dist/core/abis/borrowerOperations.js +89 -0
- package/dist/core/abis/borrowerOperations.js.map +1 -0
- package/dist/core/abis/breakerbox.d.ts +13 -0
- package/dist/core/abis/breakerbox.d.ts.map +1 -0
- package/dist/core/abis/breakerbox.js +8 -0
- package/dist/core/abis/breakerbox.js.map +1 -0
- package/dist/core/abis/erc20.d.ts +7 -0
- package/dist/core/abis/erc20.d.ts.map +1 -1
- package/dist/core/abis/erc20.js +7 -0
- package/dist/core/abis/erc20.js.map +1 -1
- package/dist/core/abis/fpmm.d.ts +128 -0
- package/dist/core/abis/fpmm.d.ts.map +1 -1
- package/dist/core/abis/fpmm.js +10 -0
- package/dist/core/abis/fpmm.js.map +1 -1
- package/dist/core/abis/hintHelpers.d.ts +2 -0
- package/dist/core/abis/hintHelpers.d.ts.map +1 -0
- package/dist/core/abis/hintHelpers.js +14 -0
- package/dist/core/abis/hintHelpers.js.map +1 -0
- package/dist/core/abis/index.d.ts +12 -0
- package/dist/core/abis/index.d.ts.map +1 -1
- package/dist/core/abis/index.js +12 -0
- package/dist/core/abis/index.js.map +1 -1
- package/dist/core/abis/multiTroveGetter.d.ts +8 -0
- package/dist/core/abis/multiTroveGetter.d.ts.map +1 -0
- package/dist/core/abis/multiTroveGetter.js +15 -0
- package/dist/core/abis/multiTroveGetter.js.map +1 -0
- package/dist/core/abis/priceFeed.d.ts +7 -0
- package/dist/core/abis/priceFeed.d.ts.map +1 -0
- package/dist/core/abis/priceFeed.js +16 -0
- package/dist/core/abis/priceFeed.js.map +1 -0
- package/dist/core/abis/router.d.ts +436 -1
- package/dist/core/abis/router.d.ts.map +1 -1
- package/dist/core/abis/router.js +13 -0
- package/dist/core/abis/router.js.map +1 -1
- package/dist/core/abis/sortedTroves.d.ts +2 -0
- package/dist/core/abis/sortedTroves.d.ts.map +1 -0
- package/dist/core/abis/sortedTroves.js +15 -0
- package/dist/core/abis/sortedTroves.js.map +1 -0
- package/dist/core/abis/systemParams.d.ts +2 -0
- package/dist/core/abis/systemParams.d.ts.map +1 -0
- package/dist/core/abis/systemParams.js +14 -0
- package/dist/core/abis/systemParams.js.map +1 -0
- package/dist/core/abis/troveManager.d.ts +2 -0
- package/dist/core/abis/troveManager.d.ts.map +1 -0
- package/dist/core/abis/troveManager.js +27 -0
- package/dist/core/abis/troveManager.js.map +1 -0
- package/dist/core/abis/troveNFT.d.ts +2 -0
- package/dist/core/abis/troveNFT.d.ts.map +1 -0
- package/dist/core/abis/troveNFT.js +9 -0
- package/dist/core/abis/troveNFT.js.map +1 -0
- package/dist/core/abis/virtualPool.d.ts +40 -0
- package/dist/core/abis/virtualPool.d.ts.map +1 -1
- package/dist/core/abis/virtualPool.js +6 -1
- package/dist/core/abis/virtualPool.js.map +1 -1
- package/dist/core/abis/virtualPoolFactory.d.ts +8 -0
- package/dist/core/abis/virtualPoolFactory.d.ts.map +1 -1
- package/dist/core/abis/virtualPoolFactory.js +1 -0
- package/dist/core/abis/virtualPoolFactory.js.map +1 -1
- package/dist/core/constants/aaveConfig.js +2 -2
- package/dist/core/constants/addresses.d.ts.map +1 -1
- package/dist/core/constants/addresses.js +9 -4
- package/dist/core/constants/addresses.js.map +1 -1
- package/dist/core/constants/borrowConstants.d.ts +10 -0
- package/dist/core/constants/borrowConstants.d.ts.map +1 -0
- package/dist/core/constants/borrowConstants.js +16 -0
- package/dist/core/constants/borrowConstants.js.map +1 -0
- package/dist/core/constants/borrowRegistries.d.ts +7 -0
- package/dist/core/constants/borrowRegistries.d.ts.map +1 -0
- package/dist/core/constants/borrowRegistries.js +31 -0
- package/dist/core/constants/borrowRegistries.js.map +1 -0
- package/dist/core/constants/index.d.ts +2 -0
- package/dist/core/constants/index.d.ts.map +1 -1
- package/dist/core/constants/index.js +2 -0
- package/dist/core/constants/index.js.map +1 -1
- package/dist/core/errors/index.d.ts +1 -0
- package/dist/core/errors/index.d.ts.map +1 -1
- package/dist/core/errors/index.js +1 -0
- package/dist/core/errors/index.js.map +1 -1
- package/dist/core/errors/oracle.d.ts +9 -0
- package/dist/core/errors/oracle.d.ts.map +1 -0
- package/dist/core/errors/oracle.js +15 -0
- package/dist/core/errors/oracle.js.map +1 -0
- package/dist/core/errors/router.d.ts +6 -0
- package/dist/core/errors/router.d.ts.map +1 -1
- package/dist/core/errors/router.js +11 -1
- package/dist/core/errors/router.js.map +1 -1
- package/dist/core/types/borrow.d.ts +87 -0
- package/dist/core/types/borrow.d.ts.map +1 -0
- package/dist/core/types/borrow.js +3 -0
- package/dist/core/types/borrow.js.map +1 -0
- package/dist/core/types/contractAddresses.d.ts +2 -0
- package/dist/core/types/contractAddresses.d.ts.map +1 -1
- package/dist/core/types/index.d.ts +5 -1
- package/dist/core/types/index.d.ts.map +1 -1
- package/dist/core/types/index.js +5 -1
- package/dist/core/types/index.js.map +1 -1
- package/dist/core/types/liquidity.d.ts +117 -0
- package/dist/core/types/liquidity.d.ts.map +1 -0
- package/dist/core/types/liquidity.js +3 -0
- package/dist/core/types/liquidity.js.map +1 -0
- package/dist/core/types/pool.d.ts +110 -0
- package/dist/core/types/pool.d.ts.map +1 -1
- package/dist/core/types/provider.d.ts.map +1 -1
- package/dist/core/types/provider.js +0 -1
- package/dist/core/types/provider.js.map +1 -1
- package/dist/core/types/route.d.ts +3 -3
- package/dist/core/types/route.d.ts.map +1 -1
- package/dist/core/types/token.d.ts +13 -3
- package/dist/core/types/token.d.ts.map +1 -1
- package/dist/core/types/tradingLimits.d.ts +91 -0
- package/dist/core/types/tradingLimits.d.ts.map +1 -0
- package/dist/core/types/tradingLimits.js +3 -0
- package/dist/core/types/tradingLimits.js.map +1 -0
- package/dist/core/types/tradingMode.d.ts +24 -0
- package/dist/core/types/tradingMode.d.ts.map +1 -0
- package/dist/core/types/tradingMode.js +31 -0
- package/dist/core/types/tradingMode.js.map +1 -0
- package/dist/core/types/transaction.d.ts +45 -0
- package/dist/core/types/transaction.d.ts.map +1 -0
- package/dist/core/types/transaction.js +3 -0
- package/dist/core/types/transaction.js.map +1 -0
- package/dist/index.d.ts +34 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +47 -10
- package/dist/index.js.map +1 -1
- package/dist/services/borrow/BorrowService.d.ts +54 -0
- package/dist/services/borrow/BorrowService.d.ts.map +1 -0
- package/dist/services/borrow/BorrowService.js +129 -0
- package/dist/services/borrow/BorrowService.js.map +1 -0
- package/dist/services/borrow/borrowHelpers.d.ts +4 -0
- package/dist/services/borrow/borrowHelpers.d.ts.map +1 -0
- package/dist/services/borrow/borrowHelpers.js +13 -0
- package/dist/services/borrow/borrowHelpers.js.map +1 -0
- package/dist/services/borrow/borrowMath.d.ts +13 -0
- package/dist/services/borrow/borrowMath.d.ts.map +1 -0
- package/dist/services/borrow/borrowMath.js +129 -0
- package/dist/services/borrow/borrowMath.js.map +1 -0
- package/dist/services/borrow/index.d.ts +2 -0
- package/dist/services/borrow/index.d.ts.map +1 -0
- package/dist/services/borrow/index.js +18 -0
- package/dist/services/borrow/index.js.map +1 -0
- package/dist/services/borrow/internal/borrowApprovalService.d.ts +14 -0
- package/dist/services/borrow/internal/borrowApprovalService.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowApprovalService.js +53 -0
- package/dist/services/borrow/internal/borrowApprovalService.js.map +1 -0
- package/dist/services/borrow/internal/borrowContextStore.d.ts +11 -0
- package/dist/services/borrow/internal/borrowContextStore.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowContextStore.js +40 -0
- package/dist/services/borrow/internal/borrowContextStore.js.map +1 -0
- package/dist/services/borrow/internal/borrowErc20.d.ts +5 -0
- package/dist/services/borrow/internal/borrowErc20.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowErc20.js +43 -0
- package/dist/services/borrow/internal/borrowErc20.js.map +1 -0
- package/dist/services/borrow/internal/borrowHints.d.ts +7 -0
- package/dist/services/borrow/internal/borrowHints.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowHints.js +31 -0
- package/dist/services/borrow/internal/borrowHints.js.map +1 -0
- package/dist/services/borrow/internal/borrowPositionParser.d.ts +4 -0
- package/dist/services/borrow/internal/borrowPositionParser.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowPositionParser.js +87 -0
- package/dist/services/borrow/internal/borrowPositionParser.js.map +1 -0
- package/dist/services/borrow/internal/borrowReadService.d.ts +28 -0
- package/dist/services/borrow/internal/borrowReadService.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowReadService.js +218 -0
- package/dist/services/borrow/internal/borrowReadService.js.map +1 -0
- package/dist/services/borrow/internal/borrowRegistryReader.d.ts +5 -0
- package/dist/services/borrow/internal/borrowRegistryReader.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowRegistryReader.js +96 -0
- package/dist/services/borrow/internal/borrowRegistryReader.js.map +1 -0
- package/dist/services/borrow/internal/borrowTransactionService.d.ts +23 -0
- package/dist/services/borrow/internal/borrowTransactionService.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowTransactionService.js +276 -0
- package/dist/services/borrow/internal/borrowTransactionService.js.map +1 -0
- package/dist/services/borrow/internal/borrowTypes.d.ts +15 -0
- package/dist/services/borrow/internal/borrowTypes.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowTypes.js +3 -0
- package/dist/services/borrow/internal/borrowTypes.js.map +1 -0
- package/dist/services/borrow/internal/borrowValidation.d.ts +13 -0
- package/dist/services/borrow/internal/borrowValidation.d.ts.map +1 -0
- package/dist/services/borrow/internal/borrowValidation.js +96 -0
- package/dist/services/borrow/internal/borrowValidation.js.map +1 -0
- package/dist/services/index.d.ts +2 -0
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +2 -0
- package/dist/services/index.js.map +1 -1
- package/dist/services/liquidity/LiquidityService.d.ts +154 -0
- package/dist/services/liquidity/LiquidityService.d.ts.map +1 -0
- package/dist/services/liquidity/LiquidityService.js +184 -0
- package/dist/services/liquidity/LiquidityService.js.map +1 -0
- package/dist/services/liquidity/basicLiquidity.d.ts +11 -0
- package/dist/services/liquidity/basicLiquidity.d.ts.map +1 -0
- package/dist/services/liquidity/basicLiquidity.js +172 -0
- package/dist/services/liquidity/basicLiquidity.js.map +1 -0
- package/dist/services/liquidity/index.d.ts +2 -0
- package/dist/services/liquidity/index.d.ts.map +1 -0
- package/dist/services/liquidity/index.js +18 -0
- package/dist/services/liquidity/index.js.map +1 -0
- package/dist/services/liquidity/liquidityHelpers.d.ts +13 -0
- package/dist/services/liquidity/liquidityHelpers.d.ts.map +1 -0
- package/dist/services/liquidity/liquidityHelpers.js +74 -0
- package/dist/services/liquidity/liquidityHelpers.js.map +1 -0
- package/dist/services/liquidity/zapHelpers.d.ts +66 -0
- package/dist/services/liquidity/zapHelpers.d.ts.map +1 -0
- package/dist/services/liquidity/zapHelpers.js +133 -0
- package/dist/services/liquidity/zapHelpers.js.map +1 -0
- package/dist/services/liquidity/zapIn.d.ts +17 -0
- package/dist/services/liquidity/zapIn.d.ts.map +1 -0
- package/dist/services/liquidity/zapIn.js +125 -0
- package/dist/services/liquidity/zapIn.js.map +1 -0
- package/dist/services/liquidity/zapOut.d.ts +17 -0
- package/dist/services/liquidity/zapOut.d.ts.map +1 -0
- package/dist/services/liquidity/zapOut.js +242 -0
- package/dist/services/liquidity/zapOut.js.map +1 -0
- package/dist/services/pools/PoolService.d.ts +35 -10
- package/dist/services/pools/PoolService.d.ts.map +1 -1
- package/dist/services/pools/PoolService.js +61 -109
- package/dist/services/pools/PoolService.js.map +1 -1
- package/dist/services/pools/poolDetails.d.ts +11 -0
- package/dist/services/pools/poolDetails.d.ts.map +1 -0
- package/dist/services/pools/poolDetails.js +145 -0
- package/dist/services/pools/poolDetails.js.map +1 -0
- package/dist/services/pools/poolDiscovery.d.ts +12 -0
- package/dist/services/pools/poolDiscovery.d.ts.map +1 -0
- package/dist/services/pools/poolDiscovery.js +114 -0
- package/dist/services/pools/poolDiscovery.js.map +1 -0
- package/dist/services/quotes/QuoteService.d.ts +21 -12
- package/dist/services/quotes/QuoteService.d.ts.map +1 -1
- package/dist/services/quotes/QuoteService.js +41 -17
- package/dist/services/quotes/QuoteService.js.map +1 -1
- package/dist/services/routes/RouteService.d.ts +3 -3
- package/dist/services/routes/RouteService.d.ts.map +1 -1
- package/dist/services/routes/RouteService.js +3 -5
- package/dist/services/routes/RouteService.js.map +1 -1
- package/dist/services/swap/SwapService.d.ts +23 -19
- package/dist/services/swap/SwapService.d.ts.map +1 -1
- package/dist/services/swap/SwapService.js +36 -15
- package/dist/services/swap/SwapService.js.map +1 -1
- package/dist/services/tokens/supplyAdjustmentService.d.ts +0 -4
- package/dist/services/tokens/supplyAdjustmentService.d.ts.map +1 -1
- package/dist/services/tokens/supplyAdjustmentService.js +3 -8
- package/dist/services/tokens/supplyAdjustmentService.js.map +1 -1
- package/dist/services/tokens/tokenService.d.ts.map +1 -1
- package/dist/services/tokens/tokenService.js +2 -2
- package/dist/services/tokens/tokenService.js.map +1 -1
- package/dist/services/trading/TradingLimitsService.d.ts +38 -0
- package/dist/services/trading/TradingLimitsService.d.ts.map +1 -0
- package/dist/services/trading/TradingLimitsService.js +157 -0
- package/dist/services/trading/TradingLimitsService.js.map +1 -0
- package/dist/services/trading/TradingService.d.ts +110 -0
- package/dist/services/trading/TradingService.d.ts.map +1 -0
- package/dist/services/trading/TradingService.js +162 -0
- package/dist/services/trading/TradingService.js.map +1 -0
- package/dist/services/trading/index.d.ts +3 -0
- package/dist/services/trading/index.d.ts.map +1 -0
- package/dist/services/trading/index.js +19 -0
- package/dist/services/trading/index.js.map +1 -0
- package/dist/utils/costUtils.js +4 -4
- package/dist/utils/costUtils.js.map +1 -1
- package/dist/utils/deadline.d.ts +21 -0
- package/dist/utils/deadline.d.ts.map +1 -0
- package/dist/utils/deadline.js +26 -0
- package/dist/utils/deadline.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/pathEncoder.d.ts +8 -2
- package/dist/utils/pathEncoder.d.ts.map +1 -1
- package/dist/utils/pathEncoder.js +19 -3
- package/dist/utils/pathEncoder.js.map +1 -1
- package/dist/utils/rateFeed.d.ts +18 -0
- package/dist/utils/rateFeed.d.ts.map +1 -0
- package/dist/utils/rateFeed.js +27 -0
- package/dist/utils/rateFeed.js.map +1 -0
- package/dist/utils/routeUtils.d.ts +53 -53
- package/dist/utils/routeUtils.d.ts.map +1 -1
- package/dist/utils/routeUtils.js +41 -41
- package/dist/utils/routeUtils.js.map +1 -1
- package/dist/utils/routes.d.ts +2 -8
- package/dist/utils/routes.d.ts.map +1 -1
- package/dist/utils/routes.js +5 -46
- package/dist/utils/routes.js.map +1 -1
- package/dist/utils/tokens.d.ts +1 -77
- package/dist/utils/tokens.d.ts.map +1 -1
- package/dist/utils/tokens.js +10 -178
- package/dist/utils/tokens.js.map +1 -1
- package/dist/utils/tradingLimits.d.ts +41 -0
- package/dist/utils/tradingLimits.d.ts.map +1 -0
- package/dist/utils/tradingLimits.js +171 -0
- package/dist/utils/tradingLimits.js.map +1 -0
- package/dist/utils/validation.d.ts +19 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +34 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +3 -1
- package/dist/cache/routes.11142220.js +0 -1
- package/dist/cache/routes.42220.d.ts +0 -3
- package/dist/cache/routes.42220.d.ts.map +0 -1
- package/dist/cache/routes.42220.js +0 -112
- package/dist/cache/routes.42220.js.map +0 -1
- package/dist/cache/tokens.11142220.d.ts +0 -3
- package/dist/cache/tokens.11142220.d.ts.map +0 -1
- package/dist/cache/tokens.11142220.js +0 -129
- package/dist/cache/tokens.11142220.js.map +0 -1
- package/dist/cache/tokens.42220.d.ts +0 -3
- package/dist/cache/tokens.42220.d.ts.map +0 -1
- package/dist/cache/tokens.42220.js +0 -129
- package/dist/cache/tokens.42220.js.map +0 -1
|
@@ -1,5 +1,12 @@
|
|
|
1
|
-
import { Pool } from '../../core/types';
|
|
1
|
+
import { Pool, PoolDetails } from '../../core/types';
|
|
2
2
|
import { PublicClient } from 'viem';
|
|
3
|
+
/**
|
|
4
|
+
* Result of pool discovery including any warnings from failed factories
|
|
5
|
+
*/
|
|
6
|
+
export interface PoolDiscoveryResult {
|
|
7
|
+
pools: Pool[];
|
|
8
|
+
warnings: string[];
|
|
9
|
+
}
|
|
3
10
|
/**
|
|
4
11
|
* Service for discovering liquidity pools in the Mento protocol.
|
|
5
12
|
* Aggregates pools from multiple factory contracts (FPMM and VirtualPool).
|
|
@@ -8,13 +15,19 @@ export declare class PoolService {
|
|
|
8
15
|
private publicClient;
|
|
9
16
|
private chainId;
|
|
10
17
|
private poolsCache;
|
|
18
|
+
private discoveryWarnings;
|
|
11
19
|
constructor(publicClient: PublicClient, chainId: number);
|
|
20
|
+
/**
|
|
21
|
+
* Returns any warnings from the last pool discovery operation.
|
|
22
|
+
* Useful for debugging when some factories fail but others succeed.
|
|
23
|
+
*/
|
|
24
|
+
getDiscoveryWarnings(): string[];
|
|
12
25
|
/**
|
|
13
26
|
* Fetches all pools available in the protocol from both FPMM and Virtual pool factories
|
|
14
27
|
* Results are cached in memory for the service instance lifetime
|
|
15
28
|
*
|
|
16
29
|
* @returns Array of all pools available in the protocol
|
|
17
|
-
* @throws {Error} If
|
|
30
|
+
* @throws {Error} If no pools can be discovered from any factory
|
|
18
31
|
*
|
|
19
32
|
* @example
|
|
20
33
|
* ```typescript
|
|
@@ -24,14 +37,26 @@ export declare class PoolService {
|
|
|
24
37
|
*/
|
|
25
38
|
getPools(): Promise<Pool[]>;
|
|
26
39
|
/**
|
|
27
|
-
* Fetches
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
*
|
|
32
|
-
*
|
|
33
|
-
*
|
|
40
|
+
* Fetches enriched on-chain details for a specific pool by address.
|
|
41
|
+
* Resolves the pool type from the discovery cache, then fetches
|
|
42
|
+
* pool-type-specific data (pricing, fees, rebalancing for FPMM; reserves and spread for Virtual).
|
|
43
|
+
*
|
|
44
|
+
* @param poolAddr - The deployed pool contract address
|
|
45
|
+
* @returns Enriched pool details (FPMMPoolDetails or VirtualPoolDetails)
|
|
46
|
+
* @throws {Error} If the pool address is not found in any known factory
|
|
47
|
+
* @throws {Error} If on-chain calls fail
|
|
48
|
+
*
|
|
49
|
+
* @example
|
|
50
|
+
* ```typescript
|
|
51
|
+
* const details = await poolService.getPoolDetails('0x...')
|
|
52
|
+
* if (details.poolType === 'FPMM') {
|
|
53
|
+
* console.log(details.pricing.oraclePrice)
|
|
54
|
+
* console.log(details.rebalancing.inBand)
|
|
55
|
+
* } else {
|
|
56
|
+
* console.log(details.spreadPercent)
|
|
57
|
+
* }
|
|
58
|
+
* ```
|
|
34
59
|
*/
|
|
35
|
-
|
|
60
|
+
getPoolDetails(poolAddr: string): Promise<PoolDetails>;
|
|
36
61
|
}
|
|
37
62
|
//# sourceMappingURL=PoolService.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PoolService.d.ts","sourceRoot":"","sources":["../../../src/services/pools/PoolService.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PoolService.d.ts","sourceRoot":"","sources":["../../../src/services/pools/PoolService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAY,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAInC;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,IAAI,EAAE,CAAA;IACb,QAAQ,EAAE,MAAM,EAAE,CAAA;CACnB;AAED;;;GAGG;AACH,qBAAa,WAAW;IAIV,OAAO,CAAC,YAAY;IAAgB,OAAO,CAAC,OAAO;IAH/D,OAAO,CAAC,UAAU,CAAsB;IACxC,OAAO,CAAC,iBAAiB,CAAe;gBAEpB,YAAY,EAAE,YAAY,EAAU,OAAO,EAAE,MAAM;IAEvE;;;OAGG;IACH,oBAAoB,IAAI,MAAM,EAAE;IAIhC;;;;;;;;;;;;OAYG;IACG,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IA2CjC;;;;;;;;;;;;;;;;;;;;OAoBG;IACG,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;CAc7D"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PoolService = void 0;
|
|
4
|
-
const constants_1 = require("../../core/constants");
|
|
5
4
|
const types_1 = require("../../core/types");
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
// TODO: Update to enrich pools with more data as needed. Use optional flag to include more data.
|
|
5
|
+
const poolDiscovery_1 = require("./poolDiscovery");
|
|
6
|
+
const poolDetails_1 = require("./poolDetails");
|
|
9
7
|
/**
|
|
10
8
|
* Service for discovering liquidity pools in the Mento protocol.
|
|
11
9
|
* Aggregates pools from multiple factory contracts (FPMM and VirtualPool).
|
|
@@ -15,13 +13,21 @@ class PoolService {
|
|
|
15
13
|
this.publicClient = publicClient;
|
|
16
14
|
this.chainId = chainId;
|
|
17
15
|
this.poolsCache = null;
|
|
16
|
+
this.discoveryWarnings = [];
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Returns any warnings from the last pool discovery operation.
|
|
20
|
+
* Useful for debugging when some factories fail but others succeed.
|
|
21
|
+
*/
|
|
22
|
+
getDiscoveryWarnings() {
|
|
23
|
+
return [...this.discoveryWarnings];
|
|
18
24
|
}
|
|
19
25
|
/**
|
|
20
26
|
* Fetches all pools available in the protocol from both FPMM and Virtual pool factories
|
|
21
27
|
* Results are cached in memory for the service instance lifetime
|
|
22
28
|
*
|
|
23
29
|
* @returns Array of all pools available in the protocol
|
|
24
|
-
* @throws {Error} If
|
|
30
|
+
* @throws {Error} If no pools can be discovered from any factory
|
|
25
31
|
*
|
|
26
32
|
* @example
|
|
27
33
|
* ```typescript
|
|
@@ -37,120 +43,66 @@ class PoolService {
|
|
|
37
43
|
// for dynamic factory discovery. For now we will use
|
|
38
44
|
// the hardcoded factory addresses for the chain for v1.
|
|
39
45
|
const pools = [];
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
*/
|
|
50
|
-
async fetchFPMMPools() {
|
|
51
|
-
const fpmmFactoryAddress = (0, constants_1.getContractAddress)(this.chainId, 'FPMMFactory');
|
|
52
|
-
if (!fpmmFactoryAddress) {
|
|
53
|
-
console.warn('FPMM Factory address not found for this chain');
|
|
54
|
-
return [];
|
|
46
|
+
const warnings = [];
|
|
47
|
+
try {
|
|
48
|
+
const fpmmPools = await (0, poolDiscovery_1.fetchFPMMPools)(this.publicClient, this.chainId);
|
|
49
|
+
pools.push(...fpmmPools);
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
const message = `Failed to fetch FPMM pools: ${error instanceof Error ? error.message : String(error)}`;
|
|
53
|
+
console.warn(`[PoolService] ${message}`);
|
|
54
|
+
warnings.push(message);
|
|
55
55
|
}
|
|
56
56
|
try {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
address: fpmmFactoryAddress,
|
|
60
|
-
abi: abis_1.FPMM_FACTORY_ABI,
|
|
61
|
-
functionName: 'deployedFPMMAddresses',
|
|
62
|
-
}));
|
|
63
|
-
if (poolAddresses.length === 0) {
|
|
64
|
-
return [];
|
|
65
|
-
}
|
|
66
|
-
const poolDataPromises = poolAddresses.map(async (poolAddress) => {
|
|
67
|
-
const [token0, token1] = await Promise.all([
|
|
68
|
-
this.publicClient.readContract({
|
|
69
|
-
address: poolAddress,
|
|
70
|
-
abi: abis_1.FPMM_ABI,
|
|
71
|
-
functionName: 'token0',
|
|
72
|
-
}),
|
|
73
|
-
this.publicClient.readContract({
|
|
74
|
-
address: poolAddress,
|
|
75
|
-
abi: abis_1.FPMM_ABI,
|
|
76
|
-
functionName: 'token1',
|
|
77
|
-
}),
|
|
78
|
-
]);
|
|
79
|
-
return {
|
|
80
|
-
factoryAddr: fpmmFactoryAddress,
|
|
81
|
-
poolAddr: poolAddress,
|
|
82
|
-
token0: token0,
|
|
83
|
-
token1: token1,
|
|
84
|
-
poolType: types_1.PoolType.FPMM,
|
|
85
|
-
};
|
|
86
|
-
});
|
|
87
|
-
return await Promise.all(poolDataPromises);
|
|
57
|
+
const virtualPools = await (0, poolDiscovery_1.fetchVirtualPools)(this.publicClient, this.chainId);
|
|
58
|
+
pools.push(...virtualPools);
|
|
88
59
|
}
|
|
89
60
|
catch (error) {
|
|
90
|
-
|
|
91
|
-
|
|
61
|
+
const message = `Failed to fetch Virtual pools: ${error instanceof Error ? error.message : String(error)}`;
|
|
62
|
+
console.warn(`[PoolService] ${message}`);
|
|
63
|
+
warnings.push(message);
|
|
92
64
|
}
|
|
65
|
+
this.discoveryWarnings = warnings;
|
|
66
|
+
// Only throw if NO pools were discovered from any factory
|
|
67
|
+
if (pools.length === 0) {
|
|
68
|
+
throw new Error('Failed to discover any pools from any factory. ' +
|
|
69
|
+
'All pool factory queries failed. Check network connectivity and RPC endpoint.');
|
|
70
|
+
}
|
|
71
|
+
this.poolsCache = pools;
|
|
72
|
+
return pools;
|
|
93
73
|
}
|
|
94
74
|
/**
|
|
95
|
-
* Fetches
|
|
96
|
-
*
|
|
97
|
-
*
|
|
75
|
+
* Fetches enriched on-chain details for a specific pool by address.
|
|
76
|
+
* Resolves the pool type from the discovery cache, then fetches
|
|
77
|
+
* pool-type-specific data (pricing, fees, rebalancing for FPMM; reserves and spread for Virtual).
|
|
78
|
+
*
|
|
79
|
+
* @param poolAddr - The deployed pool contract address
|
|
80
|
+
* @returns Enriched pool details (FPMMPoolDetails or VirtualPoolDetails)
|
|
81
|
+
* @throws {Error} If the pool address is not found in any known factory
|
|
82
|
+
* @throws {Error} If on-chain calls fail
|
|
83
|
+
*
|
|
84
|
+
* @example
|
|
85
|
+
* ```typescript
|
|
86
|
+
* const details = await poolService.getPoolDetails('0x...')
|
|
87
|
+
* if (details.poolType === 'FPMM') {
|
|
88
|
+
* console.log(details.pricing.oraclePrice)
|
|
89
|
+
* console.log(details.rebalancing.inBand)
|
|
90
|
+
* } else {
|
|
91
|
+
* console.log(details.spreadPercent)
|
|
92
|
+
* }
|
|
93
|
+
* ```
|
|
98
94
|
*/
|
|
99
|
-
async
|
|
100
|
-
const
|
|
101
|
-
const
|
|
102
|
-
if (!
|
|
103
|
-
|
|
104
|
-
return [];
|
|
95
|
+
async getPoolDetails(poolAddr) {
|
|
96
|
+
const pools = await this.getPools();
|
|
97
|
+
const pool = pools.find((p) => p.poolAddr.toLowerCase() === poolAddr.toLowerCase());
|
|
98
|
+
if (!pool) {
|
|
99
|
+
throw new Error(`Pool not found: ${poolAddr}. ` + 'Ensure the address is a valid pool discovered by getPools().');
|
|
105
100
|
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
// we can simplify this by using VirtualPoolFactory.getAllPools() returns(address[])
|
|
109
|
-
// Get all exchanges from BiPoolManager
|
|
110
|
-
const exchangesData = (await this.publicClient.readContract({
|
|
111
|
-
address: biPoolManagerAddress,
|
|
112
|
-
abi: abis_1.BIPOOL_MANAGER_ABI,
|
|
113
|
-
functionName: 'getExchanges',
|
|
114
|
-
}));
|
|
115
|
-
if (exchangesData.length === 0) {
|
|
116
|
-
return [];
|
|
117
|
-
}
|
|
118
|
-
// For each exchange, check if a virtual pool exists, and if so, return the pool address.
|
|
119
|
-
const poolPromises = exchangesData.map(async (exchange) => {
|
|
120
|
-
if (exchange.assets.length !== 2) {
|
|
121
|
-
console.warn(`Skipping invalid exchange ${exchange.exchangeId}: expected 2 assets`);
|
|
122
|
-
return null;
|
|
123
|
-
}
|
|
124
|
-
const [token0, token1] = (0, sortUtils_1.sortTokenAddresses)(exchange.assets[0], exchange.assets[1]);
|
|
125
|
-
const poolAddress = (await this.publicClient.readContract({
|
|
126
|
-
address: virtualPoolFactoryAddress,
|
|
127
|
-
abi: abis_1.VIRTUAL_POOL_FACTORY_ABI,
|
|
128
|
-
functionName: 'getOrPrecomputeProxyAddress',
|
|
129
|
-
args: [token0, token1],
|
|
130
|
-
}));
|
|
131
|
-
const isDeployed = (await this.publicClient.readContract({
|
|
132
|
-
address: virtualPoolFactoryAddress,
|
|
133
|
-
abi: abis_1.VIRTUAL_POOL_FACTORY_ABI,
|
|
134
|
-
functionName: 'isPool',
|
|
135
|
-
args: [poolAddress],
|
|
136
|
-
}));
|
|
137
|
-
if (!isDeployed) {
|
|
138
|
-
return null;
|
|
139
|
-
}
|
|
140
|
-
return {
|
|
141
|
-
factoryAddr: virtualPoolFactoryAddress,
|
|
142
|
-
poolAddr: poolAddress,
|
|
143
|
-
token0: token0,
|
|
144
|
-
token1: token1,
|
|
145
|
-
poolType: types_1.PoolType.Virtual,
|
|
146
|
-
};
|
|
147
|
-
});
|
|
148
|
-
const results = await Promise.all(poolPromises);
|
|
149
|
-
return results.filter((pool) => pool !== null);
|
|
101
|
+
if (pool.poolType === types_1.PoolType.FPMM) {
|
|
102
|
+
return (0, poolDetails_1.fetchFPMMPoolDetails)(this.publicClient, this.chainId, pool);
|
|
150
103
|
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
throw new Error(`Failed to fetch Virtual pools: ${error.message}`);
|
|
104
|
+
else {
|
|
105
|
+
return (0, poolDetails_1.fetchVirtualPoolDetails)(this.publicClient, pool);
|
|
154
106
|
}
|
|
155
107
|
}
|
|
156
108
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PoolService.js","sourceRoot":"","sources":["../../../src/services/pools/PoolService.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"PoolService.js","sourceRoot":"","sources":["../../../src/services/pools/PoolService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Pool, FPMMPoolDetails, VirtualPoolDetails } from '../../core/types';
|
|
2
|
+
import { PublicClient } from 'viem';
|
|
3
|
+
/**
|
|
4
|
+
* Fetches enriched details for an FPMM pool
|
|
5
|
+
*/
|
|
6
|
+
export declare function fetchFPMMPoolDetails(publicClient: PublicClient, chainId: number, pool: Pool): Promise<FPMMPoolDetails>;
|
|
7
|
+
/**
|
|
8
|
+
* Fetches enriched details for a Virtual pool
|
|
9
|
+
*/
|
|
10
|
+
export declare function fetchVirtualPoolDetails(publicClient: PublicClient, pool: Pool): Promise<VirtualPoolDetails>;
|
|
11
|
+
//# sourceMappingURL=poolDetails.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"poolDetails.d.ts","sourceRoot":"","sources":["../../../src/services/pools/poolDetails.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,eAAe,EAAe,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAEzF,OAAO,EAAE,YAAY,EAAW,MAAM,MAAM,CAAA;AAE5C;;GAEG;AACH,wBAAsB,oBAAoB,CACxC,YAAY,EAAE,YAAY,EAC1B,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,IAAI,GACT,OAAO,CAAC,eAAe,CAAC,CAmH1B;AAED;;GAEG;AACH,wBAAsB,uBAAuB,CAAC,YAAY,EAAE,YAAY,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,kBAAkB,CAAC,CA4BjH"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fetchFPMMPoolDetails = fetchFPMMPoolDetails;
|
|
4
|
+
exports.fetchVirtualPoolDetails = fetchVirtualPoolDetails;
|
|
5
|
+
const constants_1 = require("../../core/constants");
|
|
6
|
+
const abis_1 = require("../../core/abis");
|
|
7
|
+
/**
|
|
8
|
+
* Fetches enriched details for an FPMM pool
|
|
9
|
+
*/
|
|
10
|
+
async function fetchFPMMPoolDetails(publicClient, chainId, pool) {
|
|
11
|
+
const address = pool.poolAddr;
|
|
12
|
+
try {
|
|
13
|
+
// Known liquidity strategy addresses for this chain
|
|
14
|
+
const knownStrategies = getKnownLiquidityStrategies(chainId);
|
|
15
|
+
// Fetch core data
|
|
16
|
+
const [reservesResult, decimals0, decimals1, lpFee, protocolFee, rebalanceIncentive, rebalanceThresholdAbove, rebalanceThresholdBelow, ...strategyResults] = await Promise.all([
|
|
17
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'getReserves' }),
|
|
18
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'decimals0' }),
|
|
19
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'decimals1' }),
|
|
20
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'lpFee' }),
|
|
21
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'protocolFee' }),
|
|
22
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'rebalanceIncentive' }),
|
|
23
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'rebalanceThresholdAbove' }),
|
|
24
|
+
publicClient.readContract({ address, abi: abis_1.FPMM_ABI, functionName: 'rebalanceThresholdBelow' }),
|
|
25
|
+
...knownStrategies.map((strategyAddr) => publicClient.readContract({
|
|
26
|
+
address,
|
|
27
|
+
abi: abis_1.FPMM_ABI,
|
|
28
|
+
functionName: 'liquidityStrategy',
|
|
29
|
+
args: [strategyAddr],
|
|
30
|
+
})),
|
|
31
|
+
]);
|
|
32
|
+
const [reserve0, reserve1, blockTimestampLast] = reservesResult;
|
|
33
|
+
const lpFeeBps = lpFee;
|
|
34
|
+
const protocolFeeBps = protocolFee;
|
|
35
|
+
const rebalanceIncentiveBps = rebalanceIncentive;
|
|
36
|
+
const thresholdAboveBps = rebalanceThresholdAbove;
|
|
37
|
+
const thresholdBelowBps = rebalanceThresholdBelow;
|
|
38
|
+
// Find the active liquidity strategy (first match wins)
|
|
39
|
+
const activeIndex = strategyResults.findIndex((result) => result === true);
|
|
40
|
+
const liquidityStrategy = activeIndex >= 0 ? knownStrategies[activeIndex] : null;
|
|
41
|
+
// Fetch pricing separately — graceful degradation when FX market is closed
|
|
42
|
+
let pricing = null;
|
|
43
|
+
let inBand = null;
|
|
44
|
+
try {
|
|
45
|
+
const rebalancingStateResult = await publicClient.readContract({
|
|
46
|
+
address,
|
|
47
|
+
abi: abis_1.FPMM_ABI,
|
|
48
|
+
functionName: 'getRebalancingState',
|
|
49
|
+
});
|
|
50
|
+
const [oraclePriceNum, oraclePriceDen, reservePriceNum, reservePriceDen, reservePriceAboveOraclePrice, rebalanceThreshold, priceDifference,] = rebalancingStateResult;
|
|
51
|
+
pricing = {
|
|
52
|
+
oraclePriceNum,
|
|
53
|
+
oraclePriceDen,
|
|
54
|
+
oraclePrice: Number(oraclePriceNum) / Number(oraclePriceDen),
|
|
55
|
+
reservePriceNum,
|
|
56
|
+
reservePriceDen,
|
|
57
|
+
reservePrice: Number(reservePriceNum) / Number(reservePriceDen),
|
|
58
|
+
priceDifferenceBps: priceDifference,
|
|
59
|
+
priceDifferencePercent: Number(priceDifference) / 100,
|
|
60
|
+
reservePriceAboveOraclePrice,
|
|
61
|
+
};
|
|
62
|
+
inBand = priceDifference < BigInt(rebalanceThreshold);
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
// getRebalancingState() failed (likely FXMarketClosed) — pricing stays null
|
|
66
|
+
}
|
|
67
|
+
return {
|
|
68
|
+
...pool,
|
|
69
|
+
poolType: 'FPMM',
|
|
70
|
+
scalingFactor0: decimals0,
|
|
71
|
+
scalingFactor1: decimals1,
|
|
72
|
+
reserve0,
|
|
73
|
+
reserve1,
|
|
74
|
+
blockTimestampLast,
|
|
75
|
+
pricing,
|
|
76
|
+
fees: {
|
|
77
|
+
lpFeeBps,
|
|
78
|
+
lpFeePercent: Number(lpFeeBps) / 100,
|
|
79
|
+
protocolFeeBps,
|
|
80
|
+
protocolFeePercent: Number(protocolFeeBps) / 100,
|
|
81
|
+
totalFeePercent: (Number(lpFeeBps) + Number(protocolFeeBps)) / 100,
|
|
82
|
+
},
|
|
83
|
+
rebalancing: {
|
|
84
|
+
rebalanceIncentiveBps,
|
|
85
|
+
rebalanceIncentivePercent: Number(rebalanceIncentiveBps) / 100,
|
|
86
|
+
rebalanceThresholdAboveBps: thresholdAboveBps,
|
|
87
|
+
rebalanceThresholdAbovePercent: Number(thresholdAboveBps) / 100,
|
|
88
|
+
rebalanceThresholdBelowBps: thresholdBelowBps,
|
|
89
|
+
rebalanceThresholdBelowPercent: Number(thresholdBelowBps) / 100,
|
|
90
|
+
inBand,
|
|
91
|
+
liquidityStrategy,
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
throw new Error(`Failed to fetch FPMM pool details for ${pool.poolAddr}: ${error.message}`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Fetches enriched details for a Virtual pool
|
|
101
|
+
*/
|
|
102
|
+
async function fetchVirtualPoolDetails(publicClient, pool) {
|
|
103
|
+
const address = pool.poolAddr;
|
|
104
|
+
try {
|
|
105
|
+
const [reservesResult, protocolFee, metadataResult] = await Promise.all([
|
|
106
|
+
publicClient.readContract({ address, abi: abis_1.VIRTUAL_POOL_ABI, functionName: 'getReserves' }),
|
|
107
|
+
publicClient.readContract({ address, abi: abis_1.VIRTUAL_POOL_ABI, functionName: 'protocolFee' }),
|
|
108
|
+
publicClient.readContract({ address, abi: abis_1.VIRTUAL_POOL_ABI, functionName: 'metadata' }),
|
|
109
|
+
]);
|
|
110
|
+
const [reserve0, reserve1, blockTimestampLast] = reservesResult;
|
|
111
|
+
const [dec0, dec1] = metadataResult;
|
|
112
|
+
const spreadBps = protocolFee;
|
|
113
|
+
return {
|
|
114
|
+
...pool,
|
|
115
|
+
poolType: 'Virtual',
|
|
116
|
+
scalingFactor0: dec0,
|
|
117
|
+
scalingFactor1: dec1,
|
|
118
|
+
reserve0,
|
|
119
|
+
reserve1,
|
|
120
|
+
blockTimestampLast,
|
|
121
|
+
spreadBps,
|
|
122
|
+
spreadPercent: Number(spreadBps) / 100,
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
catch (error) {
|
|
126
|
+
throw new Error(`Failed to fetch Virtual pool details for ${pool.poolAddr}: ${error.message}`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Returns the known liquidity strategy addresses for the given chain.
|
|
131
|
+
*/
|
|
132
|
+
function getKnownLiquidityStrategies(chainId) {
|
|
133
|
+
const strategies = [];
|
|
134
|
+
const chainAddresses = constants_1.addresses[chainId];
|
|
135
|
+
if (!chainAddresses)
|
|
136
|
+
return strategies;
|
|
137
|
+
if (chainAddresses.ReserveLiquidityStrategy) {
|
|
138
|
+
strategies.push(chainAddresses.ReserveLiquidityStrategy);
|
|
139
|
+
}
|
|
140
|
+
if (chainAddresses.CDPLiquidityStrategy) {
|
|
141
|
+
strategies.push(chainAddresses.CDPLiquidityStrategy);
|
|
142
|
+
}
|
|
143
|
+
return strategies;
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=poolDetails.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"poolDetails.js","sourceRoot":"","sources":["../../../src/services/pools/poolDetails.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Pool } from '../../core/types';
|
|
2
|
+
import { PublicClient } from 'viem';
|
|
3
|
+
/**
|
|
4
|
+
* Fetches all FPMM pools from the FPMM Factory
|
|
5
|
+
*/
|
|
6
|
+
export declare function fetchFPMMPools(publicClient: PublicClient, chainId: number): Promise<Pool[]>;
|
|
7
|
+
/**
|
|
8
|
+
* Fetches all active Virtual pools from the VirtualPoolFactory,
|
|
9
|
+
* then resolves token pairs and exchange IDs from each pool and BiPoolManager.
|
|
10
|
+
*/
|
|
11
|
+
export declare function fetchVirtualPools(publicClient: PublicClient, chainId: number): Promise<Pool[]>;
|
|
12
|
+
//# sourceMappingURL=poolDiscovery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"poolDiscovery.d.ts","sourceRoot":"","sources":["../../../src/services/pools/poolDiscovery.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAY,MAAM,kBAAkB,CAAA;AAQjD,OAAO,EAAE,YAAY,EAAW,MAAM,MAAM,CAAA;AAG5C;;GAEG;AACH,wBAAsB,cAAc,CAAC,YAAY,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,CA8CjG;AAED;;;GAGG;AACH,wBAAsB,iBAAiB,CAAC,YAAY,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,CA8DpG"}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fetchFPMMPools = fetchFPMMPools;
|
|
4
|
+
exports.fetchVirtualPools = fetchVirtualPools;
|
|
5
|
+
const constants_1 = require("../../core/constants");
|
|
6
|
+
const types_1 = require("../../core/types");
|
|
7
|
+
const abis_1 = require("../../core/abis");
|
|
8
|
+
const sortUtils_1 = require("../../utils/sortUtils");
|
|
9
|
+
/**
|
|
10
|
+
* Fetches all FPMM pools from the FPMM Factory
|
|
11
|
+
*/
|
|
12
|
+
async function fetchFPMMPools(publicClient, chainId) {
|
|
13
|
+
const fpmmFactoryAddress = (0, constants_1.getContractAddress)(chainId, 'FPMMFactory');
|
|
14
|
+
if (!fpmmFactoryAddress) {
|
|
15
|
+
return [];
|
|
16
|
+
}
|
|
17
|
+
try {
|
|
18
|
+
// Get all deployed FPMM pool addresses
|
|
19
|
+
const poolAddresses = (await publicClient.readContract({
|
|
20
|
+
address: fpmmFactoryAddress,
|
|
21
|
+
abi: abis_1.FPMM_FACTORY_ABI,
|
|
22
|
+
functionName: 'deployedFPMMAddresses',
|
|
23
|
+
}));
|
|
24
|
+
if (poolAddresses.length === 0) {
|
|
25
|
+
return [];
|
|
26
|
+
}
|
|
27
|
+
const poolDataPromises = poolAddresses.map(async (poolAddress) => {
|
|
28
|
+
const [token0, token1] = await Promise.all([
|
|
29
|
+
publicClient.readContract({
|
|
30
|
+
address: poolAddress,
|
|
31
|
+
abi: abis_1.FPMM_ABI,
|
|
32
|
+
functionName: 'token0',
|
|
33
|
+
}),
|
|
34
|
+
publicClient.readContract({
|
|
35
|
+
address: poolAddress,
|
|
36
|
+
abi: abis_1.FPMM_ABI,
|
|
37
|
+
functionName: 'token1',
|
|
38
|
+
}),
|
|
39
|
+
]);
|
|
40
|
+
return {
|
|
41
|
+
factoryAddr: fpmmFactoryAddress,
|
|
42
|
+
poolAddr: poolAddress,
|
|
43
|
+
token0: token0,
|
|
44
|
+
token1: token1,
|
|
45
|
+
poolType: types_1.PoolType.FPMM,
|
|
46
|
+
};
|
|
47
|
+
});
|
|
48
|
+
return await Promise.all(poolDataPromises);
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
throw new Error(`Failed to fetch FPMM pools: ${error.message}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Fetches all active Virtual pools from the VirtualPoolFactory,
|
|
56
|
+
* then resolves token pairs and exchange IDs from each pool and BiPoolManager.
|
|
57
|
+
*/
|
|
58
|
+
async function fetchVirtualPools(publicClient, chainId) {
|
|
59
|
+
const virtualPoolFactoryAddress = (0, constants_1.getContractAddress)(chainId, 'VirtualPoolFactory');
|
|
60
|
+
const biPoolManagerAddress = (0, constants_1.getContractAddress)(chainId, 'BiPoolManager');
|
|
61
|
+
if (!virtualPoolFactoryAddress || !biPoolManagerAddress) {
|
|
62
|
+
return [];
|
|
63
|
+
}
|
|
64
|
+
try {
|
|
65
|
+
// Fetch active pool addresses and all exchanges in parallel
|
|
66
|
+
const [poolAddresses, exchangesData] = await Promise.all([
|
|
67
|
+
publicClient.readContract({
|
|
68
|
+
address: virtualPoolFactoryAddress,
|
|
69
|
+
abi: abis_1.VIRTUAL_POOL_FACTORY_ABI,
|
|
70
|
+
functionName: 'getAllPools',
|
|
71
|
+
}),
|
|
72
|
+
publicClient.readContract({
|
|
73
|
+
address: biPoolManagerAddress,
|
|
74
|
+
abi: abis_1.BIPOOL_MANAGER_ABI,
|
|
75
|
+
functionName: 'getExchanges',
|
|
76
|
+
}),
|
|
77
|
+
]);
|
|
78
|
+
if (poolAddresses.length === 0) {
|
|
79
|
+
return [];
|
|
80
|
+
}
|
|
81
|
+
// Build a lookup from sorted token pair to exchangeId
|
|
82
|
+
const tokenPairToExchangeId = new Map();
|
|
83
|
+
for (const exchange of exchangesData) {
|
|
84
|
+
if (exchange.assets.length === 2) {
|
|
85
|
+
const [t0, t1] = (0, sortUtils_1.sortTokenAddresses)(exchange.assets[0], exchange.assets[1]);
|
|
86
|
+
tokenPairToExchangeId.set(`${t0}:${t1}`, exchange.exchangeId);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
// For each pool, read its token pair and match to an exchangeId
|
|
90
|
+
const poolPromises = poolAddresses.map(async (poolAddress) => {
|
|
91
|
+
const [token0, token1] = (await publicClient.readContract({
|
|
92
|
+
address: poolAddress,
|
|
93
|
+
abi: abis_1.VIRTUAL_POOL_ABI,
|
|
94
|
+
functionName: 'tokens',
|
|
95
|
+
}));
|
|
96
|
+
const [sorted0, sorted1] = (0, sortUtils_1.sortTokenAddresses)(token0, token1);
|
|
97
|
+
const exchangeId = tokenPairToExchangeId.get(`${sorted0}:${sorted1}`);
|
|
98
|
+
const pool = {
|
|
99
|
+
factoryAddr: virtualPoolFactoryAddress,
|
|
100
|
+
poolAddr: poolAddress,
|
|
101
|
+
token0: sorted0,
|
|
102
|
+
token1: sorted1,
|
|
103
|
+
poolType: types_1.PoolType.Virtual,
|
|
104
|
+
exchangeId,
|
|
105
|
+
};
|
|
106
|
+
return pool;
|
|
107
|
+
});
|
|
108
|
+
return await Promise.all(poolPromises);
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
throw new Error(`Failed to fetch Virtual pools: ${error.message}`);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
//# sourceMappingURL=poolDiscovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"poolDiscovery.js","sourceRoot":"","sources":["../../../src/services/pools/poolDiscovery.ts"],"names":[],"mappings":"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"}
|