@mento-protocol/mento-sdk 3.2.6 → 3.2.7
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/package.json +7 -1
- package/dist/cache/routes.d.ts +0 -13
- package/dist/cache/routes.js +0 -14649
- package/dist/cache/tokens.d.ts +0 -68
- package/dist/cache/tokens.js +0 -488
- package/dist/core/abis/activePool.d.ts +0 -2
- package/dist/core/abis/activePool.js +0 -14
- package/dist/core/abis/addressesRegistry.d.ts +0 -2
- package/dist/core/abis/addressesRegistry.js +0 -26
- package/dist/core/abis/bipoolmanager.d.ts +0 -34
- package/dist/core/abis/bipoolmanager.js +0 -72
- package/dist/core/abis/borrowerOperations.d.ts +0 -9
- package/dist/core/abis/borrowerOperations.js +0 -89
- package/dist/core/abis/breakerbox.d.ts +0 -13
- package/dist/core/abis/breakerbox.js +0 -8
- package/dist/core/abis/broker.d.ts +0 -2
- package/dist/core/abis/broker.js +0 -9
- package/dist/core/abis/erc20.d.ts +0 -9
- package/dist/core/abis/erc20.js +0 -21
- package/dist/core/abis/fpmm.d.ts +0 -270
- package/dist/core/abis/fpmm.js +0 -49
- package/dist/core/abis/fpmmFactory.d.ts +0 -85
- package/dist/core/abis/fpmmFactory.js +0 -26
- package/dist/core/abis/hintHelpers.d.ts +0 -2
- package/dist/core/abis/hintHelpers.js +0 -14
- package/dist/core/abis/index.d.ts +0 -22
- package/dist/core/abis/index.js +0 -38
- package/dist/core/abis/liquidityStrategy.d.ts +0 -132
- package/dist/core/abis/liquidityStrategy.js +0 -10
- package/dist/core/abis/multiTroveGetter.d.ts +0 -8
- package/dist/core/abis/multiTroveGetter.js +0 -15
- package/dist/core/abis/priceFeed.d.ts +0 -7
- package/dist/core/abis/priceFeed.js +0 -16
- package/dist/core/abis/pricingmodule.d.ts +0 -2
- package/dist/core/abis/pricingmodule.js +0 -6
- package/dist/core/abis/reserve.d.ts +0 -3
- package/dist/core/abis/reserve.js +0 -18
- package/dist/core/abis/router.d.ts +0 -521
- package/dist/core/abis/router.js +0 -45
- package/dist/core/abis/sortedTroves.d.ts +0 -2
- package/dist/core/abis/sortedTroves.js +0 -15
- package/dist/core/abis/systemParams.d.ts +0 -2
- package/dist/core/abis/systemParams.js +0 -14
- package/dist/core/abis/troveManager.d.ts +0 -2
- package/dist/core/abis/troveManager.js +0 -27
- package/dist/core/abis/troveNFT.d.ts +0 -2
- package/dist/core/abis/troveNFT.js +0 -9
- package/dist/core/abis/virtualPool.d.ts +0 -50
- package/dist/core/abis/virtualPool.js +0 -11
- package/dist/core/abis/virtualPoolFactory.d.ts +0 -59
- package/dist/core/abis/virtualPoolFactory.js +0 -17
- package/dist/core/constants/addresses.d.ts +0 -18
- package/dist/core/constants/addresses.js +0 -113
- package/dist/core/constants/borrowConstants.d.ts +0 -10
- package/dist/core/constants/borrowConstants.js +0 -16
- package/dist/core/constants/borrowRegistries.d.ts +0 -7
- package/dist/core/constants/borrowRegistries.js +0 -34
- package/dist/core/constants/chainId.d.ts +0 -7
- package/dist/core/constants/chainId.js +0 -11
- package/dist/core/constants/contractNames.d.ts +0 -21
- package/dist/core/constants/contractNames.js +0 -24
- package/dist/core/constants/index.d.ts +0 -6
- package/dist/core/constants/index.js +0 -22
- package/dist/core/errors/base.d.ts +0 -8
- package/dist/core/errors/base.js +0 -17
- package/dist/core/errors/index.d.ts +0 -4
- package/dist/core/errors/index.js +0 -20
- package/dist/core/errors/oracle.d.ts +0 -9
- package/dist/core/errors/oracle.js +0 -15
- package/dist/core/errors/router.d.ts +0 -14
- package/dist/core/errors/router.js +0 -24
- package/dist/core/types/borrow.d.ts +0 -87
- package/dist/core/types/borrow.js +0 -3
- package/dist/core/types/contractAddresses.d.ts +0 -42
- package/dist/core/types/contractAddresses.js +0 -3
- package/dist/core/types/index.d.ts +0 -10
- package/dist/core/types/index.js +0 -26
- package/dist/core/types/liquidity.d.ts +0 -194
- package/dist/core/types/liquidity.js +0 -3
- package/dist/core/types/pool.d.ts +0 -208
- package/dist/core/types/pool.js +0 -14
- package/dist/core/types/provider.d.ts +0 -45
- package/dist/core/types/provider.js +0 -3
- package/dist/core/types/route.d.ts +0 -62
- package/dist/core/types/route.js +0 -3
- package/dist/core/types/token.d.ts +0 -21
- package/dist/core/types/token.js +0 -3
- package/dist/core/types/tradingLimits.d.ts +0 -91
- package/dist/core/types/tradingLimits.js +0 -3
- package/dist/core/types/tradingMode.d.ts +0 -24
- package/dist/core/types/tradingMode.js +0 -31
- package/dist/core/types/transaction.d.ts +0 -45
- package/dist/core/types/transaction.js +0 -3
- package/dist/esm/cache/routes.js +0 -14644
- package/dist/esm/cache/tokens.js +0 -480
- package/dist/esm/core/abis/activePool.js +0 -10
- package/dist/esm/core/abis/addressesRegistry.js +0 -22
- package/dist/esm/core/abis/bipoolmanager.js +0 -68
- package/dist/esm/core/abis/borrowerOperations.js +0 -85
- package/dist/esm/core/abis/breakerbox.js +0 -4
- package/dist/esm/core/abis/broker.js +0 -5
- package/dist/esm/core/abis/erc20.js +0 -17
- package/dist/esm/core/abis/fpmm.js +0 -45
- package/dist/esm/core/abis/fpmmFactory.js +0 -22
- package/dist/esm/core/abis/hintHelpers.js +0 -10
- package/dist/esm/core/abis/index.js +0 -21
- package/dist/esm/core/abis/liquidityStrategy.js +0 -6
- package/dist/esm/core/abis/multiTroveGetter.js +0 -11
- package/dist/esm/core/abis/priceFeed.js +0 -12
- package/dist/esm/core/abis/pricingmodule.js +0 -2
- package/dist/esm/core/abis/reserve.js +0 -14
- package/dist/esm/core/abis/router.js +0 -41
- package/dist/esm/core/abis/sortedTroves.js +0 -11
- package/dist/esm/core/abis/systemParams.js +0 -10
- package/dist/esm/core/abis/troveManager.js +0 -23
- package/dist/esm/core/abis/troveNFT.js +0 -5
- package/dist/esm/core/abis/virtualPool.js +0 -7
- package/dist/esm/core/abis/virtualPoolFactory.js +0 -13
- package/dist/esm/core/constants/addresses.js +0 -107
- package/dist/esm/core/constants/borrowConstants.js +0 -12
- package/dist/esm/core/constants/borrowRegistries.js +0 -29
- package/dist/esm/core/constants/chainId.js +0 -7
- package/dist/esm/core/constants/contractNames.js +0 -20
- package/dist/esm/core/constants/index.js +0 -5
- package/dist/esm/core/errors/base.js +0 -12
- package/dist/esm/core/errors/index.js +0 -3
- package/dist/esm/core/errors/oracle.js +0 -10
- package/dist/esm/core/errors/router.js +0 -18
- package/dist/esm/core/types/borrow.js +0 -1
- package/dist/esm/core/types/contractAddresses.js +0 -1
- package/dist/esm/core/types/index.js +0 -9
- package/dist/esm/core/types/liquidity.js +0 -1
- package/dist/esm/core/types/pool.js +0 -10
- package/dist/esm/core/types/provider.js +0 -1
- package/dist/esm/core/types/route.js +0 -1
- package/dist/esm/core/types/token.js +0 -1
- package/dist/esm/core/types/tradingLimits.js +0 -1
- package/dist/esm/core/types/tradingMode.js +0 -26
- package/dist/esm/core/types/transaction.js +0 -1
- package/dist/esm/index.js +0 -139
- package/dist/esm/package.json +0 -1
- package/dist/esm/services/borrow/BorrowService.js +0 -455
- package/dist/esm/services/borrow/borrowHelpers.js +0 -3
- package/dist/esm/services/borrow/borrowMath.js +0 -127
- package/dist/esm/services/borrow/index.js +0 -3
- package/dist/esm/services/borrow/internal/borrowApprovalService.js +0 -48
- package/dist/esm/services/borrow/internal/borrowContextStore.js +0 -35
- package/dist/esm/services/borrow/internal/borrowErc20.js +0 -38
- package/dist/esm/services/borrow/internal/borrowHints.js +0 -27
- package/dist/esm/services/borrow/internal/borrowPositionParser.js +0 -82
- package/dist/esm/services/borrow/internal/borrowReadService.js +0 -271
- package/dist/esm/services/borrow/internal/borrowRegistryReader.js +0 -108
- package/dist/esm/services/borrow/internal/borrowTransactionService.js +0 -271
- package/dist/esm/services/borrow/internal/borrowTypes.js +0 -1
- package/dist/esm/services/borrow/internal/borrowValidation.js +0 -89
- package/dist/esm/services/index.js +0 -8
- package/dist/esm/services/liquidity/LiquidityService.js +0 -163
- package/dist/esm/services/liquidity/basicLiquidity.js +0 -162
- package/dist/esm/services/liquidity/index.js +0 -1
- package/dist/esm/services/liquidity/liquidityHelpers.js +0 -95
- package/dist/esm/services/liquidity/rebalance.js +0 -59
- package/dist/esm/services/liquidity/zapHelpers.js +0 -120
- package/dist/esm/services/liquidity/zapIn.js +0 -112
- package/dist/esm/services/liquidity/zapOut.js +0 -248
- package/dist/esm/services/pools/PoolService.js +0 -204
- package/dist/esm/services/pools/index.js +0 -1
- package/dist/esm/services/pools/poolDetails.js +0 -209
- package/dist/esm/services/pools/poolDiscovery.js +0 -112
- package/dist/esm/services/pools/rebalancePreview.js +0 -181
- package/dist/esm/services/quotes/QuoteService.js +0 -85
- package/dist/esm/services/quotes/index.js +0 -1
- package/dist/esm/services/routes/RouteService.js +0 -268
- package/dist/esm/services/routes/index.js +0 -1
- package/dist/esm/services/swap/SwapService.js +0 -247
- package/dist/esm/services/swap/index.js +0 -1
- package/dist/esm/services/tokens/index.js +0 -1
- package/dist/esm/services/tokens/tokenService.js +0 -285
- package/dist/esm/services/trading/TradingLimitsService.js +0 -154
- package/dist/esm/services/trading/TradingService.js +0 -222
- package/dist/esm/services/trading/index.js +0 -2
- package/dist/esm/utils/chainConfig.js +0 -118
- package/dist/esm/utils/costUtils.js +0 -56
- package/dist/esm/utils/deadline.js +0 -22
- package/dist/esm/utils/index.js +0 -9
- package/dist/esm/utils/multicall.js +0 -47
- package/dist/esm/utils/pathEncoder.js +0 -69
- package/dist/esm/utils/rateFeed.js +0 -23
- package/dist/esm/utils/retry.js +0 -24
- package/dist/esm/utils/routeUtils.js +0 -361
- package/dist/esm/utils/routes.js +0 -2
- package/dist/esm/utils/sortUtils.js +0 -33
- package/dist/esm/utils/tokens.js +0 -2
- package/dist/esm/utils/tradingLimits.js +0 -163
- package/dist/esm/utils/validation.js +0 -30
- package/dist/index.d.ts +0 -101
- package/dist/index.js +0 -158
- package/dist/services/borrow/BorrowService.d.ts +0 -381
- package/dist/services/borrow/BorrowService.js +0 -460
- package/dist/services/borrow/borrowHelpers.d.ts +0 -4
- package/dist/services/borrow/borrowHelpers.js +0 -13
- package/dist/services/borrow/borrowMath.d.ts +0 -21
- package/dist/services/borrow/borrowMath.js +0 -137
- package/dist/services/borrow/index.d.ts +0 -4
- package/dist/services/borrow/index.js +0 -20
- package/dist/services/borrow/internal/borrowApprovalService.d.ts +0 -14
- package/dist/services/borrow/internal/borrowApprovalService.js +0 -53
- package/dist/services/borrow/internal/borrowContextStore.d.ts +0 -11
- package/dist/services/borrow/internal/borrowContextStore.js +0 -40
- package/dist/services/borrow/internal/borrowErc20.d.ts +0 -5
- package/dist/services/borrow/internal/borrowErc20.js +0 -43
- package/dist/services/borrow/internal/borrowHints.d.ts +0 -7
- package/dist/services/borrow/internal/borrowHints.js +0 -31
- package/dist/services/borrow/internal/borrowPositionParser.d.ts +0 -4
- package/dist/services/borrow/internal/borrowPositionParser.js +0 -87
- package/dist/services/borrow/internal/borrowReadService.d.ts +0 -31
- package/dist/services/borrow/internal/borrowReadService.js +0 -276
- package/dist/services/borrow/internal/borrowRegistryReader.d.ts +0 -5
- package/dist/services/borrow/internal/borrowRegistryReader.js +0 -113
- package/dist/services/borrow/internal/borrowTransactionService.d.ts +0 -23
- package/dist/services/borrow/internal/borrowTransactionService.js +0 -276
- package/dist/services/borrow/internal/borrowTypes.d.ts +0 -15
- package/dist/services/borrow/internal/borrowTypes.js +0 -3
- package/dist/services/borrow/internal/borrowValidation.d.ts +0 -14
- package/dist/services/borrow/internal/borrowValidation.js +0 -104
- package/dist/services/index.d.ts +0 -9
- package/dist/services/index.js +0 -25
- package/dist/services/liquidity/LiquidityService.d.ts +0 -139
- package/dist/services/liquidity/LiquidityService.js +0 -168
- package/dist/services/liquidity/basicLiquidity.d.ts +0 -11
- package/dist/services/liquidity/basicLiquidity.js +0 -172
- package/dist/services/liquidity/index.d.ts +0 -2
- package/dist/services/liquidity/index.js +0 -18
- package/dist/services/liquidity/liquidityHelpers.d.ts +0 -19
- package/dist/services/liquidity/liquidityHelpers.js +0 -104
- package/dist/services/liquidity/rebalance.d.ts +0 -6
- package/dist/services/liquidity/rebalance.js +0 -64
- package/dist/services/liquidity/zapHelpers.d.ts +0 -66
- package/dist/services/liquidity/zapHelpers.js +0 -129
- package/dist/services/liquidity/zapIn.d.ts +0 -18
- package/dist/services/liquidity/zapIn.js +0 -119
- package/dist/services/liquidity/zapOut.d.ts +0 -9
- package/dist/services/liquidity/zapOut.js +0 -255
- package/dist/services/pools/PoolService.d.ts +0 -69
- package/dist/services/pools/PoolService.js +0 -209
- package/dist/services/pools/index.d.ts +0 -2
- package/dist/services/pools/index.js +0 -18
- package/dist/services/pools/poolDetails.d.ts +0 -13
- package/dist/services/pools/poolDetails.js +0 -216
- package/dist/services/pools/poolDiscovery.d.ts +0 -12
- package/dist/services/pools/poolDiscovery.js +0 -117
- package/dist/services/pools/rebalancePreview.d.ts +0 -5
- package/dist/services/pools/rebalancePreview.js +0 -186
- package/dist/services/quotes/QuoteService.d.ts +0 -51
- package/dist/services/quotes/QuoteService.js +0 -91
- package/dist/services/quotes/index.d.ts +0 -2
- package/dist/services/quotes/index.js +0 -18
- package/dist/services/routes/RouteService.d.ts +0 -117
- package/dist/services/routes/RouteService.js +0 -306
- package/dist/services/routes/index.d.ts +0 -2
- package/dist/services/routes/index.js +0 -18
- package/dist/services/swap/SwapService.d.ts +0 -198
- package/dist/services/swap/SwapService.js +0 -252
- package/dist/services/swap/index.d.ts +0 -2
- package/dist/services/swap/index.js +0 -18
- package/dist/services/tokens/index.d.ts +0 -2
- package/dist/services/tokens/index.js +0 -18
- package/dist/services/tokens/tokenService.d.ts +0 -55
- package/dist/services/tokens/tokenService.js +0 -290
- package/dist/services/trading/TradingLimitsService.d.ts +0 -38
- package/dist/services/trading/TradingLimitsService.js +0 -159
- package/dist/services/trading/TradingService.d.ts +0 -115
- package/dist/services/trading/TradingService.js +0 -227
- package/dist/services/trading/index.d.ts +0 -3
- package/dist/services/trading/index.js +0 -19
- package/dist/utils/chainConfig.d.ts +0 -16
- package/dist/utils/chainConfig.js +0 -123
- package/dist/utils/costUtils.d.ts +0 -12
- package/dist/utils/costUtils.js +0 -60
- package/dist/utils/deadline.d.ts +0 -21
- package/dist/utils/deadline.js +0 -26
- package/dist/utils/index.d.ts +0 -10
- package/dist/utils/index.js +0 -26
- package/dist/utils/multicall.d.ts +0 -30
- package/dist/utils/multicall.js +0 -52
- package/dist/utils/pathEncoder.d.ts +0 -34
- package/dist/utils/pathEncoder.js +0 -73
- package/dist/utils/rateFeed.d.ts +0 -18
- package/dist/utils/rateFeed.js +0 -27
- package/dist/utils/retry.d.ts +0 -12
- package/dist/utils/retry.js +0 -28
- package/dist/utils/routeUtils.d.ts +0 -295
- package/dist/utils/routeUtils.js +0 -371
- package/dist/utils/routes.d.ts +0 -3
- package/dist/utils/routes.js +0 -8
- package/dist/utils/sortUtils.d.ts +0 -24
- package/dist/utils/sortUtils.js +0 -39
- package/dist/utils/tokens.d.ts +0 -2
- package/dist/utils/tokens.js +0 -13
- package/dist/utils/tradingLimits.d.ts +0 -41
- package/dist/utils/tradingLimits.js +0 -171
- package/dist/utils/validation.d.ts +0 -19
- package/dist/utils/validation.js +0 -34
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.fetchPoolRebalancePreview = fetchPoolRebalancePreview;
|
|
4
|
-
exports.fetchPoolRebalancePreviewBatch = fetchPoolRebalancePreviewBatch;
|
|
5
|
-
const viem_1 = require("viem");
|
|
6
|
-
const abis_1 = require("../../core/abis");
|
|
7
|
-
const multicall_1 = require("../../utils/multicall");
|
|
8
|
-
// Liquidity strategy incentive rates are stored as 18-decimal percentages.
|
|
9
|
-
const FEE_DENOMINATOR = 10n ** 18n;
|
|
10
|
-
function toBigIntValue(value) {
|
|
11
|
-
return typeof value === 'bigint' ? value : BigInt(value);
|
|
12
|
-
}
|
|
13
|
-
function toNumberValue(value) {
|
|
14
|
-
return typeof value === 'number' ? value : Number(value);
|
|
15
|
-
}
|
|
16
|
-
function parseDirection(value) {
|
|
17
|
-
const normalized = toNumberValue(value);
|
|
18
|
-
if (normalized === 0)
|
|
19
|
-
return 'Expand';
|
|
20
|
-
if (normalized === 1)
|
|
21
|
-
return 'Contract';
|
|
22
|
-
throw new Error(`Unsupported liquidity strategy direction: ${normalized}`);
|
|
23
|
-
}
|
|
24
|
-
function parsePoolConfig(raw) {
|
|
25
|
-
return {
|
|
26
|
-
isToken0Debt: raw[0],
|
|
27
|
-
lastRebalance: toNumberValue(raw[1]),
|
|
28
|
-
rebalanceCooldown: toNumberValue(raw[2]),
|
|
29
|
-
protocolFeeRecipient: raw[3],
|
|
30
|
-
liquiditySourceIncentiveExpansion: toBigIntValue(raw[4]),
|
|
31
|
-
protocolIncentiveExpansion: toBigIntValue(raw[5]),
|
|
32
|
-
liquiditySourceIncentiveContraction: toBigIntValue(raw[6]),
|
|
33
|
-
protocolIncentiveContraction: toBigIntValue(raw[7]),
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
function parseContext(raw) {
|
|
37
|
-
return {
|
|
38
|
-
pool: raw[0],
|
|
39
|
-
reserves: {
|
|
40
|
-
reserveNum: toBigIntValue(raw[1][0]),
|
|
41
|
-
reserveDen: toBigIntValue(raw[1][1]),
|
|
42
|
-
},
|
|
43
|
-
prices: {
|
|
44
|
-
oracleNum: toBigIntValue(raw[2][0]),
|
|
45
|
-
oracleDen: toBigIntValue(raw[2][1]),
|
|
46
|
-
poolPriceAbove: raw[2][2],
|
|
47
|
-
rebalanceThreshold: toNumberValue(raw[2][3]),
|
|
48
|
-
},
|
|
49
|
-
token0: raw[3],
|
|
50
|
-
token1: raw[4],
|
|
51
|
-
token0Dec: toBigIntValue(raw[5]),
|
|
52
|
-
token1Dec: toBigIntValue(raw[6]),
|
|
53
|
-
isToken0Debt: raw[7],
|
|
54
|
-
incentives: {
|
|
55
|
-
liquiditySourceIncentiveExpansion: toBigIntValue(raw[8][0]),
|
|
56
|
-
protocolIncentiveExpansion: toBigIntValue(raw[8][1]),
|
|
57
|
-
liquiditySourceIncentiveContraction: toBigIntValue(raw[8][2]),
|
|
58
|
-
protocolIncentiveContraction: toBigIntValue(raw[8][3]),
|
|
59
|
-
},
|
|
60
|
-
};
|
|
61
|
-
}
|
|
62
|
-
function parseAction(raw) {
|
|
63
|
-
return {
|
|
64
|
-
dir: parseDirection(raw[0]),
|
|
65
|
-
amount0Out: toBigIntValue(raw[1]),
|
|
66
|
-
amount1Out: toBigIntValue(raw[2]),
|
|
67
|
-
amountOwedToPool: toBigIntValue(raw[3]),
|
|
68
|
-
};
|
|
69
|
-
}
|
|
70
|
-
function isPreviewEligible(detail) {
|
|
71
|
-
return (detail.poolType === 'FPMM' &&
|
|
72
|
-
detail.pricing !== null &&
|
|
73
|
-
detail.rebalancing.inBand === false &&
|
|
74
|
-
!!detail.rebalancing.liquidityStrategy);
|
|
75
|
-
}
|
|
76
|
-
function buildPreview(detail, strategyAddress, config, context, action) {
|
|
77
|
-
const debtToken = context.isToken0Debt ? context.token0 : context.token1;
|
|
78
|
-
const collateralToken = context.isToken0Debt ? context.token1 : context.token0;
|
|
79
|
-
const inputToken = action.dir === 'Expand' ? debtToken : collateralToken;
|
|
80
|
-
const outputToken = action.dir === 'Expand' ? collateralToken : debtToken;
|
|
81
|
-
const amountTransferredValue = action.amount0Out > 0n ? action.amount0Out : action.amount1Out;
|
|
82
|
-
const protocolRate = action.dir === 'Expand'
|
|
83
|
-
? config.protocolIncentiveExpansion
|
|
84
|
-
: config.protocolIncentiveContraction;
|
|
85
|
-
const liquiditySourceRate = action.dir === 'Expand'
|
|
86
|
-
? config.liquiditySourceIncentiveExpansion
|
|
87
|
-
: config.liquiditySourceIncentiveContraction;
|
|
88
|
-
const protocolIncentiveAmount = (amountTransferredValue * protocolRate) / FEE_DENOMINATOR;
|
|
89
|
-
const liquiditySourceBase = amountTransferredValue > protocolIncentiveAmount
|
|
90
|
-
? amountTransferredValue - protocolIncentiveAmount
|
|
91
|
-
: 0n;
|
|
92
|
-
const liquiditySourceIncentiveAmount = (liquiditySourceBase * liquiditySourceRate) / FEE_DENOMINATOR;
|
|
93
|
-
return {
|
|
94
|
-
poolAddress: detail.poolAddr,
|
|
95
|
-
strategyAddress,
|
|
96
|
-
direction: action.dir,
|
|
97
|
-
config,
|
|
98
|
-
context,
|
|
99
|
-
action,
|
|
100
|
-
inputToken,
|
|
101
|
-
outputToken,
|
|
102
|
-
amountRequired: {
|
|
103
|
-
token: inputToken,
|
|
104
|
-
amount: action.amountOwedToPool,
|
|
105
|
-
},
|
|
106
|
-
amountTransferred: {
|
|
107
|
-
token: outputToken,
|
|
108
|
-
amount: amountTransferredValue,
|
|
109
|
-
},
|
|
110
|
-
protocolIncentive: {
|
|
111
|
-
token: outputToken,
|
|
112
|
-
amount: protocolIncentiveAmount,
|
|
113
|
-
},
|
|
114
|
-
liquiditySourceIncentive: {
|
|
115
|
-
token: outputToken,
|
|
116
|
-
amount: liquiditySourceIncentiveAmount,
|
|
117
|
-
},
|
|
118
|
-
approvalToken: inputToken,
|
|
119
|
-
approvalSpender: strategyAddress,
|
|
120
|
-
approvalAmount: action.amountOwedToPool,
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
async function fetchPoolRebalancePreview(publicClient, detail) {
|
|
124
|
-
const [preview] = await fetchPoolRebalancePreviewBatch(publicClient, [detail]);
|
|
125
|
-
return preview;
|
|
126
|
-
}
|
|
127
|
-
async function fetchPoolRebalancePreviewBatch(publicClient, details) {
|
|
128
|
-
const previews = details.map(() => null);
|
|
129
|
-
const eligibleTargets = details.flatMap((detail, index) => {
|
|
130
|
-
if (!isPreviewEligible(detail))
|
|
131
|
-
return [];
|
|
132
|
-
const strategyAddress = detail.rebalancing.liquidityStrategy;
|
|
133
|
-
if (!strategyAddress)
|
|
134
|
-
return [];
|
|
135
|
-
try {
|
|
136
|
-
return [
|
|
137
|
-
{
|
|
138
|
-
index,
|
|
139
|
-
detail,
|
|
140
|
-
strategyAddress: (0, viem_1.getAddress)(strategyAddress),
|
|
141
|
-
},
|
|
142
|
-
];
|
|
143
|
-
}
|
|
144
|
-
catch {
|
|
145
|
-
return [];
|
|
146
|
-
}
|
|
147
|
-
});
|
|
148
|
-
if (eligibleTargets.length === 0) {
|
|
149
|
-
return previews;
|
|
150
|
-
}
|
|
151
|
-
const contracts = eligibleTargets.flatMap(({ detail, strategyAddress }) => [
|
|
152
|
-
{
|
|
153
|
-
address: strategyAddress,
|
|
154
|
-
abi: abis_1.LIQUIDITY_STRATEGY_ABI,
|
|
155
|
-
functionName: 'poolConfigs',
|
|
156
|
-
args: [detail.poolAddr],
|
|
157
|
-
},
|
|
158
|
-
{
|
|
159
|
-
address: strategyAddress,
|
|
160
|
-
abi: abis_1.LIQUIDITY_STRATEGY_ABI,
|
|
161
|
-
functionName: 'determineAction',
|
|
162
|
-
args: [detail.poolAddr],
|
|
163
|
-
},
|
|
164
|
-
]);
|
|
165
|
-
const results = await (0, multicall_1.multicall)(publicClient, contracts);
|
|
166
|
-
eligibleTargets.forEach((target, targetIndex) => {
|
|
167
|
-
const configResult = results[targetIndex * 2];
|
|
168
|
-
const determineActionResult = results[targetIndex * 2 + 1];
|
|
169
|
-
if (!configResult || !determineActionResult)
|
|
170
|
-
return;
|
|
171
|
-
if (configResult.status === 'failure' || determineActionResult.status === 'failure')
|
|
172
|
-
return;
|
|
173
|
-
try {
|
|
174
|
-
const config = parsePoolConfig(configResult.result);
|
|
175
|
-
const [rawContext, rawAction] = determineActionResult.result;
|
|
176
|
-
const context = parseContext(rawContext);
|
|
177
|
-
const action = parseAction(rawAction);
|
|
178
|
-
previews[target.index] = buildPreview(target.detail, target.strategyAddress, config, context, action);
|
|
179
|
-
}
|
|
180
|
-
catch {
|
|
181
|
-
previews[target.index] = null;
|
|
182
|
-
}
|
|
183
|
-
});
|
|
184
|
-
return previews;
|
|
185
|
-
}
|
|
186
|
-
//# sourceMappingURL=rebalancePreview.js.map
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { PublicClient } from 'viem';
|
|
2
|
-
import { RouteService } from '../routes';
|
|
3
|
-
import { Route } from '../../core/types';
|
|
4
|
-
/**
|
|
5
|
-
* Service for getting swap quotes from the Mento protocol.
|
|
6
|
-
* Calculates expected output amounts for trades without executing them.
|
|
7
|
-
*/
|
|
8
|
-
export declare class QuoteService {
|
|
9
|
-
private publicClient;
|
|
10
|
-
private chainId;
|
|
11
|
-
private routeService;
|
|
12
|
-
constructor(publicClient: PublicClient, chainId: number, routeService: RouteService);
|
|
13
|
-
/**
|
|
14
|
-
* Calculates the expected output amount for a swap between two tokens.
|
|
15
|
-
*
|
|
16
|
-
* @param tokenIn - The address of the input token (e.g., '0x765DE816845861e75A25fCA122bb6898B8B1282a')
|
|
17
|
-
* @param tokenOut - The address of the output token (e.g., '0x471EcE3750Da237f93B8E339c536989b8978a438')
|
|
18
|
-
* @param amountIn - The amount of input tokens (in wei/smallest unit)
|
|
19
|
-
* @param route - Optional pre-fetched route. If not provided, the optimal route will be found automatically.
|
|
20
|
-
* @returns The expected output amount (in wei/smallest unit)
|
|
21
|
-
* @throws {RouteNotFoundError} If no route exists between the token pair
|
|
22
|
-
* @throws {Error} If the Router contract call fails
|
|
23
|
-
*
|
|
24
|
-
* @example
|
|
25
|
-
* ```typescript
|
|
26
|
-
* // Calculate output for 100 USDm
|
|
27
|
-
* const amountIn = BigInt(100) * BigInt(10 ** 18) // 100 USDm in wei
|
|
28
|
-
* const expectedOut = await quoteService.getAmountOut(
|
|
29
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a', // USDm
|
|
30
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438', // CELO
|
|
31
|
-
* amountIn
|
|
32
|
-
* )
|
|
33
|
-
* console.log(`Expected CELO output: ${expectedOut}`)
|
|
34
|
-
*
|
|
35
|
-
* // Or provide a pre-fetched route for better performance
|
|
36
|
-
* const route = await routeService.findRoute(
|
|
37
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a',
|
|
38
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438'
|
|
39
|
-
* )
|
|
40
|
-
* const expectedOut2 = await quoteService.getAmountOut(
|
|
41
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a',
|
|
42
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438',
|
|
43
|
-
* amountIn,
|
|
44
|
-
* route
|
|
45
|
-
* )
|
|
46
|
-
* ```
|
|
47
|
-
*/
|
|
48
|
-
getAmountOut(tokenIn: string, tokenOut: string, amountIn: bigint, route?: Route): Promise<bigint>;
|
|
49
|
-
}
|
|
50
|
-
export declare function getAmountOutForRoute(publicClient: PublicClient, chainId: number, tokenIn: string, tokenOut: string, amountIn: bigint, route: Route): Promise<bigint>;
|
|
51
|
-
//# sourceMappingURL=QuoteService.d.ts.map
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.QuoteService = void 0;
|
|
4
|
-
exports.getAmountOutForRoute = getAmountOutForRoute;
|
|
5
|
-
const viem_1 = require("viem");
|
|
6
|
-
const abis_1 = require("../../core/abis");
|
|
7
|
-
const constants_1 = require("../../core/constants");
|
|
8
|
-
const errors_1 = require("../../core/errors");
|
|
9
|
-
const pathEncoder_1 = require("../../utils/pathEncoder");
|
|
10
|
-
const validation_1 = require("../../utils/validation");
|
|
11
|
-
/**
|
|
12
|
-
* Service for getting swap quotes from the Mento protocol.
|
|
13
|
-
* Calculates expected output amounts for trades without executing them.
|
|
14
|
-
*/
|
|
15
|
-
class QuoteService {
|
|
16
|
-
constructor(publicClient, chainId, routeService) {
|
|
17
|
-
this.publicClient = publicClient;
|
|
18
|
-
this.chainId = chainId;
|
|
19
|
-
this.routeService = routeService;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Calculates the expected output amount for a swap between two tokens.
|
|
23
|
-
*
|
|
24
|
-
* @param tokenIn - The address of the input token (e.g., '0x765DE816845861e75A25fCA122bb6898B8B1282a')
|
|
25
|
-
* @param tokenOut - The address of the output token (e.g., '0x471EcE3750Da237f93B8E339c536989b8978a438')
|
|
26
|
-
* @param amountIn - The amount of input tokens (in wei/smallest unit)
|
|
27
|
-
* @param route - Optional pre-fetched route. If not provided, the optimal route will be found automatically.
|
|
28
|
-
* @returns The expected output amount (in wei/smallest unit)
|
|
29
|
-
* @throws {RouteNotFoundError} If no route exists between the token pair
|
|
30
|
-
* @throws {Error} If the Router contract call fails
|
|
31
|
-
*
|
|
32
|
-
* @example
|
|
33
|
-
* ```typescript
|
|
34
|
-
* // Calculate output for 100 USDm
|
|
35
|
-
* const amountIn = BigInt(100) * BigInt(10 ** 18) // 100 USDm in wei
|
|
36
|
-
* const expectedOut = await quoteService.getAmountOut(
|
|
37
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a', // USDm
|
|
38
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438', // CELO
|
|
39
|
-
* amountIn
|
|
40
|
-
* )
|
|
41
|
-
* console.log(`Expected CELO output: ${expectedOut}`)
|
|
42
|
-
*
|
|
43
|
-
* // Or provide a pre-fetched route for better performance
|
|
44
|
-
* const route = await routeService.findRoute(
|
|
45
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a',
|
|
46
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438'
|
|
47
|
-
* )
|
|
48
|
-
* const expectedOut2 = await quoteService.getAmountOut(
|
|
49
|
-
* '0x765DE816845861e75A25fCA122bb6898B8B1282a',
|
|
50
|
-
* '0x471EcE3750Da237f93B8E339c536989b8978a438',
|
|
51
|
-
* amountIn,
|
|
52
|
-
* route
|
|
53
|
-
* )
|
|
54
|
-
* ```
|
|
55
|
-
*/
|
|
56
|
-
async getAmountOut(tokenIn, tokenOut, amountIn, route) {
|
|
57
|
-
// Validate address inputs
|
|
58
|
-
(0, validation_1.validateAddress)(tokenIn, 'tokenIn');
|
|
59
|
-
(0, validation_1.validateAddress)(tokenOut, 'tokenOut');
|
|
60
|
-
// If the consumer does not provide a route then we find the best route.
|
|
61
|
-
if (!route) {
|
|
62
|
-
route = await this.routeService.findRoute(tokenIn, tokenOut);
|
|
63
|
-
}
|
|
64
|
-
return getAmountOutForRoute(this.publicClient, this.chainId, tokenIn, tokenOut, amountIn, route);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
exports.QuoteService = QuoteService;
|
|
68
|
-
async function getAmountOutForRoute(publicClient, chainId, tokenIn, tokenOut, amountIn, route) {
|
|
69
|
-
const routerRoutes = (0, pathEncoder_1.encodeRoutePath)(route.path, tokenIn, tokenOut);
|
|
70
|
-
const routerAddress = (0, constants_1.getContractAddress)(chainId, 'Router');
|
|
71
|
-
try {
|
|
72
|
-
const amounts = (await publicClient.readContract({
|
|
73
|
-
address: routerAddress,
|
|
74
|
-
abi: abis_1.ROUTER_ABI,
|
|
75
|
-
functionName: 'getAmountsOut',
|
|
76
|
-
args: [amountIn, routerRoutes],
|
|
77
|
-
}));
|
|
78
|
-
return amounts[amounts.length - 1];
|
|
79
|
-
}
|
|
80
|
-
catch (error) {
|
|
81
|
-
if (error instanceof viem_1.BaseError) {
|
|
82
|
-
const revertError = error.walk((candidate) => candidate instanceof viem_1.ContractFunctionRevertedError);
|
|
83
|
-
if (revertError instanceof viem_1.ContractFunctionRevertedError &&
|
|
84
|
-
revertError.data?.errorName === 'FXMarketClosed') {
|
|
85
|
-
throw new errors_1.FXMarketClosedError();
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
throw error;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
//# sourceMappingURL=QuoteService.js.map
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./QuoteService"), exports);
|
|
18
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import { PoolService } from '../pools';
|
|
2
|
-
import { Route, RouteWithCost } from '../../core/types';
|
|
3
|
-
import { PublicClient } from 'viem';
|
|
4
|
-
export interface RouteOptions {
|
|
5
|
-
/**
|
|
6
|
-
* Whether to use pre-generated cached routes (default: true)
|
|
7
|
-
*/
|
|
8
|
-
cached?: boolean;
|
|
9
|
-
/**
|
|
10
|
-
* Whether to return all possible routes or just the optimal one per pair (default: false)
|
|
11
|
-
*/
|
|
12
|
-
returnAllRoutes?: boolean;
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Service for discovering and managing trading routes in the Mento protocol.
|
|
16
|
-
* Handles route discovery for both direct (single-hop) and multi-hop trading paths.
|
|
17
|
-
*
|
|
18
|
-
* Routes are identified by their token pair and include the path of pools
|
|
19
|
-
* needed to execute the trade. Multi-hop routes (up to 2 hops) are automatically
|
|
20
|
-
* discovered when no direct route exists between two tokens.
|
|
21
|
-
*/
|
|
22
|
-
export declare class RouteService {
|
|
23
|
-
private publicClient;
|
|
24
|
-
private chainId;
|
|
25
|
-
private poolService;
|
|
26
|
-
private symbolCache;
|
|
27
|
-
private routeCache;
|
|
28
|
-
private routeLookupCache;
|
|
29
|
-
private routePromises;
|
|
30
|
-
constructor(publicClient: PublicClient, chainId: number, poolService: PoolService);
|
|
31
|
-
/**
|
|
32
|
-
* Generates all direct (single-hop) routes from available pools
|
|
33
|
-
* Routes are deduplicated and assets are sorted alphabetically by symbol
|
|
34
|
-
*
|
|
35
|
-
* @returns Array of direct routes with single-hop paths
|
|
36
|
-
* @throws {Error} If RPC calls fail
|
|
37
|
-
*
|
|
38
|
-
* @example
|
|
39
|
-
* ```typescript
|
|
40
|
-
* const directRoutes = await routeService.getDirectRoutes()
|
|
41
|
-
* console.log(`Found ${directRoutes.length} direct routes`)
|
|
42
|
-
* ```
|
|
43
|
-
*/
|
|
44
|
-
getDirectRoutes(): Promise<Route[]>;
|
|
45
|
-
/**
|
|
46
|
-
* Discovers all tradable routes including multi-hop routes (up to 2 hops)
|
|
47
|
-
* Uses cached data by default for instant results, or generates fresh from blockchain
|
|
48
|
-
*
|
|
49
|
-
* @param options - Configuration options
|
|
50
|
-
* @param options.cached - Whether to use pre-generated cached routes (default: true)
|
|
51
|
-
* @param options.returnAllRoutes - Whether to return all possible routes or just the optimal one per pair (default: false)
|
|
52
|
-
* @returns Array of all tradable routes (direct + multi-hop routes)
|
|
53
|
-
*
|
|
54
|
-
* @example
|
|
55
|
-
* ```typescript
|
|
56
|
-
* // Fast: use pre-generated cache
|
|
57
|
-
* const cachedRoutes = await routeService.getRoutes({ cached: true })
|
|
58
|
-
*
|
|
59
|
-
* // Slower but fresh: generate from blockchain
|
|
60
|
-
* const freshRoutes = await routeService.getRoutes({ cached: false })
|
|
61
|
-
*
|
|
62
|
-
* // Get all route variants (useful for cache generation)
|
|
63
|
-
* const allRoutes = await routeService.getRoutes({ cached: false, returnAllRoutes: true })
|
|
64
|
-
* ```
|
|
65
|
-
*/
|
|
66
|
-
getRoutes(options?: RouteOptions): Promise<readonly (Route | RouteWithCost)[]>;
|
|
67
|
-
warm(options?: RouteOptions): Promise<readonly (Route | RouteWithCost)[]>;
|
|
68
|
-
/**
|
|
69
|
-
* Looks up the tradable route between two tokens (direct or multi-hop)
|
|
70
|
-
*
|
|
71
|
-
* @param tokenIn - Input token address (direction matters for routing)
|
|
72
|
-
* @param tokenOut - Output token address (direction matters for routing)
|
|
73
|
-
* @param options - Optional configuration (e.g., cached)
|
|
74
|
-
* @returns The optimal tradable route connecting the two tokens
|
|
75
|
-
* @throws {RouteNotFoundError} If no route exists between the token pair
|
|
76
|
-
*
|
|
77
|
-
* @example
|
|
78
|
-
* ```typescript
|
|
79
|
-
* const USDm = '0x765DE816845861e75A25fCA122bb6898B8B1282a'
|
|
80
|
-
* const BRLm = '0xE4D5...'
|
|
81
|
-
* const route = await routeService.findRoute(USDm, BRLm)
|
|
82
|
-
*
|
|
83
|
-
* if (route.path.length === 1) {
|
|
84
|
-
* console.log('Direct route available')
|
|
85
|
-
* } else {
|
|
86
|
-
* console.log('Two-hop route:', route.path)
|
|
87
|
-
* }
|
|
88
|
-
* ```
|
|
89
|
-
*/
|
|
90
|
-
findRoute(tokenIn: string, tokenOut: string, options?: {
|
|
91
|
-
cached?: boolean;
|
|
92
|
-
}): Promise<Route>;
|
|
93
|
-
/**
|
|
94
|
-
* Generate fresh tradable routes from blockchain data
|
|
95
|
-
* @param returnAllRoutes - Whether to return all routes or just optimal ones per pair
|
|
96
|
-
* @private
|
|
97
|
-
*/
|
|
98
|
-
private generateFreshRoutes;
|
|
99
|
-
/**
|
|
100
|
-
* Load cached tradable routes for current chain
|
|
101
|
-
* @private
|
|
102
|
-
*/
|
|
103
|
-
private loadCachedRoutes;
|
|
104
|
-
private loadRoutes;
|
|
105
|
-
private getCacheKey;
|
|
106
|
-
private buildLookup;
|
|
107
|
-
private hydrateTokenSymbols;
|
|
108
|
-
/**
|
|
109
|
-
* Helper: Fetch token symbol from on-chain
|
|
110
|
-
* Results are cached to avoid redundant RPC calls
|
|
111
|
-
* Falls back to address if symbol fetch fails
|
|
112
|
-
*
|
|
113
|
-
* @private
|
|
114
|
-
*/
|
|
115
|
-
private fetchTokenSymbol;
|
|
116
|
-
}
|
|
117
|
-
//# sourceMappingURL=RouteService.d.ts.map
|