@stake-dao/reader 0.1.3 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/bytecodes/index.js +16 -0
- package/dist/esm/bytecodes/index.js.map +1 -0
- package/dist/esm/bytecodes/strategies/batches/batchBalancerStrats.js +68 -0
- package/dist/esm/bytecodes/strategies/batches/batchBalancerStrats.js.map +1 -0
- package/dist/esm/{batches/curveStrats.js → bytecodes/strategies/batches/batchCurveStrats.js} +3 -3
- package/dist/esm/bytecodes/strategies/batches/batchCurveStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.js +61 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapPositions.js +44 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapPositions.js.map +1 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeswapStrats.js +48 -0
- package/dist/esm/bytecodes/strategies/batches/batchPancakeswapStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/batches/batchPendleStrats.js +63 -0
- package/dist/esm/bytecodes/strategies/batches/batchPendleStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/builds/buildBalancerStrats.js +54 -0
- package/dist/esm/bytecodes/strategies/builds/buildBalancerStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.js +64 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapStrats.js +51 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.js +54 -0
- package/dist/esm/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/builds/buildPendleStrats.js +39 -0
- package/dist/esm/bytecodes/strategies/builds/buildPendleStrats.js.map +1 -0
- package/dist/esm/{batches → bytecodes/strategies/builds}/buildYearnStrats.js +2 -2
- package/dist/esm/bytecodes/strategies/builds/buildYearnStrats.js.map +1 -0
- package/dist/esm/bytecodes/strategies/fetchYearnGauges.js.map +1 -0
- package/dist/esm/{batches → bytecodes/strategies}/sdtGaugeRewards.js +1 -1
- package/dist/esm/bytecodes/strategies/sdtGaugeRewards.js.map +1 -0
- package/dist/esm/bytecodes/tokenData.js.map +1 -0
- package/dist/esm/{batches → bytecodes}/types.js.map +1 -1
- package/dist/esm/endpoints.js +1 -0
- package/dist/esm/endpoints.js.map +1 -1
- package/dist/esm/index.js +33 -5
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lockers/utils/endpoints.js +1 -1
- package/dist/esm/lockers/utils/endpoints.js.map +1 -1
- package/dist/esm/prices.js +39 -3
- package/dist/esm/prices.js.map +1 -1
- package/dist/esm/strategies/balancer/build.js +51 -0
- package/dist/esm/strategies/balancer/build.js.map +1 -0
- package/dist/esm/strategies/balancer/endpoints.js +27 -0
- package/dist/esm/strategies/balancer/endpoints.js.map +1 -0
- package/dist/esm/strategies/balancer/fetch.js +190 -0
- package/dist/esm/strategies/balancer/fetch.js.map +1 -0
- package/dist/esm/strategies/curve/build.js +4 -3
- package/dist/esm/strategies/curve/build.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/bytecode.js +0 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/bytecode.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getCurveApiData.js +3 -2
- package/dist/esm/strategies/curve/fetch/curveApiData/getCurveApiData.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.js +3 -2
- package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesWeights.js +2 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesWeights.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.js +2 -1
- package/dist/esm/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.js.map +1 -1
- package/dist/esm/strategies/curve/fetch/index.js +22 -4
- package/dist/esm/strategies/curve/fetch/index.js.map +1 -1
- package/dist/esm/strategies/curve/httpCalls.js +3 -3
- package/dist/esm/strategies/curve/httpCalls.js.map +1 -1
- package/dist/esm/strategies/curve/onChainCalls.js +3 -2
- package/dist/esm/strategies/curve/onChainCalls.js.map +1 -1
- package/dist/esm/strategies/pancakeswap/abis/PancakeSwapMasterchef.json +1575 -0
- package/dist/esm/strategies/pancakeswap/build.js +48 -0
- package/dist/esm/strategies/pancakeswap/build.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/buildErc20.js +63 -0
- package/dist/esm/strategies/pancakeswap/buildErc20.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/config.js +7 -0
- package/dist/esm/strategies/pancakeswap/config.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/endpoints.js +10 -0
- package/dist/esm/strategies/pancakeswap/endpoints.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeApisData.js +24 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeApisData.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeErc20Vaults.js +134 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeErc20Vaults.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeNotDeployed.js +102 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeNotDeployed.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeV3Vaults.js +142 -0
- package/dist/esm/strategies/pancakeswap/fetch/getPancakeV3Vaults.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/index.js +25 -0
- package/dist/esm/strategies/pancakeswap/fetch/index.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/pancakePositions.js +87 -0
- package/dist/esm/strategies/pancakeswap/fetch/pancakePositions.js.map +1 -0
- package/dist/esm/strategies/pancakeswap/fetch/pancakeswapMath.js +199 -0
- package/dist/esm/strategies/pancakeswap/fetch/pancakeswapMath.js.map +1 -0
- package/dist/esm/strategies/pendle/abis/MulticallPendleStratsAbi.json +103 -0
- package/dist/esm/strategies/pendle/build.js +70 -0
- package/dist/esm/strategies/pendle/build.js.map +1 -0
- package/dist/esm/strategies/pendle/fetch.js +267 -0
- package/dist/esm/strategies/pendle/fetch.js.map +1 -0
- package/dist/esm/strategies/pendle/getPendleApiData.js +15 -0
- package/dist/esm/strategies/pendle/getPendleApiData.js.map +1 -0
- package/dist/esm/strategies/pendle/pendlePoints.js +71 -0
- package/dist/esm/strategies/pendle/pendlePoints.js.map +1 -0
- package/dist/esm/strategies/utils/getAprBreakdown.js +9 -9
- package/dist/esm/strategies/utils/getAprBreakdown.js.map +1 -1
- package/dist/esm/strategies/utils/index.js +10 -1
- package/dist/esm/strategies/utils/index.js.map +1 -1
- package/dist/esm/strategies/yearn/build.js +5 -4
- package/dist/esm/strategies/yearn/build.js.map +1 -1
- package/dist/esm/strategies/yearn/fetch/fetchAllYearnGauges.js +3 -2
- package/dist/esm/strategies/yearn/fetch/fetchAllYearnGauges.js.map +1 -1
- package/dist/esm/strategies/yearn/fetch/index.js +1 -1
- package/dist/esm/strategies/yearn/fetch/index.js.map +1 -1
- package/dist/esm/tsconfig.build.tsbuildinfo +1 -1
- package/dist/esm/utils.js +1 -1
- package/dist/esm/utils.js.map +1 -1
- package/dist/types/bytecodes/index.d.ts +16 -0
- package/dist/types/bytecodes/index.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchBalancerStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchBalancerStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchCurveStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchCurveStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeSwapPositions.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeSwapPositions.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeswapStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchPancakeswapStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/batches/batchPendleStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/batches/batchPendleStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildBalancerStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildBalancerStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeSwapStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeSwapStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildPendleStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildPendleStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/builds/buildYearnStrats.d.ts +4 -0
- package/dist/types/bytecodes/strategies/builds/buildYearnStrats.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/fetchYearnGauges.d.ts +4 -0
- package/dist/types/bytecodes/strategies/fetchYearnGauges.d.ts.map +1 -0
- package/dist/types/bytecodes/strategies/sdtGaugeRewards.d.ts +4 -0
- package/dist/types/bytecodes/strategies/sdtGaugeRewards.d.ts.map +1 -0
- package/dist/types/bytecodes/tokenData.d.ts.map +1 -0
- package/dist/types/bytecodes/types.d.ts.map +1 -0
- package/dist/types/endpoints.d.ts +1 -0
- package/dist/types/endpoints.d.ts.map +1 -1
- package/dist/types/index.d.ts +15 -5
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/lockers/utils/endpoints.d.ts +1 -1
- package/dist/types/lockers/utils/endpoints.d.ts.map +1 -1
- package/dist/types/prices.d.ts +8 -1
- package/dist/types/prices.d.ts.map +1 -1
- package/dist/types/strategies/balancer/build.d.ts +21 -0
- package/dist/types/strategies/balancer/build.d.ts.map +1 -0
- package/dist/types/strategies/balancer/endpoints.d.ts +3 -0
- package/dist/types/strategies/balancer/endpoints.d.ts.map +1 -0
- package/dist/types/strategies/balancer/fetch.d.ts +11 -0
- package/dist/types/strategies/balancer/fetch.d.ts.map +1 -0
- package/dist/types/strategies/curve/build.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/bytecode.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/getCurveApiData.d.ts +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/getCurveApiData.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/getGaugesWeights.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.d.ts.map +1 -1
- package/dist/types/strategies/curve/fetch/index.d.ts +15 -2
- package/dist/types/strategies/curve/fetch/index.d.ts.map +1 -1
- package/dist/types/strategies/curve/onChainCalls.d.ts.map +1 -1
- package/dist/types/strategies/pancakeswap/build.d.ts +2 -0
- package/dist/types/strategies/pancakeswap/build.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/buildErc20.d.ts +7 -0
- package/dist/types/strategies/pancakeswap/buildErc20.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/config.d.ts +7 -0
- package/dist/types/strategies/pancakeswap/config.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/endpoints.d.ts +8 -0
- package/dist/types/strategies/pancakeswap/endpoints.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeApisData.d.ts +10 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeApisData.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeErc20Vaults.d.ts +44 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeErc20Vaults.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeNotDeployed.d.ts +3 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeNotDeployed.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeV3Vaults.d.ts +7 -0
- package/dist/types/strategies/pancakeswap/fetch/getPancakeV3Vaults.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/index.d.ts +17 -0
- package/dist/types/strategies/pancakeswap/fetch/index.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/pancakePositions.d.ts +11 -0
- package/dist/types/strategies/pancakeswap/fetch/pancakePositions.d.ts.map +1 -0
- package/dist/types/strategies/pancakeswap/fetch/pancakeswapMath.d.ts +33 -0
- package/dist/types/strategies/pancakeswap/fetch/pancakeswapMath.d.ts.map +1 -0
- package/dist/types/strategies/pendle/build.d.ts +42 -0
- package/dist/types/strategies/pendle/build.d.ts.map +1 -0
- package/dist/types/strategies/pendle/fetch.d.ts +60 -0
- package/dist/types/strategies/pendle/fetch.d.ts.map +1 -0
- package/dist/types/strategies/pendle/getPendleApiData.d.ts +3 -0
- package/dist/types/strategies/pendle/getPendleApiData.d.ts.map +1 -0
- package/dist/types/strategies/pendle/pendlePoints.d.ts +80 -0
- package/dist/types/strategies/pendle/pendlePoints.d.ts.map +1 -0
- package/dist/types/strategies/types.d.ts +17 -3
- package/dist/types/strategies/types.d.ts.map +1 -1
- package/dist/types/strategies/utils/getAprBreakdown.d.ts +1 -4
- package/dist/types/strategies/utils/getAprBreakdown.d.ts.map +1 -1
- package/dist/types/strategies/utils/index.d.ts +2 -0
- package/dist/types/strategies/utils/index.d.ts.map +1 -1
- package/dist/types/strategies/yearn/build.d.ts.map +1 -1
- package/dist/types/strategies/yearn/fetch/fetchAllYearnGauges.d.ts.map +1 -1
- package/dist/types/strategies/yearn/fetch/index.d.ts +13 -2
- package/dist/types/strategies/yearn/fetch/index.d.ts.map +1 -1
- package/dist/types/utils.d.ts.map +1 -1
- package/package.json +3 -2
- package/src/bytecodes/index.ts +18 -0
- package/src/bytecodes/strategies/batches/batchBalancerStrats.ts +70 -0
- package/src/{batches/curveStrats.ts → bytecodes/strategies/batches/batchCurveStrats.ts} +3 -3
- package/src/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.ts +67 -0
- package/src/bytecodes/strategies/batches/batchPancakeSwapPositions.ts +50 -0
- package/src/bytecodes/strategies/batches/batchPancakeswapStrats.ts +54 -0
- package/src/bytecodes/strategies/batches/batchPendleStrats.ts +65 -0
- package/src/bytecodes/strategies/builds/buildBalancerStrats.ts +56 -0
- package/src/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.ts +70 -0
- package/src/bytecodes/strategies/builds/buildPancakeSwapStrats.ts +57 -0
- package/src/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.ts +60 -0
- package/src/bytecodes/strategies/builds/buildPendleStrats.ts +41 -0
- package/src/{batches → bytecodes/strategies/builds}/buildYearnStrats.ts +3 -3
- package/src/{batches → bytecodes/strategies}/fetchYearnGauges.ts +1 -1
- package/src/{batches → bytecodes/strategies}/sdtGaugeRewards.ts +2 -2
- package/src/endpoints.ts +2 -0
- package/src/index.ts +43 -5
- package/src/lockers/utils/endpoints.ts +2 -1
- package/src/prices.ts +57 -6
- package/src/strategies/balancer/build.ts +66 -0
- package/src/strategies/balancer/endpoints.ts +27 -0
- package/src/strategies/balancer/fetch.ts +266 -0
- package/src/strategies/curve/build.ts +4 -3
- package/src/strategies/curve/fetch/curveApiData/bytecode.ts +0 -1
- package/src/strategies/curve/fetch/curveApiData/getCurveApiData.ts +3 -2
- package/src/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.ts +6 -2
- package/src/strategies/curve/fetch/curveApiData/getGaugesWeights.ts +2 -1
- package/src/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.ts +2 -1
- package/src/strategies/curve/fetch/index.ts +53 -15
- package/src/strategies/curve/httpCalls.ts +3 -3
- package/src/strategies/curve/onChainCalls.ts +3 -2
- package/src/strategies/pancakeswap/build.ts +57 -0
- package/src/strategies/pancakeswap/buildErc20.ts +73 -0
- package/src/strategies/pancakeswap/config.ts +7 -0
- package/src/strategies/pancakeswap/endpoints.ts +12 -0
- package/src/strategies/pancakeswap/fetch/getPancakeApisData.ts +32 -0
- package/src/strategies/pancakeswap/fetch/getPancakeErc20Vaults.ts +184 -0
- package/src/strategies/pancakeswap/fetch/getPancakeNotDeployed.ts +132 -0
- package/src/strategies/pancakeswap/fetch/getPancakeV3Vaults.ts +191 -0
- package/src/strategies/pancakeswap/fetch/index.ts +50 -0
- package/src/strategies/pancakeswap/fetch/pancakePositions.ts +147 -0
- package/src/strategies/pancakeswap/fetch/pancakeswapMath.ts +305 -0
- package/src/strategies/pendle/build.ts +93 -0
- package/src/strategies/pendle/fetch.ts +348 -0
- package/src/strategies/pendle/getPendleApiData.ts +20 -0
- package/src/strategies/pendle/pendlePoints.ts +71 -0
- package/src/strategies/types.ts +20 -3
- package/src/strategies/utils/getAprBreakdown.ts +9 -9
- package/src/strategies/utils/index.ts +14 -1
- package/src/strategies/yearn/build.ts +5 -4
- package/src/strategies/yearn/fetch/fetchAllYearnGauges.ts +3 -2
- package/src/strategies/yearn/fetch/index.ts +22 -11
- package/src/utils.ts +1 -1
- package/dist/esm/batches/buildYearnStrats.js.map +0 -1
- package/dist/esm/batches/curveStrats.js.map +0 -1
- package/dist/esm/batches/fetchYearnGauges.js.map +0 -1
- package/dist/esm/batches/index.js +0 -6
- package/dist/esm/batches/index.js.map +0 -1
- package/dist/esm/batches/sdtGaugeRewards.js.map +0 -1
- package/dist/esm/batches/tokenData.js.map +0 -1
- package/dist/types/batches/buildYearnStrats.d.ts +0 -4
- package/dist/types/batches/buildYearnStrats.d.ts.map +0 -1
- package/dist/types/batches/curveStrats.d.ts +0 -4
- package/dist/types/batches/curveStrats.d.ts.map +0 -1
- package/dist/types/batches/fetchYearnGauges.d.ts +0 -4
- package/dist/types/batches/fetchYearnGauges.d.ts.map +0 -1
- package/dist/types/batches/index.d.ts +0 -6
- package/dist/types/batches/index.d.ts.map +0 -1
- package/dist/types/batches/sdtGaugeRewards.d.ts +0 -4
- package/dist/types/batches/sdtGaugeRewards.d.ts.map +0 -1
- package/dist/types/batches/tokenData.d.ts.map +0 -1
- package/dist/types/batches/types.d.ts.map +0 -1
- package/src/batches/index.ts +0 -5
- /package/dist/esm/{batches → bytecodes/strategies}/fetchYearnGauges.js +0 -0
- /package/dist/esm/{batches → bytecodes}/tokenData.js +0 -0
- /package/dist/esm/{batches → bytecodes}/types.js +0 -0
- /package/dist/types/{batches → bytecodes}/tokenData.d.ts +0 -0
- /package/dist/types/{batches → bytecodes}/types.d.ts +0 -0
- /package/src/{batches → bytecodes}/tokenData.ts +0 -0
- /package/src/{batches → bytecodes}/types.ts +0 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
import { formatUnits } from 'viem'
|
|
2
|
+
|
|
3
|
+
import pancakeMasterchefAbi from '../abis/PancakeSwapMasterchef.json'
|
|
4
|
+
|
|
5
|
+
import { contracts, tokenWithId } from '@stake-dao/constants'
|
|
6
|
+
import {
|
|
7
|
+
getPositionFarmApr,
|
|
8
|
+
getPositionTradingFee,
|
|
9
|
+
getToken0Amount,
|
|
10
|
+
getToken1Amount,
|
|
11
|
+
tickToPrice,
|
|
12
|
+
} from './pancakeswapMath.js'
|
|
13
|
+
|
|
14
|
+
export const computePositionData = (
|
|
15
|
+
s: any,
|
|
16
|
+
p: any,
|
|
17
|
+
stratParsedData: any,
|
|
18
|
+
fees24H: number,
|
|
19
|
+
prices: any[],
|
|
20
|
+
token0PriceInUsd: number,
|
|
21
|
+
token1PriceInUsd: number,
|
|
22
|
+
totalAllocPoint: string,
|
|
23
|
+
inflationRate: string,
|
|
24
|
+
) => {
|
|
25
|
+
const bnSqrtPriceX96 = BigInt(stratParsedData.sqrtPriceX96)
|
|
26
|
+
|
|
27
|
+
const token0Amount = formatUnits(
|
|
28
|
+
getToken0Amount(Number(stratParsedData.tick), p.tickLower, p.tickUpper, bnSqrtPriceX96, p.liquidity),
|
|
29
|
+
s.coins[0].decimals,
|
|
30
|
+
)
|
|
31
|
+
const token1Amount = formatUnits(
|
|
32
|
+
getToken1Amount(Number(stratParsedData.tick), p.tickLower, p.tickUpper, bnSqrtPriceX96, p.liquidity),
|
|
33
|
+
s.coins[1].decimals,
|
|
34
|
+
)
|
|
35
|
+
|
|
36
|
+
const token0AmountUsd = Number(token0Amount) * token0PriceInUsd
|
|
37
|
+
const token1AmountUsd = Number(token1Amount) * token1PriceInUsd
|
|
38
|
+
const tvlToAdd = token0AmountUsd + token1AmountUsd
|
|
39
|
+
|
|
40
|
+
const priceLower = tickToPrice(p.tickLower)
|
|
41
|
+
const priceUpper = tickToPrice(p.tickUpper)
|
|
42
|
+
|
|
43
|
+
const boost = Number(formatUnits(p.boostMultiplier.toString(), 12))
|
|
44
|
+
|
|
45
|
+
const apr =
|
|
46
|
+
getPositionFarmApr({
|
|
47
|
+
poolWeight: stratParsedData.allocPoint / Number(totalAllocPoint),
|
|
48
|
+
cakePriceUsd:
|
|
49
|
+
prices.find((p) => p.address.toLowerCase() === tokenWithId('cake', 56)!.address.toLowerCase())?.usdPrice || 0,
|
|
50
|
+
cakePerSecond: Number(inflationRate),
|
|
51
|
+
positionTvlUsd: token0AmountUsd + token1AmountUsd,
|
|
52
|
+
liquidity: p.boostLiquidity,
|
|
53
|
+
totalStakedLiquidity: BigInt(stratParsedData.totalBoostLiquidity),
|
|
54
|
+
tickCurrent: stratParsedData.tick,
|
|
55
|
+
tickLower: p.tickLower,
|
|
56
|
+
tickUpper: p.tickUpper,
|
|
57
|
+
}) * 0.85
|
|
58
|
+
|
|
59
|
+
const tradingApr = getPositionTradingFee({
|
|
60
|
+
fees24H,
|
|
61
|
+
sqrtRatioX96: bnSqrtPriceX96,
|
|
62
|
+
tickLower: p.tickLower,
|
|
63
|
+
tickUpper: p.tickUpper,
|
|
64
|
+
mostActiveLiquidity: BigInt(stratParsedData.poolLiquidity),
|
|
65
|
+
liquidity: p.liquidity,
|
|
66
|
+
positionUSD: token0AmountUsd + token1AmountUsd,
|
|
67
|
+
})
|
|
68
|
+
|
|
69
|
+
return {
|
|
70
|
+
positionData: {
|
|
71
|
+
...p,
|
|
72
|
+
boostLiquidity: p.boostLiquidity.toString(),
|
|
73
|
+
boostMultiplier: p.boostMultiplier.toString(),
|
|
74
|
+
liquidity: p.liquidity.toString(),
|
|
75
|
+
pid: Number(p.pid),
|
|
76
|
+
reward: p.reward.toString(),
|
|
77
|
+
rewardGrowthInside: p.rewardGrowthInside.toString(),
|
|
78
|
+
tokenId: Number(p.tokenId),
|
|
79
|
+
token0: {
|
|
80
|
+
amount: token0Amount,
|
|
81
|
+
amountUsd: token0AmountUsd,
|
|
82
|
+
},
|
|
83
|
+
token1: {
|
|
84
|
+
amount: token1Amount,
|
|
85
|
+
amountUsd: token1AmountUsd,
|
|
86
|
+
},
|
|
87
|
+
apr: {
|
|
88
|
+
trading: tradingApr,
|
|
89
|
+
min: apr,
|
|
90
|
+
max: apr,
|
|
91
|
+
},
|
|
92
|
+
priceLower,
|
|
93
|
+
priceUpper,
|
|
94
|
+
},
|
|
95
|
+
boost,
|
|
96
|
+
tvlToAdd,
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
export const getPositionData = async (
|
|
101
|
+
chainId: number,
|
|
102
|
+
tokenId: number,
|
|
103
|
+
tickLower: number,
|
|
104
|
+
tickUpper: number,
|
|
105
|
+
user: string,
|
|
106
|
+
strat: any,
|
|
107
|
+
prices: any[],
|
|
108
|
+
provider: any,
|
|
109
|
+
) => {
|
|
110
|
+
const positionData = await provider.readContract({
|
|
111
|
+
address: contracts.pancakeMasterchef![chainId],
|
|
112
|
+
abi: pancakeMasterchefAbi,
|
|
113
|
+
functionName: 'userPositionInfos',
|
|
114
|
+
args: [tokenId],
|
|
115
|
+
})
|
|
116
|
+
|
|
117
|
+
const p = {
|
|
118
|
+
tokenId,
|
|
119
|
+
liquidity: positionData[0],
|
|
120
|
+
boostLiquidity: positionData[1],
|
|
121
|
+
tickLower,
|
|
122
|
+
tickUpper,
|
|
123
|
+
rewardGrowthInside: positionData[4],
|
|
124
|
+
reward: positionData[5],
|
|
125
|
+
owner: user,
|
|
126
|
+
pid: positionData[7],
|
|
127
|
+
boostMultiplier: positionData[8],
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
const {
|
|
131
|
+
positionData: tokenIdPositionData,
|
|
132
|
+
tvlToAdd,
|
|
133
|
+
boost,
|
|
134
|
+
} = computePositionData(
|
|
135
|
+
strat,
|
|
136
|
+
p,
|
|
137
|
+
strat.stratsData,
|
|
138
|
+
strat.stratsData.fees24H,
|
|
139
|
+
prices,
|
|
140
|
+
strat.token0PriceInUsd,
|
|
141
|
+
strat.token1PriceInUsd,
|
|
142
|
+
strat.stratsData.totalAllocPoint || strat.stratsData.allocPoints,
|
|
143
|
+
strat.stratsData.inflationRate,
|
|
144
|
+
)
|
|
145
|
+
|
|
146
|
+
return { tokenIdPositionData, tvlToAdd, boost }
|
|
147
|
+
}
|
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
import { ONE_YEAR } from '@stake-dao/constants'
|
|
2
|
+
import { formatUnits, parseUnits } from 'viem'
|
|
3
|
+
import { Zero } from '../../../index.js'
|
|
4
|
+
|
|
5
|
+
const Q32 = BigInt(2 ** 32)
|
|
6
|
+
const Q96 = BigInt(2 ** 96)
|
|
7
|
+
const Q192 = Q96 * Q96
|
|
8
|
+
const MaxUint256 = BigInt('0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff')
|
|
9
|
+
export const MAX_TICK = 887250
|
|
10
|
+
|
|
11
|
+
function mulShift(val: bigint, mulBy: string): bigint {
|
|
12
|
+
return (val * BigInt(mulBy)) >> BigInt(128)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
interface FarmAprParams {
|
|
16
|
+
poolWeight: number
|
|
17
|
+
// Total tvl staked in farm in usd
|
|
18
|
+
tvlUsd: number
|
|
19
|
+
cakePriceUsd: number
|
|
20
|
+
cakePerSecond: number
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
interface PositionFarmAprParams extends Omit<FarmAprParams, 'tvlUsd'> {
|
|
24
|
+
// Position liquidity
|
|
25
|
+
liquidity: bigint
|
|
26
|
+
|
|
27
|
+
// Total staked liquidity in farm
|
|
28
|
+
totalStakedLiquidity: bigint
|
|
29
|
+
|
|
30
|
+
// Position tvl in usd
|
|
31
|
+
positionTvlUsd: number
|
|
32
|
+
|
|
33
|
+
// Tick
|
|
34
|
+
tickCurrent: number
|
|
35
|
+
tickLower: number
|
|
36
|
+
tickUpper: number
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
interface EstimateFeeOptions {
|
|
40
|
+
tickLower: number
|
|
41
|
+
tickUpper: number
|
|
42
|
+
// Average 24h historical fees generated minus pancake fees in USD
|
|
43
|
+
fees24H: number
|
|
44
|
+
|
|
45
|
+
// The reason of using price sqrt X96 instead of tick current is that
|
|
46
|
+
// tick current may have rounding error since it's a floor rounding
|
|
47
|
+
sqrtRatioX96: bigint
|
|
48
|
+
// Most active liquidity of the pool
|
|
49
|
+
mostActiveLiquidity: bigint
|
|
50
|
+
|
|
51
|
+
liquidity: bigint
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function getSqrtRatioAtTick(tick: number): bigint {
|
|
55
|
+
const absTick: number = tick < 0 ? tick * -1 : tick
|
|
56
|
+
|
|
57
|
+
let ratio: bigint =
|
|
58
|
+
(absTick & 0x1) !== 0 ? BigInt('0xfffcb933bd6fad37aa2d162d1a594001') : BigInt('0x100000000000000000000000000000000')
|
|
59
|
+
if ((absTick & 0x2) !== 0) ratio = mulShift(ratio, '0xfff97272373d413259a46990580e213a')
|
|
60
|
+
if ((absTick & 0x4) !== 0) ratio = mulShift(ratio, '0xfff2e50f5f656932ef12357cf3c7fdcc')
|
|
61
|
+
if ((absTick & 0x8) !== 0) ratio = mulShift(ratio, '0xffe5caca7e10e4e61c3624eaa0941cd0')
|
|
62
|
+
if ((absTick & 0x10) !== 0) ratio = mulShift(ratio, '0xffcb9843d60f6159c9db58835c926644')
|
|
63
|
+
if ((absTick & 0x20) !== 0) ratio = mulShift(ratio, '0xff973b41fa98c081472e6896dfb254c0')
|
|
64
|
+
if ((absTick & 0x40) !== 0) ratio = mulShift(ratio, '0xff2ea16466c96a3843ec78b326b52861')
|
|
65
|
+
if ((absTick & 0x80) !== 0) ratio = mulShift(ratio, '0xfe5dee046a99a2a811c461f1969c3053')
|
|
66
|
+
if ((absTick & 0x100) !== 0) ratio = mulShift(ratio, '0xfcbe86c7900a88aedcffc83b479aa3a4')
|
|
67
|
+
if ((absTick & 0x200) !== 0) ratio = mulShift(ratio, '0xf987a7253ac413176f2b074cf7815e54')
|
|
68
|
+
if ((absTick & 0x400) !== 0) ratio = mulShift(ratio, '0xf3392b0822b70005940c7a398e4b70f3')
|
|
69
|
+
if ((absTick & 0x800) !== 0) ratio = mulShift(ratio, '0xe7159475a2c29b7443b29c7fa6e889d9')
|
|
70
|
+
if ((absTick & 0x1000) !== 0) ratio = mulShift(ratio, '0xd097f3bdfd2022b8845ad8f792aa5825')
|
|
71
|
+
if ((absTick & 0x2000) !== 0) ratio = mulShift(ratio, '0xa9f746462d870fdf8a65dc1f90e061e5')
|
|
72
|
+
if ((absTick & 0x4000) !== 0) ratio = mulShift(ratio, '0x70d869a156d2a1b890bb3df62baf32f7')
|
|
73
|
+
if ((absTick & 0x8000) !== 0) ratio = mulShift(ratio, '0x31be135f97d08fd981231505542fcfa6')
|
|
74
|
+
if ((absTick & 0x10000) !== 0) ratio = mulShift(ratio, '0x9aa508b5b7a84e1c677de54f3e99bc9')
|
|
75
|
+
if ((absTick & 0x20000) !== 0) ratio = mulShift(ratio, '0x5d6af8dedb81196699c329225ee604')
|
|
76
|
+
if ((absTick & 0x40000) !== 0) ratio = mulShift(ratio, '0x2216e584f5fa1ea926041bedfe98')
|
|
77
|
+
if ((absTick & 0x80000) !== 0) ratio = mulShift(ratio, '0x48a170391f7dc42444e8fa2')
|
|
78
|
+
|
|
79
|
+
if (tick > 0) ratio = MaxUint256 / ratio
|
|
80
|
+
|
|
81
|
+
// back to Q96
|
|
82
|
+
return ratio % Q32 > Zero ? ratio / Q32 + BigInt(1) : ratio / Q32
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
function getAmount0Delta(sqrtRatioAX96: bigint, sqrtRatioBX96: bigint, liquidity: bigint): bigint {
|
|
86
|
+
if (sqrtRatioAX96 > sqrtRatioBX96) {
|
|
87
|
+
sqrtRatioAX96 = sqrtRatioBX96
|
|
88
|
+
sqrtRatioBX96 = sqrtRatioAX96
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
const numerator1 = liquidity << BigInt(96)
|
|
92
|
+
const numerator2 = sqrtRatioBX96 - sqrtRatioAX96
|
|
93
|
+
|
|
94
|
+
return (numerator1 * numerator2) / sqrtRatioBX96 / sqrtRatioAX96
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
function getAmount1Delta(sqrtRatioAX96: bigint, sqrtRatioBX96: bigint, liquidity: bigint): bigint {
|
|
98
|
+
if (sqrtRatioAX96 > sqrtRatioBX96) {
|
|
99
|
+
sqrtRatioAX96 = sqrtRatioBX96
|
|
100
|
+
sqrtRatioBX96 = sqrtRatioAX96
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
return (liquidity * (sqrtRatioBX96 - sqrtRatioAX96)) / Q96
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export function getToken0Amount(
|
|
107
|
+
tickCurrent: number,
|
|
108
|
+
tickLower: number,
|
|
109
|
+
tickUpper: number,
|
|
110
|
+
sqrtRatioX96: bigint,
|
|
111
|
+
liquidity: bigint,
|
|
112
|
+
): bigint {
|
|
113
|
+
if (Number.isNaN(tickCurrent) || Number.isNaN(tickLower) || Number.isNaN(tickUpper) || !sqrtRatioX96 || !liquidity) {
|
|
114
|
+
return Zero
|
|
115
|
+
}
|
|
116
|
+
if (tickCurrent < tickLower) {
|
|
117
|
+
return getAmount0Delta(getSqrtRatioAtTick(tickLower), getSqrtRatioAtTick(tickUpper), liquidity)
|
|
118
|
+
}
|
|
119
|
+
if (tickCurrent < tickUpper) {
|
|
120
|
+
return getAmount0Delta(sqrtRatioX96, getSqrtRatioAtTick(tickUpper), liquidity)
|
|
121
|
+
}
|
|
122
|
+
return Zero
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
export function getToken1Amount(
|
|
126
|
+
tickCurrent: number,
|
|
127
|
+
tickLower: number,
|
|
128
|
+
tickUpper: number,
|
|
129
|
+
sqrtRatioX96: bigint,
|
|
130
|
+
liquidity: bigint,
|
|
131
|
+
): bigint {
|
|
132
|
+
if (Number.isNaN(tickCurrent) || Number.isNaN(tickLower) || Number.isNaN(tickUpper) || !sqrtRatioX96 || !liquidity) {
|
|
133
|
+
return Zero
|
|
134
|
+
}
|
|
135
|
+
if (tickCurrent < tickLower) {
|
|
136
|
+
return Zero
|
|
137
|
+
}
|
|
138
|
+
if (tickCurrent < tickUpper) {
|
|
139
|
+
return getAmount1Delta(getSqrtRatioAtTick(tickLower), sqrtRatioX96, liquidity)
|
|
140
|
+
}
|
|
141
|
+
return getAmount1Delta(getSqrtRatioAtTick(tickLower), getSqrtRatioAtTick(tickUpper), liquidity)
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
export function getFarmApr({ poolWeight, tvlUsd, cakePriceUsd, cakePerSecond }: FarmAprParams) {
|
|
145
|
+
if (!poolWeight || !tvlUsd || !cakePriceUsd || !cakePerSecond) {
|
|
146
|
+
return 0
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
const cakeRewardPerYear = cakePerSecond * ONE_YEAR
|
|
150
|
+
const farmApr = ((poolWeight * cakeRewardPerYear * cakePriceUsd) / tvlUsd) * 100
|
|
151
|
+
|
|
152
|
+
return farmApr
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
export function getPositionFarmAprFactor({
|
|
156
|
+
poolWeight,
|
|
157
|
+
cakePriceUsd,
|
|
158
|
+
cakePerSecond,
|
|
159
|
+
liquidity,
|
|
160
|
+
totalStakedLiquidity,
|
|
161
|
+
}: Omit<PositionFarmAprParams, 'positionTvlUsd' | 'precision' | 'tickCurrent' | 'tickLower' | 'tickUpper'>) {
|
|
162
|
+
if (
|
|
163
|
+
!poolWeight ||
|
|
164
|
+
!cakePriceUsd ||
|
|
165
|
+
!cakePerSecond ||
|
|
166
|
+
BigInt(liquidity) === Zero ||
|
|
167
|
+
BigInt(totalStakedLiquidity) === Zero
|
|
168
|
+
) {
|
|
169
|
+
return 0
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
const cakeRewardPerYear = cakePerSecond * ONE_YEAR
|
|
173
|
+
const aprFactor =
|
|
174
|
+
((poolWeight * cakeRewardPerYear * cakePriceUsd) /
|
|
175
|
+
Number(formatUnits(BigInt(liquidity) + BigInt(totalStakedLiquidity), 18))) *
|
|
176
|
+
100
|
|
177
|
+
|
|
178
|
+
return aprFactor
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
export function getPositionFarmApr({
|
|
182
|
+
poolWeight,
|
|
183
|
+
positionTvlUsd,
|
|
184
|
+
cakePriceUsd,
|
|
185
|
+
cakePerSecond,
|
|
186
|
+
liquidity,
|
|
187
|
+
totalStakedLiquidity,
|
|
188
|
+
tickCurrent,
|
|
189
|
+
tickLower,
|
|
190
|
+
tickUpper,
|
|
191
|
+
}: PositionFarmAprParams) {
|
|
192
|
+
if (tickCurrent < tickLower || tickCurrent >= tickUpper) {
|
|
193
|
+
return 0
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
const aprFactor = getPositionFarmAprFactor({
|
|
197
|
+
poolWeight,
|
|
198
|
+
cakePriceUsd,
|
|
199
|
+
cakePerSecond,
|
|
200
|
+
liquidity,
|
|
201
|
+
totalStakedLiquidity,
|
|
202
|
+
})
|
|
203
|
+
|
|
204
|
+
if (!aprFactor || !positionTvlUsd) {
|
|
205
|
+
return 0
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
const positionApr = (aprFactor * Number(formatUnits(liquidity, 18))) / positionTvlUsd
|
|
209
|
+
|
|
210
|
+
return positionApr
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
const POWERS_OF_2 = [128, 64, 32, 16, 8, 4, 2, 1].map((pow: number): [number, bigint] => [pow, BigInt(2 ** pow)])
|
|
214
|
+
|
|
215
|
+
export function mostSignificantBit(x: bigint): number {
|
|
216
|
+
let msb = 0
|
|
217
|
+
for (const [power, min] of POWERS_OF_2) {
|
|
218
|
+
if (x >= min) {
|
|
219
|
+
// eslint-disable-next-line operator-assignment
|
|
220
|
+
x = x >> BigInt(power)
|
|
221
|
+
msb += power
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return msb
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
function getTickAtSqrtRatio(sqrtRatioX96: bigint): number {
|
|
228
|
+
const sqrtRatioX128 = sqrtRatioX96 << BigInt(32)
|
|
229
|
+
|
|
230
|
+
const msb = mostSignificantBit(sqrtRatioX128)
|
|
231
|
+
|
|
232
|
+
let r: bigint
|
|
233
|
+
if (BigInt(msb) >= BigInt(128)) {
|
|
234
|
+
r = sqrtRatioX128 >> BigInt(msb - 127)
|
|
235
|
+
} else {
|
|
236
|
+
r = sqrtRatioX128 << BigInt(127 - msb)
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
let log_2: bigint = (BigInt(msb) - BigInt(128)) << BigInt(64)
|
|
240
|
+
|
|
241
|
+
for (let i = 0; i < 14; i++) {
|
|
242
|
+
r = (r * r) >> BigInt(127)
|
|
243
|
+
const f = r >> BigInt(128)
|
|
244
|
+
// eslint-disable-next-line operator-assignment
|
|
245
|
+
log_2 = log_2 | (f << BigInt(63 - i))
|
|
246
|
+
// eslint-disable-next-line operator-assignment
|
|
247
|
+
r = r >> f
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
const log_sqrt10001 = log_2 * parseUnits('255738958999603826347141', 0)
|
|
251
|
+
|
|
252
|
+
const tickLow = Number((log_sqrt10001 - parseUnits('3402992956809132418596140100660247210', 0)) >> BigInt(128))
|
|
253
|
+
const tickHigh = Number((log_sqrt10001 + parseUnits('291339464771989622907027621153398088495', 0)) >> BigInt(128))
|
|
254
|
+
|
|
255
|
+
return tickLow === tickHigh ? tickLow : getSqrtRatioAtTick(tickHigh) <= sqrtRatioX96 ? tickHigh : tickLow
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
function getEstimatedLPFeeByAmount({
|
|
259
|
+
fees24H,
|
|
260
|
+
sqrtRatioX96,
|
|
261
|
+
tickLower,
|
|
262
|
+
tickUpper,
|
|
263
|
+
mostActiveLiquidity,
|
|
264
|
+
liquidity,
|
|
265
|
+
}: EstimateFeeOptions): number {
|
|
266
|
+
const tickCurrent = getTickAtSqrtRatio(sqrtRatioX96)
|
|
267
|
+
if (tickCurrent < tickLower || tickCurrent >= tickUpper) {
|
|
268
|
+
return 0
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
if (!liquidity) {
|
|
272
|
+
return 0
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
return (100 * fees24H * Number(formatUnits(liquidity, 18))) / Number(formatUnits(liquidity + mostActiveLiquidity, 18))
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
export function getPositionTradingFee({
|
|
279
|
+
fees24H,
|
|
280
|
+
sqrtRatioX96,
|
|
281
|
+
tickLower,
|
|
282
|
+
tickUpper,
|
|
283
|
+
mostActiveLiquidity,
|
|
284
|
+
liquidity,
|
|
285
|
+
positionUSD,
|
|
286
|
+
}): number {
|
|
287
|
+
const fees24HPosition = getEstimatedLPFeeByAmount({
|
|
288
|
+
fees24H,
|
|
289
|
+
sqrtRatioX96,
|
|
290
|
+
tickLower,
|
|
291
|
+
tickUpper,
|
|
292
|
+
mostActiveLiquidity,
|
|
293
|
+
liquidity,
|
|
294
|
+
})
|
|
295
|
+
|
|
296
|
+
return (positionUSD + fees24HPosition * 365) / positionUSD - 1
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
export function tickToPrice(tick: number, precision = 6): number {
|
|
300
|
+
const sqrtRatioX96 = getSqrtRatioAtTick(tick)
|
|
301
|
+
|
|
302
|
+
const ratioX192 = sqrtRatioX96 * sqrtRatioX96
|
|
303
|
+
|
|
304
|
+
return Number((ratioX192 * BigInt(10 ** precision)) / Q192) / 10 ** precision
|
|
305
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import dayjs from 'dayjs'
|
|
2
|
+
import utc from 'dayjs/plugin/utc.js'
|
|
3
|
+
import { chunk } from 'lodash-es'
|
|
4
|
+
import { encodeAbiParameters, parseAbiParameters } from 'viem'
|
|
5
|
+
import { buildPendleStrats } from '../../bytecodes/index.js'
|
|
6
|
+
import { batchJsonRpc, equalTlc } from '../../utils.js'
|
|
7
|
+
import { concatBytecode } from '../utils/index.js'
|
|
8
|
+
|
|
9
|
+
dayjs.extend(utc)
|
|
10
|
+
|
|
11
|
+
interface VaultAndLp {
|
|
12
|
+
vault: string
|
|
13
|
+
lpToken: string
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const formatCoin = (data: any) => ({
|
|
17
|
+
address: data.address,
|
|
18
|
+
name: data.name,
|
|
19
|
+
symbol: data.symbol,
|
|
20
|
+
decimals: data.decimals,
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
export const buildPendleStrategies = async (
|
|
24
|
+
rpc: string,
|
|
25
|
+
vaultsAndLps: VaultAndLp[],
|
|
26
|
+
pendleApiData: any[],
|
|
27
|
+
chainId: number,
|
|
28
|
+
) => {
|
|
29
|
+
const strats = vaultsAndLps.map((vlp) => {
|
|
30
|
+
const pendleMarketApiData = pendleApiData.find((d) => equalTlc(d.address, vlp.lpToken))
|
|
31
|
+
const sy = pendleMarketApiData.sy
|
|
32
|
+
|
|
33
|
+
const coin = formatCoin(pendleMarketApiData.underlyingAsset)
|
|
34
|
+
const underlyingCoin = formatCoin(pendleMarketApiData.accountingAsset)
|
|
35
|
+
const underlyingReward = formatCoin(pendleMarketApiData.basePricingAsset)
|
|
36
|
+
|
|
37
|
+
const expiryDayJs = dayjs(pendleMarketApiData.expiry).utc()
|
|
38
|
+
|
|
39
|
+
return {
|
|
40
|
+
key: `pendle_${sy.proSymbol.toLowerCase()}_${expiryDayJs.format('DD_MM_YYYY')}`,
|
|
41
|
+
name: sy.proSymbol,
|
|
42
|
+
subname: expiryDayJs.format('DD/MM/YYYY'),
|
|
43
|
+
protocol: 'pendle',
|
|
44
|
+
expiry: expiryDayJs.unix(),
|
|
45
|
+
chainId,
|
|
46
|
+
vault: vlp.vault,
|
|
47
|
+
lpToken: {
|
|
48
|
+
name: `${sy.proName} Pendle Market`,
|
|
49
|
+
symbol: `${sy.proSymbol} PENDLE LP`,
|
|
50
|
+
address: vlp.lpToken,
|
|
51
|
+
decimals: pendleMarketApiData.lp.decimals,
|
|
52
|
+
},
|
|
53
|
+
coins: [coin],
|
|
54
|
+
underlyingCoins: [underlyingCoin],
|
|
55
|
+
underlyingReward,
|
|
56
|
+
syToken: sy.address,
|
|
57
|
+
}
|
|
58
|
+
})
|
|
59
|
+
|
|
60
|
+
const inputsChunks = chunk(
|
|
61
|
+
strats.map((data) => [data.vault, data.lpToken.address]),
|
|
62
|
+
30,
|
|
63
|
+
)
|
|
64
|
+
|
|
65
|
+
const pendleCalls = inputsChunks.map((inputParams) => {
|
|
66
|
+
const inputData = encodeAbiParameters(parseAbiParameters(buildPendleStrats.inputType[chainId]!) as any, [
|
|
67
|
+
inputParams,
|
|
68
|
+
])
|
|
69
|
+
return concatBytecode(buildPendleStrats.bytecode[chainId]!, inputData)
|
|
70
|
+
})
|
|
71
|
+
|
|
72
|
+
const pendleData = await batchJsonRpc({
|
|
73
|
+
rpc,
|
|
74
|
+
calls: pendleCalls,
|
|
75
|
+
outputTypeAbi: buildPendleStrats.outputTypeHr[chainId],
|
|
76
|
+
callsKey: 'Build Pendle Strategies',
|
|
77
|
+
})
|
|
78
|
+
|
|
79
|
+
return strats.map((s) => {
|
|
80
|
+
const stratData = pendleData.find((d) => equalTlc(d.lpt, s.lpToken.address))
|
|
81
|
+
|
|
82
|
+
return {
|
|
83
|
+
...s,
|
|
84
|
+
sdGauge: stratData.sdGauge,
|
|
85
|
+
rewards: stratData.rewards.map((r) => ({
|
|
86
|
+
name: r._name,
|
|
87
|
+
symbol: r._symbol,
|
|
88
|
+
address: r._address,
|
|
89
|
+
decimals: Number(r._decimals),
|
|
90
|
+
})),
|
|
91
|
+
}
|
|
92
|
+
})
|
|
93
|
+
}
|