@defisaver/positions-sdk 2.1.21-npm-workflow-dev → 2.1.22-dev-savings-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mocharc.json +4 -4
- package/.nvmrc +1 -1
- package/README.md +64 -64
- package/cjs/config/contracts.d.ts +153 -0
- package/cjs/config/contracts.js +19 -1
- package/cjs/contracts.d.ts +1344 -0
- package/cjs/contracts.js +20 -1
- package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
- package/cjs/index.d.ts +2 -1
- package/cjs/index.js +3 -1
- package/cjs/markets/morphoBlue/index.d.ts +12 -0
- package/cjs/markets/morphoBlue/index.js +106 -2
- package/cjs/savings/index.d.ts +6 -0
- package/cjs/savings/index.js +71 -0
- package/cjs/savings/morphoVaults/index.d.ts +7 -0
- package/cjs/savings/morphoVaults/index.js +108 -0
- package/cjs/savings/morphoVaults/options.d.ts +16 -0
- package/cjs/savings/morphoVaults/options.js +99 -0
- package/cjs/savings/yearnVaults/index.d.ts +7 -0
- package/cjs/savings/yearnVaults/index.js +87 -0
- package/cjs/savings/yearnVaults/options.d.ts +6 -0
- package/cjs/savings/yearnVaults/options.js +26 -0
- package/cjs/types/index.d.ts +1 -0
- package/cjs/types/index.js +1 -0
- package/cjs/types/morphoBlue.d.ts +7 -1
- package/cjs/types/morphoBlue.js +7 -0
- package/cjs/types/savings/index.d.ts +17 -0
- package/cjs/types/savings/index.js +18 -0
- package/cjs/types/savings/morphoVaults.d.ts +22 -0
- package/cjs/types/savings/morphoVaults.js +19 -0
- package/cjs/types/savings/yearnVaults.d.ts +11 -0
- package/cjs/types/savings/yearnVaults.js +9 -0
- package/esm/config/contracts.d.ts +153 -0
- package/esm/config/contracts.js +18 -0
- package/esm/contracts.d.ts +1344 -0
- package/esm/contracts.js +17 -0
- package/esm/helpers/morphoBlueHelpers/index.js +66 -66
- package/esm/index.d.ts +2 -1
- package/esm/index.js +2 -1
- package/esm/markets/morphoBlue/index.d.ts +12 -0
- package/esm/markets/morphoBlue/index.js +98 -0
- package/esm/savings/index.d.ts +6 -0
- package/esm/savings/index.js +33 -0
- package/esm/savings/morphoVaults/index.d.ts +7 -0
- package/esm/savings/morphoVaults/index.js +67 -0
- package/esm/savings/morphoVaults/options.d.ts +16 -0
- package/esm/savings/morphoVaults/options.js +95 -0
- package/esm/savings/yearnVaults/index.d.ts +7 -0
- package/esm/savings/yearnVaults/index.js +46 -0
- package/esm/savings/yearnVaults/options.d.ts +6 -0
- package/esm/savings/yearnVaults/options.js +22 -0
- package/esm/types/index.d.ts +1 -0
- package/esm/types/index.js +1 -0
- package/esm/types/morphoBlue.d.ts +7 -1
- package/esm/types/morphoBlue.js +7 -0
- package/esm/types/savings/index.d.ts +17 -0
- package/esm/types/savings/index.js +2 -0
- package/esm/types/savings/morphoVaults.d.ts +22 -0
- package/esm/types/savings/morphoVaults.js +16 -0
- package/esm/types/savings/yearnVaults.d.ts +11 -0
- package/esm/types/savings/yearnVaults.js +6 -0
- package/package.json +48 -47
- package/src/aaveV2/index.ts +240 -240
- package/src/aaveV3/index.ts +614 -614
- package/src/aaveV3/merit.ts +97 -97
- package/src/aaveV3/merkl.ts +74 -74
- package/src/claiming/aaveV3.ts +154 -154
- package/src/claiming/compV3.ts +22 -22
- package/src/claiming/index.ts +12 -12
- package/src/claiming/king.ts +66 -66
- package/src/claiming/morphoBlue.ts +118 -118
- package/src/claiming/spark.ts +225 -225
- package/src/compoundV2/index.ts +244 -244
- package/src/compoundV3/index.ts +274 -274
- package/src/config/contracts.ts +1273 -1255
- package/src/constants/index.ts +10 -10
- package/src/contracts.ts +141 -121
- package/src/curveUsd/index.ts +254 -254
- package/src/eulerV2/index.ts +324 -324
- package/src/exchange/index.ts +25 -25
- package/src/fluid/index.ts +1774 -1774
- package/src/helpers/aaveHelpers/index.ts +187 -187
- package/src/helpers/compoundHelpers/index.ts +283 -283
- package/src/helpers/curveUsdHelpers/index.ts +40 -40
- package/src/helpers/eulerHelpers/index.ts +222 -222
- package/src/helpers/fluidHelpers/index.ts +326 -326
- package/src/helpers/index.ts +10 -10
- package/src/helpers/liquityV2Helpers/index.ts +82 -82
- package/src/helpers/llamaLendHelpers/index.ts +53 -53
- package/src/helpers/makerHelpers/index.ts +52 -52
- package/src/helpers/morphoBlueHelpers/index.ts +396 -396
- package/src/helpers/sparkHelpers/index.ts +158 -158
- package/src/index.ts +49 -47
- package/src/liquity/index.ts +159 -159
- package/src/liquityV2/index.ts +703 -703
- package/src/llamaLend/index.ts +305 -305
- package/src/maker/index.ts +223 -223
- package/src/markets/aave/index.ts +116 -116
- package/src/markets/aave/marketAssets.ts +54 -54
- package/src/markets/compound/index.ts +238 -238
- package/src/markets/compound/marketsAssets.ts +97 -97
- package/src/markets/curveUsd/index.ts +69 -69
- package/src/markets/euler/index.ts +26 -26
- package/src/markets/fluid/index.ts +2900 -2900
- package/src/markets/index.ts +25 -25
- package/src/markets/liquityV2/index.ts +102 -102
- package/src/markets/llamaLend/contractAddresses.ts +141 -141
- package/src/markets/llamaLend/index.ts +235 -235
- package/src/markets/morphoBlue/index.ts +971 -866
- package/src/markets/spark/index.ts +29 -29
- package/src/markets/spark/marketAssets.ts +12 -12
- package/src/moneymarket/moneymarketCommonService.ts +84 -84
- package/src/morphoBlue/index.ts +274 -274
- package/src/portfolio/index.ts +572 -572
- package/src/savings/index.ts +38 -0
- package/src/savings/morphoVaults/index.ts +69 -0
- package/src/savings/morphoVaults/options.ts +110 -0
- package/src/savings/yearnVaults/index.ts +46 -0
- package/src/savings/yearnVaults/options.ts +27 -0
- package/src/services/priceService.ts +278 -278
- package/src/services/utils.ts +115 -115
- package/src/services/viem.ts +34 -34
- package/src/setup.ts +8 -8
- package/src/spark/index.ts +456 -456
- package/src/staking/eligibility.ts +53 -53
- package/src/staking/index.ts +1 -1
- package/src/staking/staking.ts +183 -183
- package/src/types/aave.ts +189 -189
- package/src/types/claiming.ts +109 -109
- package/src/types/common.ts +107 -107
- package/src/types/compound.ts +136 -136
- package/src/types/curveUsd.ts +123 -123
- package/src/types/euler.ts +175 -175
- package/src/types/fluid.ts +483 -483
- package/src/types/index.ts +15 -14
- package/src/types/liquity.ts +30 -30
- package/src/types/liquityV2.ts +126 -126
- package/src/types/llamaLend.ts +159 -159
- package/src/types/maker.ts +63 -63
- package/src/types/merit.ts +1 -1
- package/src/types/merkl.ts +70 -70
- package/src/types/morphoBlue.ts +200 -192
- package/src/types/portfolio.ts +60 -60
- package/src/types/savings/index.ts +20 -0
- package/src/types/savings/morphoVaults.ts +24 -0
- package/src/types/savings/yearnVaults.ts +13 -0
- package/src/types/spark.ts +133 -133
- package/src/umbrella/index.ts +69 -69
- package/src/umbrella/umbrellaUtils.ts +29 -29
package/cjs/contracts.js
CHANGED
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.StkAAVEViem = exports.LiquityV2sBoldVaultViem = exports.AaveRewardsControllerViem = exports.SparkRewardsControllerViem = exports.UUPSViem = exports.LiquityStabilityPoolViem = exports.LiquityLQTYStakingViem = exports.AaveUmbrellaViewViem = exports.AaveIncentivesControllerViem = exports.FluidViewContractViem = exports.LiquityV2LegacyViewContractViem = exports.LiquityV2ViewContractViem = exports.LiquityActivePoolContractViem = exports.LiquityPriceFeedContractViem = exports.LiquityTroveManagerContractViem = exports.LiquityCollSurplusPoolContractViem = exports.LiquityViewContractViem = exports.BTCPriceFeedContractViem = exports.WeETHPriceFeedContractViem = exports.ComptrollerContractViem = exports.CompoundLoanInfoContractViem = exports.McdJugContractViem = exports.McdDogContractViem = exports.McdSpotterContractViem = exports.McdVatContractViem = exports.McdViewContractViem = exports.McdGetCdpsContractViem = exports.LlamaLendViewContractViem = exports.CrvUSDFactoryContractViem = exports.CrvUSDViewContractViem = exports.EulerV2ViewContractViem = exports.SparkIncentiveDataProviderContractViem = exports.SparkViewContractViem = exports.CompV3ViewContractViem = exports.WstETHPriceFeedContractViem = exports.USDCPriceFeedContractViem = exports.ETHPriceFeedContractViem = exports.COMPPriceFeedContractViem = exports.DFSFeedRegistryContractViem = exports.FeedRegistryContractViem = exports.AaveIncentiveDataProviderV3ContractViem = exports.AaveV3ViewContractViem = exports.AaveLoanInfoV2ContractViem = exports.MorphoBlueViewContractViem = exports.createViemContractFromConfigFunc = exports.getConfigContractAbi = exports.getConfigContractAddress = void 0;
|
|
36
|
+
exports.YearnViewContractViem = exports.StkAAVEViem = exports.LiquityV2sBoldVaultViem = exports.AaveRewardsControllerViem = exports.SparkRewardsControllerViem = exports.UUPSViem = exports.LiquityStabilityPoolViem = exports.LiquityLQTYStakingViem = exports.AaveUmbrellaViewViem = exports.AaveIncentivesControllerViem = exports.FluidViewContractViem = exports.LiquityV2LegacyViewContractViem = exports.LiquityV2ViewContractViem = exports.LiquityActivePoolContractViem = exports.LiquityPriceFeedContractViem = exports.LiquityTroveManagerContractViem = exports.LiquityCollSurplusPoolContractViem = exports.LiquityViewContractViem = exports.BTCPriceFeedContractViem = exports.WeETHPriceFeedContractViem = exports.ComptrollerContractViem = exports.CompoundLoanInfoContractViem = exports.McdJugContractViem = exports.McdDogContractViem = exports.McdSpotterContractViem = exports.McdVatContractViem = exports.McdViewContractViem = exports.McdGetCdpsContractViem = exports.LlamaLendViewContractViem = exports.CrvUSDFactoryContractViem = exports.CrvUSDViewContractViem = exports.EulerV2ViewContractViem = exports.SparkIncentiveDataProviderContractViem = exports.SparkViewContractViem = exports.CompV3ViewContractViem = exports.WstETHPriceFeedContractViem = exports.USDCPriceFeedContractViem = exports.ETHPriceFeedContractViem = exports.COMPPriceFeedContractViem = exports.DFSFeedRegistryContractViem = exports.FeedRegistryContractViem = exports.AaveIncentiveDataProviderV3ContractViem = exports.AaveV3ViewContractViem = exports.AaveLoanInfoV2ContractViem = exports.MorphoBlueViewContractViem = exports.getYearnVaultContractViem = exports.getMorphoVaultContractViem = exports.createViemContractFromConfigFunc = exports.getConfigContractAbi = exports.getConfigContractAddress = void 0;
|
|
37
37
|
const viem_1 = require("viem");
|
|
38
38
|
const configRaw = __importStar(require("./config/contracts"));
|
|
39
39
|
// @ts-ignore
|
|
@@ -84,6 +84,24 @@ const createViemContractFromConfigFunc = (name, _address) => (client, network, b
|
|
|
84
84
|
});
|
|
85
85
|
};
|
|
86
86
|
exports.createViemContractFromConfigFunc = createViemContractFromConfigFunc;
|
|
87
|
+
const getMorphoVaultContractViem = (client, address) => {
|
|
88
|
+
const abi = (0, exports.getConfigContractAbi)('MorphoVault');
|
|
89
|
+
return (0, viem_1.getContract)({
|
|
90
|
+
address,
|
|
91
|
+
abi,
|
|
92
|
+
client,
|
|
93
|
+
});
|
|
94
|
+
};
|
|
95
|
+
exports.getMorphoVaultContractViem = getMorphoVaultContractViem;
|
|
96
|
+
const getYearnVaultContractViem = (client, address) => {
|
|
97
|
+
const abi = (0, exports.getConfigContractAbi)('YearnVault');
|
|
98
|
+
return (0, viem_1.getContract)({
|
|
99
|
+
address,
|
|
100
|
+
abi,
|
|
101
|
+
client,
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
exports.getYearnVaultContractViem = getYearnVaultContractViem;
|
|
87
105
|
exports.MorphoBlueViewContractViem = (0, exports.createViemContractFromConfigFunc)('MorphoBlueView');
|
|
88
106
|
exports.AaveLoanInfoV2ContractViem = (0, exports.createViemContractFromConfigFunc)('AaveLoanInfoV2');
|
|
89
107
|
exports.AaveV3ViewContractViem = (0, exports.createViemContractFromConfigFunc)('AaveV3View');
|
|
@@ -128,3 +146,4 @@ exports.SparkRewardsControllerViem = (0, exports.createViemContractFromConfigFun
|
|
|
128
146
|
exports.AaveRewardsControllerViem = (0, exports.createViemContractFromConfigFunc)('AaveRewardsController');
|
|
129
147
|
exports.LiquityV2sBoldVaultViem = (0, exports.createViemContractFromConfigFunc)('LiquityV2sBoldVault');
|
|
130
148
|
exports.StkAAVEViem = (0, exports.createViemContractFromConfigFunc)('StkAAVE');
|
|
149
|
+
exports.YearnViewContractViem = (0, exports.createViemContractFromConfigFunc)('YearnView');
|
|
@@ -128,73 +128,73 @@ const getApyAfterValuesEstimation = (selectedMarket, actions, provider, network)
|
|
|
128
128
|
});
|
|
129
129
|
exports.getApyAfterValuesEstimation = getApyAfterValuesEstimation;
|
|
130
130
|
const API_URL = 'https://blue-api.morpho.org/graphql';
|
|
131
|
-
const MARKET_QUERY = `
|
|
132
|
-
query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
|
|
133
|
-
marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
|
|
134
|
-
reallocatableLiquidityAssets
|
|
135
|
-
targetBorrowUtilization
|
|
136
|
-
loanAsset {
|
|
137
|
-
address
|
|
138
|
-
decimals
|
|
139
|
-
priceUsd
|
|
140
|
-
}
|
|
141
|
-
state {
|
|
142
|
-
liquidityAssets
|
|
143
|
-
borrowAssets
|
|
144
|
-
supplyAssets
|
|
145
|
-
}
|
|
146
|
-
publicAllocatorSharedLiquidity {
|
|
147
|
-
assets
|
|
148
|
-
vault {
|
|
149
|
-
address
|
|
150
|
-
name
|
|
151
|
-
}
|
|
152
|
-
allocationMarket {
|
|
153
|
-
uniqueKey
|
|
154
|
-
loanAsset {
|
|
155
|
-
address
|
|
156
|
-
}
|
|
157
|
-
collateralAsset {
|
|
158
|
-
address
|
|
159
|
-
}
|
|
160
|
-
irmAddress
|
|
161
|
-
oracle {
|
|
162
|
-
address
|
|
163
|
-
}
|
|
164
|
-
lltv
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
loanAsset {
|
|
168
|
-
address
|
|
169
|
-
}
|
|
170
|
-
collateralAsset {
|
|
171
|
-
address
|
|
172
|
-
}
|
|
173
|
-
oracle {
|
|
174
|
-
address
|
|
175
|
-
}
|
|
176
|
-
irmAddress
|
|
177
|
-
lltv
|
|
178
|
-
}
|
|
179
|
-
}
|
|
131
|
+
const MARKET_QUERY = `
|
|
132
|
+
query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
|
|
133
|
+
marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
|
|
134
|
+
reallocatableLiquidityAssets
|
|
135
|
+
targetBorrowUtilization
|
|
136
|
+
loanAsset {
|
|
137
|
+
address
|
|
138
|
+
decimals
|
|
139
|
+
priceUsd
|
|
140
|
+
}
|
|
141
|
+
state {
|
|
142
|
+
liquidityAssets
|
|
143
|
+
borrowAssets
|
|
144
|
+
supplyAssets
|
|
145
|
+
}
|
|
146
|
+
publicAllocatorSharedLiquidity {
|
|
147
|
+
assets
|
|
148
|
+
vault {
|
|
149
|
+
address
|
|
150
|
+
name
|
|
151
|
+
}
|
|
152
|
+
allocationMarket {
|
|
153
|
+
uniqueKey
|
|
154
|
+
loanAsset {
|
|
155
|
+
address
|
|
156
|
+
}
|
|
157
|
+
collateralAsset {
|
|
158
|
+
address
|
|
159
|
+
}
|
|
160
|
+
irmAddress
|
|
161
|
+
oracle {
|
|
162
|
+
address
|
|
163
|
+
}
|
|
164
|
+
lltv
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
loanAsset {
|
|
168
|
+
address
|
|
169
|
+
}
|
|
170
|
+
collateralAsset {
|
|
171
|
+
address
|
|
172
|
+
}
|
|
173
|
+
oracle {
|
|
174
|
+
address
|
|
175
|
+
}
|
|
176
|
+
irmAddress
|
|
177
|
+
lltv
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
180
|
`;
|
|
181
|
-
const REWARDS_QUERY = `
|
|
182
|
-
query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
|
|
183
|
-
marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
|
|
184
|
-
uniqueKey
|
|
185
|
-
state {
|
|
186
|
-
rewards {
|
|
187
|
-
amountPerSuppliedToken
|
|
188
|
-
supplyApr
|
|
189
|
-
amountPerBorrowedToken
|
|
190
|
-
borrowApr
|
|
191
|
-
asset {
|
|
192
|
-
address
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
181
|
+
const REWARDS_QUERY = `
|
|
182
|
+
query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
|
|
183
|
+
marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
|
|
184
|
+
uniqueKey
|
|
185
|
+
state {
|
|
186
|
+
rewards {
|
|
187
|
+
amountPerSuppliedToken
|
|
188
|
+
supplyApr
|
|
189
|
+
amountPerBorrowedToken
|
|
190
|
+
borrowApr
|
|
191
|
+
asset {
|
|
192
|
+
address
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
198
|
`;
|
|
199
199
|
/**
|
|
200
200
|
* Get reallocatable liquidity to a given market and target borrow utilization
|
package/cjs/index.d.ts
CHANGED
|
@@ -19,5 +19,6 @@ import * as llamaLend from './llamaLend';
|
|
|
19
19
|
import * as eulerV2 from './eulerV2';
|
|
20
20
|
import * as portfolio from './portfolio';
|
|
21
21
|
import * as claiming from './claiming';
|
|
22
|
+
import * as savings from './savings';
|
|
22
23
|
export * from './types';
|
|
23
|
-
export { aaveV2, aaveV3, compoundV2, compoundV3, spark, curveUsd, liquity, liquityV2, maker, exchange, staking, moneymarket, markets, helpers, morphoBlue, llamaLend, eulerV2, fluid, portfolio, claiming, };
|
|
24
|
+
export { aaveV2, aaveV3, compoundV2, compoundV3, spark, curveUsd, liquity, liquityV2, maker, exchange, staking, moneymarket, markets, helpers, morphoBlue, llamaLend, eulerV2, fluid, portfolio, claiming, savings, };
|
package/cjs/index.js
CHANGED
|
@@ -36,7 +36,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
36
36
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.claiming = exports.portfolio = exports.fluid = exports.eulerV2 = exports.llamaLend = exports.morphoBlue = exports.helpers = exports.markets = exports.moneymarket = exports.staking = exports.exchange = exports.maker = exports.liquityV2 = exports.liquity = exports.curveUsd = exports.spark = exports.compoundV3 = exports.compoundV2 = exports.aaveV3 = exports.aaveV2 = void 0;
|
|
39
|
+
exports.savings = exports.claiming = exports.portfolio = exports.fluid = exports.eulerV2 = exports.llamaLend = exports.morphoBlue = exports.helpers = exports.markets = exports.moneymarket = exports.staking = exports.exchange = exports.maker = exports.liquityV2 = exports.liquity = exports.curveUsd = exports.spark = exports.compoundV3 = exports.compoundV2 = exports.aaveV3 = exports.aaveV2 = void 0;
|
|
40
40
|
require("./setup");
|
|
41
41
|
const fluid = __importStar(require("./fluid"));
|
|
42
42
|
exports.fluid = fluid;
|
|
@@ -78,4 +78,6 @@ const portfolio = __importStar(require("./portfolio"));
|
|
|
78
78
|
exports.portfolio = portfolio;
|
|
79
79
|
const claiming = __importStar(require("./claiming"));
|
|
80
80
|
exports.claiming = claiming;
|
|
81
|
+
const savings = __importStar(require("./savings"));
|
|
82
|
+
exports.savings = savings;
|
|
81
83
|
__exportStar(require("./types"), exports);
|
|
@@ -32,6 +32,7 @@ export declare const MORPHO_BLUE_USR_USDC_915: (networkId?: NetworkNumber) => Mo
|
|
|
32
32
|
export declare const MORPHO_BLUE_SYRUPUSDC_USDC_915: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
33
33
|
export declare const MORPHO_BLUE_LBTC_USDC_860: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
34
34
|
export declare const MORPHO_BLUE_LBTC_CBBTC_945: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
35
|
+
export declare const MORPHO_BLUE_SUSDS_USDT_965: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
35
36
|
export declare const MORPHO_BLUE_CBETH_USDC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
36
37
|
export declare const MORPHO_BLUE_CBETH_USDC_860_BASE_1c21c59d: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
37
38
|
export declare const MORPHO_BLUE_WSTETH_ETH_945_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
@@ -51,6 +52,11 @@ export declare const MORPHO_BLUE_LBTC_CBBTC_945_BASE: (networkId?: NetworkNumber
|
|
|
51
52
|
export declare const MORPHO_BLUE_WSTETH_EURC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
52
53
|
export declare const MORPHO_BLUE_CBBTC_EURC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
53
54
|
export declare const MORPHO_BLUE_WETH_EURC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
55
|
+
export declare const MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
56
|
+
export declare const MorphoBlueWBTCUSDC_860_Arb: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
57
|
+
export declare const MORPHO_BLUE_WSTETH_USDC_860_ARB: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
58
|
+
export declare const MORPHO_BLUE_ETH_USDC_860_ARB: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
59
|
+
export declare const MORPHO_BLUE_SUSDS_USDC_945_ARB: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
54
60
|
export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
55
61
|
readonly morphobluewstethusdc: MorphoBlueMarketData;
|
|
56
62
|
readonly morphobluesdaiusdc: MorphoBlueMarketData;
|
|
@@ -77,6 +83,7 @@ export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
|
77
83
|
readonly morphobluesyrupusdcusdc_915: MorphoBlueMarketData;
|
|
78
84
|
readonly morphobluelbtcusdc_860: MorphoBlueMarketData;
|
|
79
85
|
readonly morphobluelbtccbbtc_945: MorphoBlueMarketData;
|
|
86
|
+
readonly morphobluesusdsusdt_965: MorphoBlueMarketData;
|
|
80
87
|
readonly morphobluewstetheth_945: MorphoBlueMarketData;
|
|
81
88
|
readonly morphobluewstetheth_945_exchange_rate: MorphoBlueMarketData;
|
|
82
89
|
readonly morphobluewstetheth_965_exchange_rate: MorphoBlueMarketData;
|
|
@@ -103,5 +110,10 @@ export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
|
103
110
|
readonly morphobluecbetheth_965_base: MorphoBlueMarketData;
|
|
104
111
|
readonly morphobluewstetheth_945_base: MorphoBlueMarketData;
|
|
105
112
|
readonly morphobluewstetheth_965_base: MorphoBlueMarketData;
|
|
113
|
+
readonly morphobluesyrupusdcusdc_915_arb: MorphoBlueMarketData;
|
|
114
|
+
readonly morphobluewbtcusdc_860_arb: MorphoBlueMarketData;
|
|
115
|
+
readonly morphobluewstethusdc_860_arb: MorphoBlueMarketData;
|
|
116
|
+
readonly morphoblueethusdc_860_arb: MorphoBlueMarketData;
|
|
117
|
+
readonly morphobluesusdsusdc_945_arb: MorphoBlueMarketData;
|
|
106
118
|
};
|
|
107
119
|
export declare const findMorphoBlueMarket: (collateralToken: string, loanToken: string, lltv: number, oracle: string, irm: string, network?: NetworkNumber) => MorphoBlueMarketData | null;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = exports.MORPHO_BLUE_WETH_EURC_860_BASE = void 0;
|
|
3
|
+
exports.MORPHO_BLUE_WSTETH_EURC_860_BASE = exports.MORPHO_BLUE_LBTC_CBBTC_945_BASE = exports.MORPHO_BLUE_LBTC_WBTC_945 = exports.MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE = exports.MORPHO_BLUE_CBBTC_USDC_860_BASE = exports.MORPHO_BLUE_CBBTC_ETH_915_BASE = exports.MORPHO_BLUE_RETH_ETH_945_BASE = exports.MORPHO_BLUE_RETH_USDC_860_BASE = exports.MORPHO_BLUE_ETH_USDC_860_BASE = exports.MORPHO_BLUE_CBETH_ETH_945_BASE = exports.MORPHO_BLUE_CBETH_ETH_965_BASE = exports.MORPHO_BLUE_WSTETH_USDC_860_BASE = exports.MORPHO_BLUE_WSTETH_USDC_860_BASE_13c42741 = exports.MORPHO_BLUE_WSTETH_ETH_965_BASE = exports.MORPHO_BLUE_WSTETH_ETH_945_BASE = exports.MORPHO_BLUE_CBETH_USDC_860_BASE_1c21c59d = exports.MORPHO_BLUE_CBETH_USDC_860_BASE = exports.MORPHO_BLUE_SUSDS_USDT_965 = exports.MORPHO_BLUE_LBTC_CBBTC_945 = exports.MORPHO_BLUE_LBTC_USDC_860 = exports.MORPHO_BLUE_SYRUPUSDC_USDC_915 = exports.MORPHO_BLUE_USR_USDC_915 = exports.MORPHO_BLUE_USDE_DAI_915 = exports.MORPHO_BLUE_USDE_DAI_860 = exports.MORPHO_BLUE_SUSDE_DAI_945 = exports.MORPHO_BLUE_SUSDE_DAI_915 = exports.MORPHO_BLUE_SUSDE_DAI_860 = exports.MORPHO_BLUE_WSTETH_ETH_965_EXCHANGE_RATE = exports.MORPHO_BLUE_WSTETH_ETH_945_EXCHANGE_RATE = exports.MORPHO_BLUE_WSTETH_ETH_945 = exports.MORPHO_BLUE_WEETH_ETH_945 = exports.MORPHO_BLUE_EZETH_ETH_945 = exports.MORPHO_BLUE_EZETH_ETH_860 = exports.MORPHO_BLUE_SUSDE_USDC_915 = exports.MORPHO_BLUE_CBBTC_USDC_860 = exports.MORPHO_BLUE_CBBTC_ETH_915 = exports.MORPHO_BLUE_TBTC_USDC = exports.MORPHO_BLUE_MKR_USDC = exports.MORPHO_BLUE_SUSDE_USDT = exports.MORPHO_BLUE_USDE_USDT = exports.MORPHO_BLUE_WSTETH_PYUSD = exports.MORPHO_BLUE_WSTETH_USDA_EXCHANGE_RATE = exports.MORPHO_BLUE_WSTETH_USDT = exports.MORPHO_BLUE_WBTC_ETH = exports.MORPHO_BLUE_WBTC_PYUSD = exports.MORPHO_BLUE_WBTC_USDT = exports.MORPHO_BLUE_ETH_USDC = exports.MORPHO_BLUE_WBTC_USDC = exports.MORPHO_BLUE_SDAI_USDC = exports.MORPHO_BLUE_WSTETH_USDC = void 0;
|
|
4
|
+
exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = exports.MORPHO_BLUE_SUSDS_USDC_945_ARB = exports.MORPHO_BLUE_ETH_USDC_860_ARB = exports.MORPHO_BLUE_WSTETH_USDC_860_ARB = exports.MorphoBlueWBTCUSDC_860_Arb = exports.MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB = exports.MORPHO_BLUE_WETH_EURC_860_BASE = exports.MORPHO_BLUE_CBBTC_EURC_860_BASE = void 0;
|
|
5
5
|
const utils_1 = require("../../services/utils");
|
|
6
6
|
const types_1 = require("../../types");
|
|
7
7
|
const common_1 = require("../../types/common");
|
|
@@ -522,6 +522,22 @@ const MORPHO_BLUE_LBTC_CBBTC_945 = (networkId = common_1.NetworkNumber.Eth) => (
|
|
|
522
522
|
protocolName: 'morpho-blue',
|
|
523
523
|
});
|
|
524
524
|
exports.MORPHO_BLUE_LBTC_CBBTC_945 = MORPHO_BLUE_LBTC_CBBTC_945;
|
|
525
|
+
const MORPHO_BLUE_SUSDS_USDT_965 = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
526
|
+
chainIds: [1],
|
|
527
|
+
label: 'Morpho',
|
|
528
|
+
shortLabel: 'sUSDS/USDT',
|
|
529
|
+
value: types_1.MorphoBlueVersions.MorphoBluesUSDSUSDT_965,
|
|
530
|
+
url: 'susdsusdt-3274643d',
|
|
531
|
+
loanToken: '0xdAC17F958D2ee523a2206206994597C13D831ec7',
|
|
532
|
+
collateralToken: '0xa3931d71877C0E7a3148CB7Eb4463524FEc27fbD',
|
|
533
|
+
oracle: '0x0C426d174FC88B7A25d59945Ab2F7274Bf7B4C79',
|
|
534
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
535
|
+
irm: '0x870aC11D48B15DB9a138Cf899d20F13F79Ba00BC',
|
|
536
|
+
lltv: 0.965,
|
|
537
|
+
marketId: '0x3274643db77a064abd3bc851de77556a4ad2e2f502f4f0c80845fa8f909ecf0b',
|
|
538
|
+
protocolName: 'morpho-blue',
|
|
539
|
+
});
|
|
540
|
+
exports.MORPHO_BLUE_SUSDS_USDT_965 = MORPHO_BLUE_SUSDS_USDT_965;
|
|
525
541
|
// ###### BASE ########
|
|
526
542
|
const MORPHO_BLUE_CBETH_USDC_860_BASE = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
527
543
|
chainIds: [common_1.NetworkNumber.Base],
|
|
@@ -827,6 +843,87 @@ const MORPHO_BLUE_WETH_EURC_860_BASE = (networkId = common_1.NetworkNumber.Eth)
|
|
|
827
843
|
protocolName: 'morpho-blue',
|
|
828
844
|
});
|
|
829
845
|
exports.MORPHO_BLUE_WETH_EURC_860_BASE = MORPHO_BLUE_WETH_EURC_860_BASE;
|
|
846
|
+
// Arbitrum
|
|
847
|
+
const MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
848
|
+
chainIds: [common_1.NetworkNumber.Arb],
|
|
849
|
+
label: 'Morpho',
|
|
850
|
+
shortLabel: 'syrupUSDC/USDC',
|
|
851
|
+
value: types_1.MorphoBlueVersions.MorphoBlueSyrupUSDCUSDC_915_Arb,
|
|
852
|
+
url: 'syrupusdcusdc-f86f3edd',
|
|
853
|
+
loanToken: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831',
|
|
854
|
+
collateralToken: '0x41CA7586cC1311807B4605fBB748a3B8862b42b5',
|
|
855
|
+
oracle: '0x8f30fF3d54e69D4dfD5E99a9937474FaDdf27009',
|
|
856
|
+
oracleType: types_1.MorphoBlueOracleType.CONTRACT_RATE,
|
|
857
|
+
irm: '0x66F30587FB8D4206918deb78ecA7d5eBbafD06DA',
|
|
858
|
+
lltv: 0.915,
|
|
859
|
+
marketId: '0xf86f3edd6f16cd8211f4d206866dc4ecd41be6211063ac11f8508e1b7112ef40',
|
|
860
|
+
protocolName: 'morpho-blue',
|
|
861
|
+
});
|
|
862
|
+
exports.MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB = MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB;
|
|
863
|
+
const MorphoBlueWBTCUSDC_860_Arb = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
864
|
+
chainIds: [common_1.NetworkNumber.Arb],
|
|
865
|
+
label: 'Morpho',
|
|
866
|
+
shortLabel: 'WBTC/USDC',
|
|
867
|
+
value: types_1.MorphoBlueVersions.MorphoBlueWBTCUSDC_860_Arb,
|
|
868
|
+
url: 'wbtcusdc-e6392ff1',
|
|
869
|
+
loanToken: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831',
|
|
870
|
+
collateralToken: '0x2f2a2543B76A4166549F7aaB2e75Bef0aefC5B0f',
|
|
871
|
+
oracle: '0x88193FcB705d29724A40Bb818eCAA47dD5F014d9',
|
|
872
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
873
|
+
irm: '0x66F30587FB8D4206918deb78ecA7d5eBbafD06DA',
|
|
874
|
+
lltv: 0.86,
|
|
875
|
+
marketId: '0xe6392ff19d10454b099d692b58c361ef93e31af34ed1ef78232e07c78fe99169',
|
|
876
|
+
protocolName: 'morpho-blue',
|
|
877
|
+
});
|
|
878
|
+
exports.MorphoBlueWBTCUSDC_860_Arb = MorphoBlueWBTCUSDC_860_Arb;
|
|
879
|
+
const MORPHO_BLUE_WSTETH_USDC_860_ARB = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
880
|
+
chainIds: [common_1.NetworkNumber.Arb],
|
|
881
|
+
label: 'Morpho',
|
|
882
|
+
shortLabel: 'wstETH/USDC',
|
|
883
|
+
value: types_1.MorphoBlueVersions.MorphoBlueWstEthUSDC_860_Arb,
|
|
884
|
+
url: 'wstethusdc-33e0c8ab',
|
|
885
|
+
loanToken: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831',
|
|
886
|
+
collateralToken: '0x5979D7b546E38E414F7E9822514be443A4800529',
|
|
887
|
+
oracle: '0x8e02a9b9Cc29d783b2fCB71C3a72651B591cae31',
|
|
888
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
889
|
+
irm: '0x66F30587FB8D4206918deb78ecA7d5eBbafD06DA',
|
|
890
|
+
lltv: 0.86,
|
|
891
|
+
marketId: '0x33e0c8ab132390822b07e5dc95033cf250c963153320b7ffca73220664da2ea0',
|
|
892
|
+
protocolName: 'morpho-blue',
|
|
893
|
+
});
|
|
894
|
+
exports.MORPHO_BLUE_WSTETH_USDC_860_ARB = MORPHO_BLUE_WSTETH_USDC_860_ARB;
|
|
895
|
+
const MORPHO_BLUE_ETH_USDC_860_ARB = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
896
|
+
chainIds: [common_1.NetworkNumber.Arb],
|
|
897
|
+
label: 'Morpho',
|
|
898
|
+
shortLabel: 'ETH/USDC',
|
|
899
|
+
value: types_1.MorphoBlueVersions.MorphoBlueEthUSDC_860_Arb,
|
|
900
|
+
url: 'ethusdc-ca83d02b',
|
|
901
|
+
loanToken: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831',
|
|
902
|
+
collateralToken: '0x82aF49447D8a07e3bd95BD0d56f35241523fBab1',
|
|
903
|
+
oracle: '0x282FEB10549fde52bD61A6979424Ddf18A4971A2',
|
|
904
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
905
|
+
irm: '0x66F30587FB8D4206918deb78ecA7d5eBbafD06DA',
|
|
906
|
+
lltv: 0.86,
|
|
907
|
+
marketId: '0xca83d02be579485cc10945c9597a6141e772f1cf0e0aa28d09a327b6cbd8642c',
|
|
908
|
+
protocolName: 'morpho-blue',
|
|
909
|
+
});
|
|
910
|
+
exports.MORPHO_BLUE_ETH_USDC_860_ARB = MORPHO_BLUE_ETH_USDC_860_ARB;
|
|
911
|
+
const MORPHO_BLUE_SUSDS_USDC_945_ARB = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
912
|
+
chainIds: [common_1.NetworkNumber.Arb],
|
|
913
|
+
label: 'Morpho',
|
|
914
|
+
shortLabel: 'sUSDS/USDC',
|
|
915
|
+
value: types_1.MorphoBlueVersions.MorphoBluesUSDSUSDC_945_Arb,
|
|
916
|
+
url: 'susdsusdc-77fe2f7c',
|
|
917
|
+
loanToken: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831',
|
|
918
|
+
collateralToken: '0xdDb46999F8891663a8F2828d25298f70416d7610',
|
|
919
|
+
oracle: '0x52CC7c3b27bb61D0a83785B5344acC919F8f7124',
|
|
920
|
+
oracleType: types_1.MorphoBlueOracleType.CONTRACT_RATE,
|
|
921
|
+
irm: '0x66F30587FB8D4206918deb78ecA7d5eBbafD06DA',
|
|
922
|
+
lltv: 0.945,
|
|
923
|
+
marketId: '0x77fe2f7c2dd6f4da6bc5f445b06052ff8df55cb70cfce9afc16ec3c69a5fd3a3',
|
|
924
|
+
protocolName: 'morpho-blue',
|
|
925
|
+
});
|
|
926
|
+
exports.MORPHO_BLUE_SUSDS_USDC_945_ARB = MORPHO_BLUE_SUSDS_USDC_945_ARB;
|
|
830
927
|
const MorphoBlueMarkets = (networkId) => ({
|
|
831
928
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthUSDC]: (0, exports.MORPHO_BLUE_WSTETH_USDC)(networkId),
|
|
832
929
|
[types_1.MorphoBlueVersions.MorphoBlueSDAIUSDC]: (0, exports.MORPHO_BLUE_SDAI_USDC)(networkId),
|
|
@@ -853,6 +950,7 @@ const MorphoBlueMarkets = (networkId) => ({
|
|
|
853
950
|
[types_1.MorphoBlueVersions.MorphoBlueSyrupUSDCUSDC_915]: (0, exports.MORPHO_BLUE_SYRUPUSDC_USDC_915)(networkId),
|
|
854
951
|
[types_1.MorphoBlueVersions.MorphoBlueLBTCUSDC_860]: (0, exports.MORPHO_BLUE_LBTC_USDC_860)(networkId),
|
|
855
952
|
[types_1.MorphoBlueVersions.MorphoBlueLBTCCbBTC_945]: (0, exports.MORPHO_BLUE_LBTC_CBBTC_945)(networkId),
|
|
953
|
+
[types_1.MorphoBlueVersions.MorphoBluesUSDSUSDT_965]: (0, exports.MORPHO_BLUE_SUSDS_USDT_965)(networkId),
|
|
856
954
|
// wstETH/WETH
|
|
857
955
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_945]: (0, exports.MORPHO_BLUE_WSTETH_ETH_945)(networkId),
|
|
858
956
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_945_Exchange_Rate]: (0, exports.MORPHO_BLUE_WSTETH_ETH_945_EXCHANGE_RATE)(networkId),
|
|
@@ -886,6 +984,12 @@ const MorphoBlueMarkets = (networkId) => ({
|
|
|
886
984
|
// wstETH/WETH Base
|
|
887
985
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_945_Base]: (0, exports.MORPHO_BLUE_WSTETH_ETH_945_BASE)(networkId),
|
|
888
986
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_965_Base]: (0, exports.MORPHO_BLUE_WSTETH_ETH_965_BASE)(networkId),
|
|
987
|
+
// Arbitrum
|
|
988
|
+
[types_1.MorphoBlueVersions.MorphoBlueSyrupUSDCUSDC_915_Arb]: (0, exports.MORPHO_BLUE_SYRUPUSDC_USDC_915_ARB)(networkId),
|
|
989
|
+
[types_1.MorphoBlueVersions.MorphoBlueWBTCUSDC_860_Arb]: (0, exports.MorphoBlueWBTCUSDC_860_Arb)(networkId),
|
|
990
|
+
[types_1.MorphoBlueVersions.MorphoBlueWstEthUSDC_860_Arb]: (0, exports.MORPHO_BLUE_WSTETH_USDC_860_ARB)(networkId),
|
|
991
|
+
[types_1.MorphoBlueVersions.MorphoBlueEthUSDC_860_Arb]: (0, exports.MORPHO_BLUE_ETH_USDC_860_ARB)(networkId),
|
|
992
|
+
[types_1.MorphoBlueVersions.MorphoBluesUSDSUSDC_945_Arb]: (0, exports.MORPHO_BLUE_SUSDS_USDC_945_ARB)(networkId),
|
|
889
993
|
});
|
|
890
994
|
exports.MorphoBlueMarkets = MorphoBlueMarkets;
|
|
891
995
|
const findMorphoBlueMarket = (collateralToken, loanToken, lltv, oracle, irm, network = common_1.NetworkNumber.Eth) => {
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { SavingsData } from '../types';
|
|
2
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../types/common';
|
|
3
|
+
import * as morphoVaults from './morphoVaults';
|
|
4
|
+
import * as yearnVaults from './yearnVaults';
|
|
5
|
+
export { morphoVaults, yearnVaults, };
|
|
6
|
+
export declare const getSavingsData: (provider: EthereumProvider, network: NetworkNumber, account: EthAddress) => Promise<SavingsData>;
|
|
@@ -0,0 +1,71 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
36
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
37
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
38
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
39
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
40
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
41
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
+
exports.getSavingsData = exports.yearnVaults = exports.morphoVaults = void 0;
|
|
46
|
+
const morphoVaults = __importStar(require("./morphoVaults"));
|
|
47
|
+
exports.morphoVaults = morphoVaults;
|
|
48
|
+
const yearnVaults = __importStar(require("./yearnVaults"));
|
|
49
|
+
exports.yearnVaults = yearnVaults;
|
|
50
|
+
const getSavingsData = (provider, network, account) => __awaiter(void 0, void 0, void 0, function* () {
|
|
51
|
+
const morphoVaultsList = Object.keys(morphoVaults.morphoVaultsOptions.MORPHO_VAULTS);
|
|
52
|
+
const yearnVaultsList = Object.keys(yearnVaults.yearnVaultsOptions.YEARN_VAULTS);
|
|
53
|
+
const savingsData = {
|
|
54
|
+
morphoVaults: {},
|
|
55
|
+
yearnVaults: {},
|
|
56
|
+
};
|
|
57
|
+
yield Promise.all([
|
|
58
|
+
...morphoVaultsList.map((vaultKey) => __awaiter(void 0, void 0, void 0, function* () {
|
|
59
|
+
const vault = morphoVaults.morphoVaultsOptions.getMorphoVault(vaultKey);
|
|
60
|
+
const data = yield morphoVaults.getMorphoVaultData(provider, network, vault, account);
|
|
61
|
+
savingsData.morphoVaults[vaultKey] = data;
|
|
62
|
+
})),
|
|
63
|
+
...yearnVaultsList.map((vaultKey) => __awaiter(void 0, void 0, void 0, function* () {
|
|
64
|
+
const vault = yearnVaults.yearnVaultsOptions.getYearnVault(vaultKey);
|
|
65
|
+
const data = yield yearnVaults.getYearnVaultData(provider, network, vault, account);
|
|
66
|
+
savingsData.yearnVaults[vaultKey] = data;
|
|
67
|
+
})),
|
|
68
|
+
]);
|
|
69
|
+
return savingsData;
|
|
70
|
+
});
|
|
71
|
+
exports.getSavingsData = getSavingsData;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Client } from 'viem';
|
|
2
|
+
import * as morphoVaultsOptions from './options';
|
|
3
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
4
|
+
import { MorphoVault, SavingsVaultData } from '../../types';
|
|
5
|
+
export { morphoVaultsOptions, };
|
|
6
|
+
export declare const _getMorphoVaultData: (provider: Client, network: NetworkNumber, morphoVault: MorphoVault, account: EthAddress) => Promise<SavingsVaultData>;
|
|
7
|
+
export declare function getMorphoVaultData(provider: EthereumProvider, network: NetworkNumber, morphoVault: MorphoVault, account: EthAddress): Promise<SavingsVaultData>;
|
|
@@ -0,0 +1,108 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
36
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
37
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
38
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
39
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
40
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
41
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
45
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
46
|
+
};
|
|
47
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
48
|
+
exports._getMorphoVaultData = exports.morphoVaultsOptions = void 0;
|
|
49
|
+
exports.getMorphoVaultData = getMorphoVaultData;
|
|
50
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
51
|
+
const graphql_request_1 = require("graphql-request");
|
|
52
|
+
const tokens_1 = require("@defisaver/tokens");
|
|
53
|
+
const morphoVaultsOptions = __importStar(require("./options"));
|
|
54
|
+
exports.morphoVaultsOptions = morphoVaultsOptions;
|
|
55
|
+
const viem_1 = require("../../services/viem");
|
|
56
|
+
const contracts_1 = require("../../contracts");
|
|
57
|
+
const vaultDataQuery = (vaultAddress) => `query vaultByAddress {
|
|
58
|
+
vaultByAddress(chainId: 1, address: "${vaultAddress}") {
|
|
59
|
+
id,
|
|
60
|
+
dailyApy,
|
|
61
|
+
dailyApys {
|
|
62
|
+
apy, netApy
|
|
63
|
+
},
|
|
64
|
+
monthlyApys {
|
|
65
|
+
apy, netApy
|
|
66
|
+
},
|
|
67
|
+
liquidity {
|
|
68
|
+
underlying, usd,
|
|
69
|
+
},
|
|
70
|
+
asset {
|
|
71
|
+
priceUsd
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}`;
|
|
75
|
+
const MORPHO_BLUE_API = 'https://blue-api.morpho.org/graphql';
|
|
76
|
+
const _getMorphoVaultData = (provider, network, morphoVault, account) => __awaiter(void 0, void 0, void 0, function* () {
|
|
77
|
+
const morphoVaultContract = (0, contracts_1.getMorphoVaultContractViem)(provider, morphoVault.address);
|
|
78
|
+
const [totalAssets, shares, totalSupply, decimals, decimalsOffset, vaultData] = yield Promise.all([
|
|
79
|
+
morphoVaultContract.read.totalAssets(),
|
|
80
|
+
morphoVaultContract.read.balanceOf([account]),
|
|
81
|
+
morphoVaultContract.read.totalSupply(),
|
|
82
|
+
morphoVaultContract.read.decimals(),
|
|
83
|
+
morphoVaultContract.read.DECIMALS_OFFSET(),
|
|
84
|
+
(0, graphql_request_1.request)(MORPHO_BLUE_API, vaultDataQuery(morphoVault.address)),
|
|
85
|
+
]);
|
|
86
|
+
const supplied = new decimal_js_1.default(new decimal_js_1.default(shares.toString()).mul(new decimal_js_1.default(totalAssets.toString()).add(1)).div(new decimal_js_1.default(totalSupply.toString()).add(Math.pow(10, decimalsOffset))).div(Math.pow(10, 18))
|
|
87
|
+
.toFixed(decimals)).mul(Math.pow(10, decimalsOffset))
|
|
88
|
+
.toString();
|
|
89
|
+
const poolSize = (0, tokens_1.assetAmountInEth)(totalAssets.toString(), morphoVault.asset);
|
|
90
|
+
const liquidity = (0, tokens_1.assetAmountInEth)(vaultData.vaultByAddress.liquidity.underlying, morphoVault.asset);
|
|
91
|
+
return {
|
|
92
|
+
poolSize,
|
|
93
|
+
supplied,
|
|
94
|
+
liquidity,
|
|
95
|
+
};
|
|
96
|
+
});
|
|
97
|
+
exports._getMorphoVaultData = _getMorphoVaultData;
|
|
98
|
+
function getMorphoVaultData(provider, network, morphoVault, account) {
|
|
99
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
100
|
+
return (0, exports._getMorphoVaultData)((0, viem_1.getViemProvider)(provider, network, {
|
|
101
|
+
batch: {
|
|
102
|
+
multicall: {
|
|
103
|
+
batchSize: 2500000,
|
|
104
|
+
},
|
|
105
|
+
},
|
|
106
|
+
}), network, morphoVault, account);
|
|
107
|
+
});
|
|
108
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MorphoVault, MorphoVaultType } from '../../types';
|
|
2
|
+
export declare const MORPHO_VAULT_FLAGSHIP_ETH: MorphoVault;
|
|
3
|
+
export declare const MORPHO_VAULT_GAUNTLET_USDC_CORE: MorphoVault;
|
|
4
|
+
export declare const MORPHO_VAULT_GAUNTLET_USDC_PRIME: MorphoVault;
|
|
5
|
+
export declare const MORPHO_VAULT_RE7_WETH: MorphoVault;
|
|
6
|
+
export declare const MORPHO_VAULT_GAUNTLET_WETH_CORE: MorphoVault;
|
|
7
|
+
export declare const MORPHO_VAULT_GAUNTLET_WETH_PRIME: MorphoVault;
|
|
8
|
+
export declare const MORPHO_VAULT_BOOSTED_USDC: MorphoVault;
|
|
9
|
+
export declare const MORPHO_VAULT_STEAKHOUSE_PYUSD: MorphoVault;
|
|
10
|
+
export declare const MORPHO_VAULT_FLAGSHIP_USDT: MorphoVault;
|
|
11
|
+
export declare const MORPHO_VAULT_STEAKHOUSE_USDT: MorphoVault;
|
|
12
|
+
export declare const MORPHO_VAULT_GAUNTLET_USDA_CORE: MorphoVault;
|
|
13
|
+
export declare const MORPHO_VAULT_GAUNTLET_USDT_PRIME: MorphoVault;
|
|
14
|
+
export declare const MORPHO_VAULT_GAUNTLET_RESOLV_USDC: MorphoVault;
|
|
15
|
+
export declare const MORPHO_VAULTS: Record<MorphoVaultType, MorphoVault>;
|
|
16
|
+
export declare const getMorphoVault: (type: MorphoVaultType) => MorphoVault;
|