@defisaver/positions-sdk 0.0.166-dev → 0.0.166-dev-liquity-v2
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 +69 -69
- package/cjs/config/contracts.d.ts +3 -32
- package/cjs/config/contracts.js +3 -3
- package/cjs/contracts.d.ts +1 -1
- package/cjs/contracts.js +2 -2
- package/cjs/helpers/index.d.ts +1 -1
- package/cjs/helpers/index.js +2 -2
- package/cjs/helpers/liquityV2Helpers/index.d.ts +12 -0
- package/cjs/helpers/liquityV2Helpers/index.js +53 -0
- package/cjs/index.d.ts +2 -2
- package/cjs/index.js +3 -3
- package/cjs/liquityV2/index.d.ts +10 -0
- package/cjs/liquityV2/index.js +94 -0
- package/cjs/markets/compound/marketsAssets.js +3 -3
- package/cjs/markets/index.d.ts +1 -1
- package/cjs/markets/index.js +3 -3
- package/cjs/markets/liquityV2/index.d.ts +8 -0
- package/cjs/markets/liquityV2/index.js +34 -0
- package/cjs/markets/morphoBlue/index.d.ts +4 -0
- package/cjs/markets/morphoBlue/index.js +36 -1
- package/cjs/markets/spark/marketAssets.js +1 -1
- package/cjs/services/utils.d.ts +0 -2
- package/cjs/services/utils.js +1 -4
- package/cjs/staking/staking.d.ts +1 -0
- package/cjs/staking/staking.js +31 -2
- package/cjs/types/contracts/generated/LiquityV2View.d.ts +222 -0
- package/cjs/types/contracts/generated/index.d.ts +1 -1
- package/cjs/types/index.d.ts +1 -1
- package/cjs/types/index.js +1 -1
- package/cjs/types/liquityV2.d.ts +73 -0
- package/cjs/types/liquityV2.js +8 -0
- package/cjs/types/morphoBlue.d.ts +3 -1
- package/cjs/types/morphoBlue.js +2 -0
- package/esm/config/contracts.d.ts +3 -32
- package/esm/config/contracts.js +3 -3
- package/esm/contracts.d.ts +1 -1
- package/esm/contracts.js +1 -1
- package/esm/helpers/index.d.ts +1 -1
- package/esm/helpers/index.js +1 -1
- package/esm/helpers/liquityV2Helpers/index.d.ts +12 -0
- package/esm/helpers/liquityV2Helpers/index.js +45 -0
- package/esm/index.d.ts +2 -2
- package/esm/index.js +2 -2
- package/esm/liquityV2/index.d.ts +10 -0
- package/esm/liquityV2/index.js +86 -0
- package/esm/markets/compound/marketsAssets.js +3 -3
- package/esm/markets/index.d.ts +1 -1
- package/esm/markets/index.js +1 -1
- package/esm/markets/liquityV2/index.d.ts +8 -0
- package/esm/markets/liquityV2/index.js +28 -0
- package/esm/markets/morphoBlue/index.d.ts +4 -0
- package/esm/markets/morphoBlue/index.js +33 -0
- package/esm/markets/spark/marketAssets.js +1 -1
- package/esm/services/utils.d.ts +0 -2
- package/esm/services/utils.js +0 -2
- package/esm/staking/staking.d.ts +1 -0
- package/esm/staking/staking.js +29 -1
- package/esm/types/contracts/generated/LiquityV2View.d.ts +222 -0
- package/esm/types/contracts/generated/index.d.ts +1 -1
- package/esm/types/index.d.ts +1 -1
- package/esm/types/index.js +1 -1
- package/esm/types/liquityV2.d.ts +73 -0
- package/esm/types/liquityV2.js +5 -0
- package/esm/types/morphoBlue.d.ts +3 -1
- package/esm/types/morphoBlue.js +2 -0
- package/package.json +49 -44
- package/src/aaveV2/index.ts +227 -227
- package/src/aaveV3/index.ts +590 -590
- package/src/assets/index.ts +60 -60
- package/src/chickenBonds/index.ts +123 -123
- package/src/compoundV2/index.ts +219 -219
- package/src/compoundV3/index.ts +281 -281
- package/src/config/contracts.js +1040 -1040
- package/src/constants/index.ts +6 -6
- package/src/contracts.ts +130 -130
- package/src/curveUsd/index.ts +229 -229
- package/src/exchange/index.ts +17 -17
- package/src/helpers/aaveHelpers/index.ts +194 -194
- package/src/helpers/chickenBondsHelpers/index.ts +23 -23
- package/src/helpers/compoundHelpers/index.ts +246 -246
- package/src/helpers/curveUsdHelpers/index.ts +40 -40
- package/src/helpers/index.ts +9 -9
- package/src/helpers/liquityV2Helpers/index.ts +69 -0
- package/src/helpers/llamaLendHelpers/index.ts +53 -53
- package/src/helpers/makerHelpers/index.ts +94 -94
- package/src/helpers/morphoBlueHelpers/index.ts +115 -115
- package/src/helpers/sparkHelpers/index.ts +150 -150
- package/src/index.ts +48 -48
- package/src/liquity/index.ts +116 -116
- package/src/liquityV2/index.ts +111 -0
- package/src/llamaLend/index.ts +275 -275
- package/src/maker/index.ts +117 -117
- package/src/markets/aave/index.ts +152 -152
- package/src/markets/aave/marketAssets.ts +46 -46
- package/src/markets/compound/index.ts +173 -173
- package/src/markets/compound/marketsAssets.ts +64 -64
- package/src/markets/curveUsd/index.ts +69 -69
- package/src/markets/index.ts +23 -24
- package/src/markets/liquityV2/index.ts +31 -0
- package/src/markets/llamaLend/contractAddresses.ts +141 -141
- package/src/markets/llamaLend/index.ts +235 -235
- package/src/markets/morphoBlue/index.ts +728 -691
- package/src/markets/spark/index.ts +29 -29
- package/src/markets/spark/marketAssets.ts +10 -10
- package/src/moneymarket/moneymarketCommonService.ts +80 -80
- package/src/morphoAaveV2/index.ts +256 -256
- package/src/morphoAaveV3/index.ts +630 -630
- package/src/morphoBlue/index.ts +171 -171
- package/src/multicall/index.ts +22 -22
- package/src/services/dsrService.ts +15 -15
- package/src/services/priceService.ts +21 -21
- package/src/services/utils.ts +54 -57
- package/src/setup.ts +8 -8
- package/src/spark/index.ts +424 -424
- package/src/staking/staking.ts +218 -189
- package/src/types/aave.ts +262 -262
- package/src/types/chickenBonds.ts +45 -45
- package/src/types/common.ts +84 -84
- package/src/types/compound.ts +129 -129
- package/src/types/contracts/generated/LiquityV2View.ts +280 -0
- package/src/types/contracts/generated/index.ts +1 -1
- package/src/types/curveUsd.ts +118 -118
- package/src/types/index.ts +10 -10
- package/src/types/liquity.ts +30 -30
- package/src/types/liquityV2.ts +79 -0
- package/src/types/llamaLend.ts +155 -155
- package/src/types/maker.ts +50 -50
- package/src/types/morphoBlue.ts +146 -144
- package/src/types/spark.ts +127 -127
- package/cjs/eulerV2/index.d.ts +0 -40
- package/cjs/eulerV2/index.js +0 -207
- package/cjs/helpers/eulerHelpers/index.d.ts +0 -27
- package/cjs/helpers/eulerHelpers/index.js +0 -232
- package/cjs/markets/euler/index.d.ts +0 -10
- package/cjs/markets/euler/index.js +0 -41
- package/cjs/types/contracts/generated/EulerV2View.d.ts +0 -333
- package/cjs/types/euler.d.ts +0 -148
- package/cjs/types/euler.js +0 -15
- package/esm/eulerV2/index.d.ts +0 -40
- package/esm/eulerV2/index.js +0 -199
- package/esm/helpers/eulerHelpers/index.d.ts +0 -27
- package/esm/helpers/eulerHelpers/index.js +0 -219
- package/esm/markets/euler/index.d.ts +0 -10
- package/esm/markets/euler/index.js +0 -34
- package/esm/types/contracts/generated/EulerV2View.d.ts +0 -333
- package/esm/types/euler.d.ts +0 -148
- package/esm/types/euler.js +0 -12
- package/src/eulerV2/index.ts +0 -286
- package/src/helpers/eulerHelpers/index.ts +0 -231
- package/src/markets/euler/index.ts +0 -38
- package/src/types/contracts/generated/EulerV2View.ts +0 -434
- package/src/types/euler.ts +0 -171
- /package/cjs/types/contracts/generated/{EulerV2View.js → LiquityV2View.js} +0 -0
- /package/esm/types/contracts/generated/{EulerV2View.js → LiquityV2View.js} +0 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.getLiquityV2TroveData = exports.getLiquityV2MarketData = void 0;
|
|
16
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
17
|
+
const tokens_1 = require("@defisaver/tokens");
|
|
18
|
+
const contracts_1 = require("../contracts");
|
|
19
|
+
const types_1 = require("../types");
|
|
20
|
+
const staking_1 = require("../staking");
|
|
21
|
+
const liquityV2Helpers_1 = require("../helpers/liquityV2Helpers");
|
|
22
|
+
const utils_1 = require("../services/utils");
|
|
23
|
+
const getLiquityV2MarketData = (web3, network, selectedMarket, mainnetWeb3) => __awaiter(void 0, void 0, void 0, function* () {
|
|
24
|
+
const viewContract = (0, contracts_1.LiquityV2ViewContract)(web3, network);
|
|
25
|
+
const { marketAddress, debtToken, collateralToken } = selectedMarket;
|
|
26
|
+
const data = yield viewContract.methods.getMarketData(marketAddress).call();
|
|
27
|
+
const assetsData = {};
|
|
28
|
+
assetsData[debtToken] = {
|
|
29
|
+
symbol: debtToken,
|
|
30
|
+
address: (0, tokens_1.getAssetInfo)(debtToken, network).address,
|
|
31
|
+
price: '1',
|
|
32
|
+
totalSupply: '0',
|
|
33
|
+
totalBorrow: (0, tokens_1.assetAmountInEth)(data.entireSystemDebt),
|
|
34
|
+
canBeSupplied: false,
|
|
35
|
+
canBeBorrowed: true,
|
|
36
|
+
};
|
|
37
|
+
assetsData[collateralToken] = {
|
|
38
|
+
symbol: collateralToken,
|
|
39
|
+
address: (0, tokens_1.getAssetInfo)((0, utils_1.ethToWeth)(collateralToken), network).address,
|
|
40
|
+
price: (0, tokens_1.assetAmountInEth)(data.collPrice),
|
|
41
|
+
totalSupply: (0, tokens_1.assetAmountInEth)(data.entireSystemColl),
|
|
42
|
+
totalBorrow: '0',
|
|
43
|
+
canBeSupplied: true,
|
|
44
|
+
canBeBorrowed: false,
|
|
45
|
+
};
|
|
46
|
+
if (staking_1.STAKING_ASSETS.includes(collateralToken)) {
|
|
47
|
+
assetsData[collateralToken].incentiveSupplyApy = yield (0, staking_1.getStakingApy)(collateralToken, mainnetWeb3);
|
|
48
|
+
assetsData[collateralToken].incentiveSupplyToken = collateralToken;
|
|
49
|
+
}
|
|
50
|
+
const minRatio = new decimal_js_1.default(data.MCR).div(1e16).toString();
|
|
51
|
+
return { assetsData, marketData: { minRatio } };
|
|
52
|
+
});
|
|
53
|
+
exports.getLiquityV2MarketData = getLiquityV2MarketData;
|
|
54
|
+
const getLiquityV2TroveData = (web3, network, { selectedMarket, assetsData, marketData, troveId, }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
55
|
+
const viewContract = (0, contracts_1.LiquityV2ViewContract)(web3, network);
|
|
56
|
+
const { minRatio } = marketData;
|
|
57
|
+
const { collateralToken, marketAddress, debtToken } = selectedMarket;
|
|
58
|
+
const data = yield viewContract.methods.getTroveInfo(marketAddress, troveId).call();
|
|
59
|
+
const usedAssets = {};
|
|
60
|
+
const debtAssetData = assetsData[debtToken];
|
|
61
|
+
const borrowed = (0, tokens_1.assetAmountInEth)(data.debtAmount);
|
|
62
|
+
usedAssets[debtToken] = {
|
|
63
|
+
symbol: debtToken,
|
|
64
|
+
address: debtAssetData.address,
|
|
65
|
+
price: debtAssetData.price,
|
|
66
|
+
supplied: '0',
|
|
67
|
+
suppliedUsd: '0',
|
|
68
|
+
borrowed,
|
|
69
|
+
borrowedUsd: new decimal_js_1.default(borrowed).mul(debtAssetData.price).toString(),
|
|
70
|
+
};
|
|
71
|
+
const collAssetData = assetsData[collateralToken];
|
|
72
|
+
const suppliedColl = (0, tokens_1.assetAmountInEth)(data.collAmount);
|
|
73
|
+
usedAssets[collateralToken] = {
|
|
74
|
+
symbol: collateralToken,
|
|
75
|
+
address: collAssetData.address,
|
|
76
|
+
price: collAssetData.price,
|
|
77
|
+
supplied: suppliedColl,
|
|
78
|
+
suppliedUsd: new decimal_js_1.default(suppliedColl).mul(collAssetData.price).toString(),
|
|
79
|
+
borrowed: '0',
|
|
80
|
+
borrowedUsd: '0',
|
|
81
|
+
};
|
|
82
|
+
const ratio = new decimal_js_1.default(data.TCRatio).div(1e16).toString();
|
|
83
|
+
const interestRate = new decimal_js_1.default(data.annualInterestRate).div(1e16).toString();
|
|
84
|
+
const interestBatchManager = data.interestBatchManager;
|
|
85
|
+
const payload = Object.assign({ usedAssets,
|
|
86
|
+
troveId,
|
|
87
|
+
ratio,
|
|
88
|
+
interestRate,
|
|
89
|
+
interestBatchManager, troveStatus: types_1.LIQUITY_TROVE_STATUS_ENUM[parseInt(data.status, 10)] }, (0, liquityV2Helpers_1.getLiquityV2AggregatedPositionData)({
|
|
90
|
+
usedAssets, assetsData, minRatio, interestRate,
|
|
91
|
+
}));
|
|
92
|
+
return payload;
|
|
93
|
+
});
|
|
94
|
+
exports.getLiquityV2TroveData = getLiquityV2TroveData;
|
|
@@ -7,7 +7,7 @@ exports.compoundV2CollateralAssets = [
|
|
|
7
7
|
'cETH', 'cDAI', 'cBAT', 'cZRX', 'cUSDC', 'cWBTC Legacy', 'cWBTC', 'cUSDT',
|
|
8
8
|
'cTUSD', 'cLINK', 'cUSDP', 'cUNI', 'cCOMP', 'cMKR', 'cSUSHI', 'cAAVE', 'cYFI',
|
|
9
9
|
].map((symbol) => (0, tokens_1.getAssetInfo)(symbol));
|
|
10
|
-
exports.v3USDCCollAssetsEth = ['COMP', 'WBTC', 'ETH', 'UNI', 'LINK', 'wstETH', 'cbBTC', '
|
|
10
|
+
exports.v3USDCCollAssetsEth = ['COMP', 'WBTC', 'ETH', 'UNI', 'LINK', 'wstETH', 'cbBTC', 'tBTC'];
|
|
11
11
|
exports.v3USDCCollAssetsArb = ['ARB', 'ETH', 'GMX', 'WBTC', 'wstETH', 'ezETH'];
|
|
12
12
|
exports.v3USDCCollAssetsBase = ['ETH', 'cbETH', 'wstETH', 'cbBTC'];
|
|
13
13
|
exports.v3USDCCollAssetsOpt = ['ETH', 'OP', 'WBTC', 'wstETH'];
|
|
@@ -26,7 +26,7 @@ exports.v3USDCeCollAssets = {
|
|
|
26
26
|
[common_1.NetworkNumber.Arb]: exports.v3USDCeCollAssetsArb,
|
|
27
27
|
[common_1.NetworkNumber.Base]: [],
|
|
28
28
|
};
|
|
29
|
-
exports.v3ETHCollAssetsEth = ['cbETH', 'wstETH', 'rETH', 'rsETH', 'weETH', 'osETH', 'WBTC', 'ezETH', 'cbBTC', 'rswETH'];
|
|
29
|
+
exports.v3ETHCollAssetsEth = ['cbETH', 'wstETH', 'rETH', 'rsETH', 'weETH', 'osETH', 'WBTC', 'ezETH', 'cbBTC', 'rswETH', 'tBTC'];
|
|
30
30
|
exports.v3ETHCollAssetsBase = ['cbETH', 'ezETH', 'wstETH', 'USDC', 'weETH', 'wrsETH', 'cbBTC'];
|
|
31
31
|
exports.v3ETHCollAssetsArb = ['weETH', 'rETH', 'wstETH', 'WBTC', 'rsETH', 'ezETH', 'USDC', 'USDT'];
|
|
32
32
|
exports.v3ETHCollAssetsOpt = ['rETH', 'wstETH', 'WBTC', 'ezETH', 'USDC', 'USDT', 'weETH', 'wrsETH'];
|
|
@@ -45,7 +45,7 @@ exports.v3USDbCCollAssets = {
|
|
|
45
45
|
[common_1.NetworkNumber.Arb]: [],
|
|
46
46
|
[common_1.NetworkNumber.Base]: exports.v3USDbCCollAssetsBase,
|
|
47
47
|
};
|
|
48
|
-
exports.v3USDTCollAssetsEth = ['ETH', 'WBTC', '
|
|
48
|
+
exports.v3USDTCollAssetsEth = ['COMP', 'ETH', 'WBTC', 'UNI', 'LINK', 'wstETH', 'cbBTC', 'tBTC'];
|
|
49
49
|
exports.v3USDTCollAssetsArb = ['ETH', 'WBTC', 'wstETH', 'ARB', 'GMX'];
|
|
50
50
|
exports.v3USDTCollAssetsOpt = ['ETH', 'WBTC', 'OP', 'wstETH'];
|
|
51
51
|
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
package/cjs/markets/index.d.ts
CHANGED
|
@@ -4,4 +4,4 @@ export { SparkMarkets } from './spark';
|
|
|
4
4
|
export { CrvUsdMarkets } from './curveUsd';
|
|
5
5
|
export { MorphoBlueMarkets, findMorphoBlueMarket } from './morphoBlue';
|
|
6
6
|
export { LlamaLendMarkets } from './llamaLend';
|
|
7
|
-
export {
|
|
7
|
+
export { LiquityV2Markets } from './liquityV2';
|
package/cjs/markets/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.LiquityV2Markets = exports.LlamaLendMarkets = exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = exports.CrvUsdMarkets = exports.SparkMarkets = exports.v3USDTCollAssets = exports.v3USDCeCollAssets = exports.v3USDCCollAssets = exports.v3USDbCCollAssets = exports.v3ETHCollAssets = exports.compoundV2CollateralAssets = exports.CompoundMarkets = exports.getAaveV3MarketByMarketAddress = exports.morphoAaveV3AssetEthMarket = exports.morphoAaveV2AssetDefaultMarket = exports.aaveV3AssetsDefaultMarket = exports.aaveV2AssetsDefaultMarket = exports.aaveV1AssetsDefaultMarket = exports.AaveMarkets = void 0;
|
|
4
4
|
var aave_1 = require("./aave");
|
|
5
5
|
Object.defineProperty(exports, "AaveMarkets", { enumerable: true, get: function () { return aave_1.AaveMarkets; } });
|
|
6
6
|
Object.defineProperty(exports, "aaveV1AssetsDefaultMarket", { enumerable: true, get: function () { return aave_1.aaveV1AssetsDefaultMarket; } });
|
|
@@ -26,5 +26,5 @@ Object.defineProperty(exports, "MorphoBlueMarkets", { enumerable: true, get: fun
|
|
|
26
26
|
Object.defineProperty(exports, "findMorphoBlueMarket", { enumerable: true, get: function () { return morphoBlue_1.findMorphoBlueMarket; } });
|
|
27
27
|
var llamaLend_1 = require("./llamaLend");
|
|
28
28
|
Object.defineProperty(exports, "LlamaLendMarkets", { enumerable: true, get: function () { return llamaLend_1.LlamaLendMarkets; } });
|
|
29
|
-
var
|
|
30
|
-
Object.defineProperty(exports, "
|
|
29
|
+
var liquityV2_1 = require("./liquityV2");
|
|
30
|
+
Object.defineProperty(exports, "LiquityV2Markets", { enumerable: true, get: function () { return liquityV2_1.LiquityV2Markets; } });
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NetworkNumber } from '../../types/common';
|
|
2
|
+
import { LiquityV2MarketInfo } from '../../types/liquityV2';
|
|
3
|
+
export declare const LIQUITY_V2_ETH_MARKET: (networkId?: NetworkNumber) => LiquityV2MarketInfo;
|
|
4
|
+
export declare const LIQUITY_V2_WSTETH_MARKET: (networkId?: NetworkNumber) => LiquityV2MarketInfo;
|
|
5
|
+
export declare const LiquityV2Markets: (networkId: NetworkNumber) => {
|
|
6
|
+
readonly liquityv2eth: LiquityV2MarketInfo;
|
|
7
|
+
readonly liquityv2wsteth: LiquityV2MarketInfo;
|
|
8
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LiquityV2Markets = exports.LIQUITY_V2_WSTETH_MARKET = exports.LIQUITY_V2_ETH_MARKET = void 0;
|
|
4
|
+
const common_1 = require("../../types/common");
|
|
5
|
+
const liquityV2_1 = require("../../types/liquityV2");
|
|
6
|
+
const LIQUITY_V2_ETH_MARKET = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
7
|
+
chainIds: [1],
|
|
8
|
+
label: 'Liquity V2 ETH',
|
|
9
|
+
shortLabel: 'ETH',
|
|
10
|
+
value: liquityV2_1.LiquityV2Versions.LiquityV2Eth,
|
|
11
|
+
url: 'eth',
|
|
12
|
+
debtToken: 'BOLD',
|
|
13
|
+
collateralToken: 'ETH',
|
|
14
|
+
marketAddress: '0xd7199b16945f1ebaa0b301bf3d05bf489caa408b',
|
|
15
|
+
protocolName: 'liquity-v2',
|
|
16
|
+
});
|
|
17
|
+
exports.LIQUITY_V2_ETH_MARKET = LIQUITY_V2_ETH_MARKET;
|
|
18
|
+
const LIQUITY_V2_WSTETH_MARKET = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
19
|
+
chainIds: [1],
|
|
20
|
+
label: 'Liquity V2 wstETH',
|
|
21
|
+
shortLabel: 'wstETH',
|
|
22
|
+
value: liquityV2_1.LiquityV2Versions.LiquityV2WstEth,
|
|
23
|
+
url: 'wsteth',
|
|
24
|
+
debtToken: 'BOLD',
|
|
25
|
+
collateralToken: 'wstETH',
|
|
26
|
+
marketAddress: '0x0d22113a543826eeaf2ae0fc9d10aea66efba156',
|
|
27
|
+
protocolName: 'liquity-v2',
|
|
28
|
+
});
|
|
29
|
+
exports.LIQUITY_V2_WSTETH_MARKET = LIQUITY_V2_WSTETH_MARKET;
|
|
30
|
+
const LiquityV2Markets = (networkId) => ({
|
|
31
|
+
[liquityV2_1.LiquityV2Versions.LiquityV2Eth]: (0, exports.LIQUITY_V2_ETH_MARKET)(networkId),
|
|
32
|
+
[liquityV2_1.LiquityV2Versions.LiquityV2WstEth]: (0, exports.LIQUITY_V2_WSTETH_MARKET)(networkId),
|
|
33
|
+
});
|
|
34
|
+
exports.LiquityV2Markets = LiquityV2Markets;
|
|
@@ -30,6 +30,7 @@ export declare const MORPHO_BLUE_USDE_DAI_770: (networkId?: NetworkNumber) => Mo
|
|
|
30
30
|
export declare const MORPHO_BLUE_USDE_DAI_860: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
31
31
|
export declare const MORPHO_BLUE_USDE_DAI_915: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
32
32
|
export declare const MORPHO_BLUE_USDE_DAI_945: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
33
|
+
export declare const MORPHO_BLUE_RETH_ETH_945: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
33
34
|
export declare const MORPHO_BLUE_CBETH_USDC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
34
35
|
export declare const MORPHO_BLUE_WSTETH_ETH_945_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
35
36
|
export declare const MORPHO_BLUE_WSTETH_ETH_965_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
@@ -41,6 +42,7 @@ export declare const MORPHO_BLUE_RETH_USDC_860_BASE: (networkId?: NetworkNumber)
|
|
|
41
42
|
export declare const MORPHO_BLUE_RETH_ETH_945_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
42
43
|
export declare const MORPHO_BLUE_CBBTC_ETH_915_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
43
44
|
export declare const MORPHO_BLUE_CBBTC_USDC_860_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
45
|
+
export declare const MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE: (networkId?: NetworkNumber) => MorphoBlueMarketData;
|
|
44
46
|
export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
45
47
|
readonly morphobluewstethusdc: MorphoBlueMarketData;
|
|
46
48
|
readonly morphobluesdaiusdc: MorphoBlueMarketData;
|
|
@@ -61,6 +63,7 @@ export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
|
61
63
|
readonly morphobluetbtcusdc: MorphoBlueMarketData;
|
|
62
64
|
readonly morphobluecbbtceth: MorphoBlueMarketData;
|
|
63
65
|
readonly morphobluecbbtcusdc: MorphoBlueMarketData;
|
|
66
|
+
readonly morphoblueretheth_945: MorphoBlueMarketData;
|
|
64
67
|
readonly morphobluewstetheth_945: MorphoBlueMarketData;
|
|
65
68
|
readonly morphobluewstetheth_945_exchange_rate: MorphoBlueMarketData;
|
|
66
69
|
readonly morphobluewstetheth_965_exchange_rate: MorphoBlueMarketData;
|
|
@@ -79,6 +82,7 @@ export declare const MorphoBlueMarkets: (networkId: NetworkNumber) => {
|
|
|
79
82
|
readonly morphoblueretheth_945_base: MorphoBlueMarketData;
|
|
80
83
|
readonly morphobluecbbtceth_915_base: MorphoBlueMarketData;
|
|
81
84
|
readonly morphobluecbbtcusdc_860_base: MorphoBlueMarketData;
|
|
85
|
+
readonly morphobluewsuperoethbweth_915_base: MorphoBlueMarketData;
|
|
82
86
|
readonly morphobluecbetheth_945_base: MorphoBlueMarketData;
|
|
83
87
|
readonly morphobluecbetheth_965_base: MorphoBlueMarketData;
|
|
84
88
|
readonly morphobluewstetheth_945_base: MorphoBlueMarketData;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = 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_ETH_965_BASE = exports.MORPHO_BLUE_WSTETH_ETH_945_BASE = exports.MORPHO_BLUE_CBETH_USDC_860_BASE = exports.MORPHO_BLUE_USDE_DAI_945 = exports.MORPHO_BLUE_USDE_DAI_915 = exports.MORPHO_BLUE_USDE_DAI_860 = exports.MORPHO_BLUE_USDE_DAI_770 = exports.MORPHO_BLUE_SUSDE_DAI_945 = exports.MORPHO_BLUE_SUSDE_DAI_915 = exports.MORPHO_BLUE_SUSDE_DAI_860 = exports.MORPHO_BLUE_SUSDE_DAI_770 = 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_CBBTC_USDC_860 = exports.MORPHO_BLUE_CBBTC_ETH_915 = exports.MORPHO_BLUE_TBTC_USDC = exports.MORPHO_BLUE_MKR_USDC = exports.MORPHO_BLUE_EZETH_ETH = exports.MORPHO_BLUE_SDAI_ETH = exports.MORPHO_BLUE_SUSDE_USDT = exports.MORPHO_BLUE_USDE_USDT = exports.MORPHO_BLUE_WEETH_ETH = 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;
|
|
3
|
+
exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = 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_ETH_965_BASE = exports.MORPHO_BLUE_WSTETH_ETH_945_BASE = exports.MORPHO_BLUE_CBETH_USDC_860_BASE = exports.MORPHO_BLUE_RETH_ETH_945 = exports.MORPHO_BLUE_USDE_DAI_945 = exports.MORPHO_BLUE_USDE_DAI_915 = exports.MORPHO_BLUE_USDE_DAI_860 = exports.MORPHO_BLUE_USDE_DAI_770 = exports.MORPHO_BLUE_SUSDE_DAI_945 = exports.MORPHO_BLUE_SUSDE_DAI_915 = exports.MORPHO_BLUE_SUSDE_DAI_860 = exports.MORPHO_BLUE_SUSDE_DAI_770 = 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_CBBTC_USDC_860 = exports.MORPHO_BLUE_CBBTC_ETH_915 = exports.MORPHO_BLUE_TBTC_USDC = exports.MORPHO_BLUE_MKR_USDC = exports.MORPHO_BLUE_EZETH_ETH = exports.MORPHO_BLUE_SDAI_ETH = exports.MORPHO_BLUE_SUSDE_USDT = exports.MORPHO_BLUE_USDE_USDT = exports.MORPHO_BLUE_WEETH_ETH = 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
4
|
const utils_1 = require("../../services/utils");
|
|
5
5
|
const types_1 = require("../../types");
|
|
6
6
|
const common_1 = require("../../types/common");
|
|
@@ -487,6 +487,22 @@ const MORPHO_BLUE_USDE_DAI_945 = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
|
487
487
|
protocolName: 'morpho-blue',
|
|
488
488
|
});
|
|
489
489
|
exports.MORPHO_BLUE_USDE_DAI_945 = MORPHO_BLUE_USDE_DAI_945;
|
|
490
|
+
const MORPHO_BLUE_RETH_ETH_945 = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
491
|
+
chainIds: [1],
|
|
492
|
+
label: 'Morpho',
|
|
493
|
+
shortLabel: 'rETH/ETH',
|
|
494
|
+
value: types_1.MorphoBlueVersions.MorphoBlueREthEth_945,
|
|
495
|
+
url: 'retheth-3c83f77b',
|
|
496
|
+
loanToken: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
|
|
497
|
+
collateralToken: '0xae78736Cd615f374D3085123A210448E74Fc6393',
|
|
498
|
+
oracle: '0x1b4A3F92e5Fffd1d35A98751c9FE4472483579bB',
|
|
499
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
500
|
+
irm: '0x870aC11D48B15DB9a138Cf899d20F13F79Ba00BC',
|
|
501
|
+
lltv: 0.945,
|
|
502
|
+
marketId: '0x3c83f77bde9541f8d3d82533b19bbc1f97eb2f1098bb991728acbfbede09cc5d',
|
|
503
|
+
protocolName: 'morpho-blue',
|
|
504
|
+
});
|
|
505
|
+
exports.MORPHO_BLUE_RETH_ETH_945 = MORPHO_BLUE_RETH_ETH_945;
|
|
490
506
|
// BASE
|
|
491
507
|
const MORPHO_BLUE_CBETH_USDC_860_BASE = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
492
508
|
chainIds: [common_1.NetworkNumber.Base],
|
|
@@ -664,6 +680,22 @@ const MORPHO_BLUE_CBBTC_USDC_860_BASE = (networkId = common_1.NetworkNumber.Eth)
|
|
|
664
680
|
protocolName: 'morpho-blue',
|
|
665
681
|
});
|
|
666
682
|
exports.MORPHO_BLUE_CBBTC_USDC_860_BASE = MORPHO_BLUE_CBBTC_USDC_860_BASE;
|
|
683
|
+
const MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE = (networkId = common_1.NetworkNumber.Eth) => ({
|
|
684
|
+
chainIds: [common_1.NetworkNumber.Base],
|
|
685
|
+
label: 'Morpho',
|
|
686
|
+
shortLabel: 'wsuperOETHb/WETH',
|
|
687
|
+
value: types_1.MorphoBlueVersions.MorphoBlueWsuperOETHbWETH_915_Base,
|
|
688
|
+
url: 'wsuperoethbweth-144bf18d',
|
|
689
|
+
loanToken: '0x4200000000000000000000000000000000000006',
|
|
690
|
+
collateralToken: '0x7FcD174E80f264448ebeE8c88a7C4476AAF58Ea6',
|
|
691
|
+
oracle: '0x28C964c985fe84736fAdc7Cf0bBd58B54bc7CF93',
|
|
692
|
+
oracleType: types_1.MorphoBlueOracleType.MARKET_RATE,
|
|
693
|
+
irm: '0x46415998764C29aB2a25CbeA6254146D50D22687',
|
|
694
|
+
lltv: 0.915,
|
|
695
|
+
marketId: '0x144bf18d6bf4c59602548a825034f73bf1d20177fc5f975fc69d5a5eba929b45',
|
|
696
|
+
protocolName: 'morpho-blue',
|
|
697
|
+
});
|
|
698
|
+
exports.MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE = MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE;
|
|
667
699
|
const MorphoBlueMarkets = (networkId) => ({
|
|
668
700
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthUSDC]: (0, exports.MORPHO_BLUE_WSTETH_USDC)(networkId),
|
|
669
701
|
[types_1.MorphoBlueVersions.MorphoBlueSDAIUSDC]: (0, exports.MORPHO_BLUE_SDAI_USDC)(networkId),
|
|
@@ -684,6 +716,7 @@ const MorphoBlueMarkets = (networkId) => ({
|
|
|
684
716
|
[types_1.MorphoBlueVersions.MorphoBlueTBTCUSDC]: (0, exports.MORPHO_BLUE_TBTC_USDC)(networkId),
|
|
685
717
|
[types_1.MorphoBlueVersions.MorphoBlueCbBTCEth_915]: (0, exports.MORPHO_BLUE_CBBTC_ETH_915)(networkId),
|
|
686
718
|
[types_1.MorphoBlueVersions.MorphoBlueCbBTCUSDC_860]: (0, exports.MORPHO_BLUE_CBBTC_USDC_860)(networkId),
|
|
719
|
+
[types_1.MorphoBlueVersions.MorphoBlueREthEth_945]: (0, exports.MORPHO_BLUE_RETH_ETH_945)(networkId),
|
|
687
720
|
// wstETH/WETH
|
|
688
721
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_945]: (0, exports.MORPHO_BLUE_WSTETH_ETH_945)(networkId),
|
|
689
722
|
[types_1.MorphoBlueVersions.MorphoBlueWstEthEth_945_Exchange_Rate]: (0, exports.MORPHO_BLUE_WSTETH_ETH_945_EXCHANGE_RATE)(networkId),
|
|
@@ -706,6 +739,8 @@ const MorphoBlueMarkets = (networkId) => ({
|
|
|
706
739
|
[types_1.MorphoBlueVersions.MorphoBlueREthEth_945_Base]: (0, exports.MORPHO_BLUE_RETH_ETH_945_BASE)(networkId),
|
|
707
740
|
[types_1.MorphoBlueVersions.MorphoBlueCbBTCEth_915_Base]: (0, exports.MORPHO_BLUE_CBBTC_ETH_915_BASE)(networkId),
|
|
708
741
|
[types_1.MorphoBlueVersions.MorphoBlueCbBTCUSDC_860_Base]: (0, exports.MORPHO_BLUE_CBBTC_USDC_860_BASE)(networkId),
|
|
742
|
+
// wsuperOETHb/WETH Base
|
|
743
|
+
[types_1.MorphoBlueVersions.MorphoBlueWsuperOETHbWETH_915_Base]: (0, exports.MORPHO_BLUE_WSUPEROETHB_WETH_915_BASE)(networkId),
|
|
709
744
|
// cbETH/WETH Base
|
|
710
745
|
[types_1.MorphoBlueVersions.MorphoBlueCbEthEth_945_Base]: (0, exports.MORPHO_BLUE_CBETH_ETH_945_BASE)(networkId),
|
|
711
746
|
[types_1.MorphoBlueVersions.MorphoBlueCbEthEth_965_Base]: (0, exports.MORPHO_BLUE_CBETH_ETH_965_BASE)(networkId),
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.sparkAssetsDefaultMarket = exports.sparkAssetsDefaultMarketEth = void 0;
|
|
4
4
|
const common_1 = require("../../types/common");
|
|
5
|
-
exports.sparkAssetsDefaultMarketEth = ['DAI', 'sDAI', 'USDC', 'ETH', 'wstETH', 'WBTC', 'GNO', 'rETH', 'USDT', 'weETH', 'cbBTC'];
|
|
5
|
+
exports.sparkAssetsDefaultMarketEth = ['DAI', 'sDAI', 'USDC', 'ETH', 'wstETH', 'WBTC', 'GNO', 'rETH', 'USDT', 'weETH', 'cbBTC', 'sUSDS'];
|
|
6
6
|
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
7
7
|
exports.sparkAssetsDefaultMarket = {
|
|
8
8
|
[common_1.NetworkNumber.Eth]: exports.sparkAssetsDefaultMarketEth,
|
package/cjs/services/utils.d.ts
CHANGED
|
@@ -20,5 +20,3 @@ export declare const bytesToString: (hex: string) => string;
|
|
|
20
20
|
*/
|
|
21
21
|
export declare const mapRange: (input: number | string, minInput: number | string, maxInput: number | string, minOutput: number | string, maxOutput: number | string) => number;
|
|
22
22
|
export declare const isEnabledOnBitmap: (bitmap: number, assetId: number) => bigint;
|
|
23
|
-
export declare const MAXUINT: string;
|
|
24
|
-
export declare const isMaxuint: (amount: string) => boolean;
|
package/cjs/services/utils.js
CHANGED
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
6
|
+
exports.isEnabledOnBitmap = exports.mapRange = exports.bytesToString = exports.ethToWethByAddress = exports.wethToEthByAddress = exports.handleWbtcLegacy = exports.getEthAmountForDecimals = exports.getWeiAmountForDecimals = exports.compareAddresses = exports.isAddress = exports.ADDRESS_REGEX = exports.getAbiItem = exports.wstEthToStEth = exports.stEthToWstEth = exports.wethToEth = exports.ethToWeth = exports.addToObjectIf = exports.isLayer2Network = void 0;
|
|
7
7
|
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
8
8
|
const tokens_1 = require("@defisaver/tokens");
|
|
9
9
|
const common_1 = require("../types/common");
|
|
@@ -56,6 +56,3 @@ exports.mapRange = mapRange;
|
|
|
56
56
|
// eslint-disable-next-line no-bitwise
|
|
57
57
|
const isEnabledOnBitmap = (bitmap, assetId) => (BigInt(bitmap) >> BigInt(assetId)) & BigInt(1);
|
|
58
58
|
exports.isEnabledOnBitmap = isEnabledOnBitmap;
|
|
59
|
-
exports.MAXUINT = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
|
|
60
|
-
const isMaxuint = (amount) => (0, exports.compareAddresses)(exports.MAXUINT, amount);
|
|
61
|
-
exports.isMaxuint = isMaxuint;
|
package/cjs/staking/staking.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ export declare const getStETHApr: (web3: Web3, fromBlock?: number, blockNumber?:
|
|
|
4
4
|
export declare const getCbETHApr: (web3: Web3, blockNumber?: 'latest' | number) => Promise<string>;
|
|
5
5
|
export declare const getREthApr: (web3: Web3, blockNumber?: 'latest' | number) => Promise<string>;
|
|
6
6
|
export declare const getDsrApy: (web3: Web3, blockNumber?: 'latest' | number) => Promise<string>;
|
|
7
|
+
export declare const getSsrApy: () => Promise<string>;
|
|
7
8
|
export declare const STAKING_ASSETS: string[];
|
|
8
9
|
export declare const getStakingApy: (asset: string, web3: Web3, blockNumber?: 'latest' | number, fromBlock?: number | undefined) => Promise<any> | "0" | undefined;
|
|
9
10
|
export declare const calculateInterestEarned: (principal: string, interest: string, type: string, apy?: boolean) => number;
|
package/cjs/staking/staking.js
CHANGED
|
@@ -12,7 +12,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.getStETHByWstETHMultiple = exports.getStETHByWstETH = exports.getWstETHByStETH = exports.calculateNetApy = exports.calculateInterestEarned = exports.getStakingApy = exports.STAKING_ASSETS = exports.getDsrApy = exports.getREthApr = exports.getCbETHApr = exports.getStETHApr = void 0;
|
|
15
|
+
exports.getStETHByWstETHMultiple = exports.getStETHByWstETH = exports.getWstETHByStETH = exports.calculateNetApy = exports.calculateInterestEarned = exports.getStakingApy = exports.STAKING_ASSETS = exports.getSsrApy = exports.getDsrApy = exports.getREthApr = exports.getCbETHApr = exports.getStETHApr = void 0;
|
|
16
16
|
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
17
17
|
const contracts_1 = require("../contracts");
|
|
18
18
|
const common_1 = require("../types/common");
|
|
@@ -86,13 +86,38 @@ const getDsrApy = (web3, blockNumber = 'latest') => __awaiter(void 0, void 0, vo
|
|
|
86
86
|
.toString();
|
|
87
87
|
});
|
|
88
88
|
exports.getDsrApy = getDsrApy;
|
|
89
|
+
const getSsrApy = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
90
|
+
const res = yield fetch('https://app.defisaver.com/api/sky/data');
|
|
91
|
+
const data = yield res.json();
|
|
92
|
+
return new decimal_js_1.default(data.data.skyData[0].sky_savings_rate_apy).mul(100).toString();
|
|
93
|
+
});
|
|
94
|
+
exports.getSsrApy = getSsrApy;
|
|
95
|
+
const getSuperOETHApy = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
96
|
+
console.log('getSuperOETHApy');
|
|
97
|
+
const res = yield fetch('https://origin.squids.live/origin-squid/graphql', {
|
|
98
|
+
method: 'POST',
|
|
99
|
+
headers: {
|
|
100
|
+
'Content-Type': 'application/json',
|
|
101
|
+
},
|
|
102
|
+
body: JSON.stringify({
|
|
103
|
+
query: '\n query OTokenApy($chainId: Int!, $token: String!) {\n oTokenApies(\n limit: 1\n orderBy: timestamp_DESC\n where: {chainId_eq: $chainId, otoken_containsInsensitive: $token}\n ) {\n apy7DayAvg\n apy14DayAvg\n apy30DayAvg\n apr\n apy\n }\n}\n ',
|
|
104
|
+
variables: {
|
|
105
|
+
token: '0xdbfefd2e8460a6ee4955a68582f85708baea60a3',
|
|
106
|
+
chainId: 8453,
|
|
107
|
+
},
|
|
108
|
+
}),
|
|
109
|
+
});
|
|
110
|
+
const data = yield res.json();
|
|
111
|
+
return new decimal_js_1.default(data.data.oTokenApies[0].apy).mul(100).toString();
|
|
112
|
+
});
|
|
89
113
|
const getApyFromDfsApi = (asset) => __awaiter(void 0, void 0, void 0, function* () {
|
|
90
114
|
const res = yield fetch(`https://app.defisaver.com/api/staking/apy?asset=${asset}`);
|
|
91
115
|
const data = yield res.json();
|
|
92
116
|
return data.apy;
|
|
93
117
|
});
|
|
94
|
-
exports.STAKING_ASSETS = ['cbETH', 'wstETH', 'cbETH', 'rETH', 'sDAI', 'weETH', 'sUSDe', 'osETH', 'ezETH', 'ETHx', 'rsETH', 'pufETH', 'wrsETH'];
|
|
118
|
+
exports.STAKING_ASSETS = ['cbETH', 'wstETH', 'cbETH', 'rETH', 'sDAI', 'weETH', 'sUSDe', 'osETH', 'ezETH', 'ETHx', 'rsETH', 'pufETH', 'wrsETH', 'wsuperOETHb', 'sUSDS'];
|
|
95
119
|
const getStakingApy = (asset, web3, blockNumber = 'latest', fromBlock = undefined) => {
|
|
120
|
+
console.log('getStakingApy', asset, blockNumber, fromBlock);
|
|
96
121
|
try {
|
|
97
122
|
if (asset === 'stETH' || asset === 'wstETH')
|
|
98
123
|
return (0, exports.getStETHApr)(web3, fromBlock, blockNumber);
|
|
@@ -116,6 +141,10 @@ const getStakingApy = (asset, web3, blockNumber = 'latest', fromBlock = undefine
|
|
|
116
141
|
return getApyFromDfsApi('rsETH');
|
|
117
142
|
if (asset === 'pufETH')
|
|
118
143
|
return getApyFromDfsApi('pufETH');
|
|
144
|
+
if (asset === 'wsuperOETHb')
|
|
145
|
+
return getSuperOETHApy();
|
|
146
|
+
if (asset === 'sUSDS')
|
|
147
|
+
return (0, exports.getSsrApy)();
|
|
119
148
|
}
|
|
120
149
|
catch (e) {
|
|
121
150
|
console.error(`Failed to fetch APY for ${asset}`);
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import type BN from "bn.js";
|
|
3
|
+
import type { ContractOptions } from "web3-eth-contract";
|
|
4
|
+
import type { EventLog } from "web3-core";
|
|
5
|
+
import type { EventEmitter } from "events";
|
|
6
|
+
import type { Callback, NonPayableTransactionObject, BlockType, BaseContract } from "./types";
|
|
7
|
+
export interface EventOptions {
|
|
8
|
+
filter?: object;
|
|
9
|
+
fromBlock?: BlockType;
|
|
10
|
+
topics?: string[];
|
|
11
|
+
}
|
|
12
|
+
export declare namespace LiquityV2View {
|
|
13
|
+
type MarketDataStruct = [
|
|
14
|
+
string,
|
|
15
|
+
number | string | BN,
|
|
16
|
+
number | string | BN,
|
|
17
|
+
number | string | BN,
|
|
18
|
+
number | string | BN,
|
|
19
|
+
number | string | BN,
|
|
20
|
+
number | string | BN,
|
|
21
|
+
number | string | BN,
|
|
22
|
+
string,
|
|
23
|
+
string,
|
|
24
|
+
string,
|
|
25
|
+
string,
|
|
26
|
+
string,
|
|
27
|
+
string,
|
|
28
|
+
string,
|
|
29
|
+
string,
|
|
30
|
+
string,
|
|
31
|
+
number | string | BN,
|
|
32
|
+
boolean
|
|
33
|
+
] | {
|
|
34
|
+
market: string;
|
|
35
|
+
CCR: number | string | BN;
|
|
36
|
+
MCR: number | string | BN;
|
|
37
|
+
SCR: number | string | BN;
|
|
38
|
+
LIQUIDATION_PENALTY_SP: number | string | BN;
|
|
39
|
+
LIQUIDATION_PENALTY_REDISTRIBUTION: number | string | BN;
|
|
40
|
+
entireSystemColl: number | string | BN;
|
|
41
|
+
entireSystemDebt: number | string | BN;
|
|
42
|
+
collToken: string;
|
|
43
|
+
troveNFT: string;
|
|
44
|
+
borrowerOperations: string;
|
|
45
|
+
troveManager: string;
|
|
46
|
+
stabilityPool: string;
|
|
47
|
+
sortedTroves: string;
|
|
48
|
+
collSurplusPool: string;
|
|
49
|
+
hintHelpers: string;
|
|
50
|
+
priceFeed: string;
|
|
51
|
+
collPrice: number | string | BN;
|
|
52
|
+
isShutDown: boolean;
|
|
53
|
+
};
|
|
54
|
+
type MarketDataStructOutputArray = [
|
|
55
|
+
string,
|
|
56
|
+
string,
|
|
57
|
+
string,
|
|
58
|
+
string,
|
|
59
|
+
string,
|
|
60
|
+
string,
|
|
61
|
+
string,
|
|
62
|
+
string,
|
|
63
|
+
string,
|
|
64
|
+
string,
|
|
65
|
+
string,
|
|
66
|
+
string,
|
|
67
|
+
string,
|
|
68
|
+
string,
|
|
69
|
+
string,
|
|
70
|
+
string,
|
|
71
|
+
string,
|
|
72
|
+
string,
|
|
73
|
+
boolean
|
|
74
|
+
];
|
|
75
|
+
type MarketDataStructOutputStruct = {
|
|
76
|
+
market: string;
|
|
77
|
+
CCR: string;
|
|
78
|
+
MCR: string;
|
|
79
|
+
SCR: string;
|
|
80
|
+
LIQUIDATION_PENALTY_SP: string;
|
|
81
|
+
LIQUIDATION_PENALTY_REDISTRIBUTION: string;
|
|
82
|
+
entireSystemColl: string;
|
|
83
|
+
entireSystemDebt: string;
|
|
84
|
+
collToken: string;
|
|
85
|
+
troveNFT: string;
|
|
86
|
+
borrowerOperations: string;
|
|
87
|
+
troveManager: string;
|
|
88
|
+
stabilityPool: string;
|
|
89
|
+
sortedTroves: string;
|
|
90
|
+
collSurplusPool: string;
|
|
91
|
+
hintHelpers: string;
|
|
92
|
+
priceFeed: string;
|
|
93
|
+
collPrice: string;
|
|
94
|
+
isShutDown: boolean;
|
|
95
|
+
};
|
|
96
|
+
type MarketDataStructOutput = MarketDataStructOutputArray & MarketDataStructOutputStruct;
|
|
97
|
+
type TroveDataStruct = [
|
|
98
|
+
number | string | BN,
|
|
99
|
+
string,
|
|
100
|
+
string,
|
|
101
|
+
number | string | BN,
|
|
102
|
+
number | string | BN,
|
|
103
|
+
number | string | BN,
|
|
104
|
+
number | string | BN,
|
|
105
|
+
number | string | BN,
|
|
106
|
+
number | string | BN,
|
|
107
|
+
string,
|
|
108
|
+
number | string | BN
|
|
109
|
+
] | {
|
|
110
|
+
troveId: number | string | BN;
|
|
111
|
+
owner: string;
|
|
112
|
+
collToken: string;
|
|
113
|
+
status: number | string | BN;
|
|
114
|
+
collAmount: number | string | BN;
|
|
115
|
+
debtAmount: number | string | BN;
|
|
116
|
+
collPrice: number | string | BN;
|
|
117
|
+
TCRatio: number | string | BN;
|
|
118
|
+
annualInterestRate: number | string | BN;
|
|
119
|
+
interestBatchManager: string;
|
|
120
|
+
batchDebtShares: number | string | BN;
|
|
121
|
+
};
|
|
122
|
+
type TroveDataStructOutputArray = [
|
|
123
|
+
string,
|
|
124
|
+
string,
|
|
125
|
+
string,
|
|
126
|
+
string,
|
|
127
|
+
string,
|
|
128
|
+
string,
|
|
129
|
+
string,
|
|
130
|
+
string,
|
|
131
|
+
string,
|
|
132
|
+
string,
|
|
133
|
+
string
|
|
134
|
+
];
|
|
135
|
+
type TroveDataStructOutputStruct = {
|
|
136
|
+
troveId: string;
|
|
137
|
+
owner: string;
|
|
138
|
+
collToken: string;
|
|
139
|
+
status: string;
|
|
140
|
+
collAmount: string;
|
|
141
|
+
debtAmount: string;
|
|
142
|
+
collPrice: string;
|
|
143
|
+
TCRatio: string;
|
|
144
|
+
annualInterestRate: string;
|
|
145
|
+
interestBatchManager: string;
|
|
146
|
+
batchDebtShares: string;
|
|
147
|
+
};
|
|
148
|
+
type TroveDataStructOutput = TroveDataStructOutputArray & TroveDataStructOutputStruct;
|
|
149
|
+
}
|
|
150
|
+
export interface LiquityV2View extends BaseContract {
|
|
151
|
+
constructor(jsonInterface: any[], address?: string, options?: ContractOptions): LiquityV2View;
|
|
152
|
+
clone(): LiquityV2View;
|
|
153
|
+
methods: {
|
|
154
|
+
findInsertPosition(_market: string, _interestRate: number | string | BN, _prevId: number | string | BN, _nextId: number | string | BN): NonPayableTransactionObject<[
|
|
155
|
+
string,
|
|
156
|
+
string
|
|
157
|
+
] & {
|
|
158
|
+
prevId: string;
|
|
159
|
+
nextId: string;
|
|
160
|
+
}>;
|
|
161
|
+
getApproxHint(_market: string, _collIndex: number | string | BN, _interestRate: number | string | BN, _numTrials: number | string | BN, _inputRandomSeed: number | string | BN): NonPayableTransactionObject<[
|
|
162
|
+
string,
|
|
163
|
+
string,
|
|
164
|
+
string
|
|
165
|
+
] & {
|
|
166
|
+
hintId: string;
|
|
167
|
+
diff: string;
|
|
168
|
+
latestRandomSeed: string;
|
|
169
|
+
}>;
|
|
170
|
+
getDebtInFront(_market: string, _troveId: number | string | BN, _acc: number | string | BN, _iterations: number | string | BN): NonPayableTransactionObject<[
|
|
171
|
+
string,
|
|
172
|
+
string
|
|
173
|
+
] & {
|
|
174
|
+
next: string;
|
|
175
|
+
debt: string;
|
|
176
|
+
}>;
|
|
177
|
+
getDebtInFrontByInterestRate(_market: string, _troveId: number | string | BN, _acc: number | string | BN, _iterations: number | string | BN, _targetIR: number | string | BN): NonPayableTransactionObject<[
|
|
178
|
+
string,
|
|
179
|
+
string
|
|
180
|
+
] & {
|
|
181
|
+
next: string;
|
|
182
|
+
debt: string;
|
|
183
|
+
}>;
|
|
184
|
+
getDebtInFrontByTroveNum(_market: string, _numTroves: number | string | BN): NonPayableTransactionObject<string>;
|
|
185
|
+
getDepositorInfo(_market: string, _depositor: string): NonPayableTransactionObject<[
|
|
186
|
+
string,
|
|
187
|
+
string,
|
|
188
|
+
string
|
|
189
|
+
] & {
|
|
190
|
+
compoundedBOLD: string;
|
|
191
|
+
collGain: string;
|
|
192
|
+
boldGain: string;
|
|
193
|
+
}>;
|
|
194
|
+
getInsertPosition(_market: string, _collIndex: number | string | BN, _interestRate: number | string | BN, _numTrials: number | string | BN, _inputRandomSeed: number | string | BN): NonPayableTransactionObject<[
|
|
195
|
+
string,
|
|
196
|
+
string
|
|
197
|
+
] & {
|
|
198
|
+
prevId: string;
|
|
199
|
+
nextId: string;
|
|
200
|
+
}>;
|
|
201
|
+
getMarketData(_market: string): NonPayableTransactionObject<LiquityV2View.MarketDataStructOutput>;
|
|
202
|
+
getNumOfTrovesInFrontOfTrove(_market: string, _troveId: number | string | BN, _iterations: number | string | BN): NonPayableTransactionObject<[
|
|
203
|
+
string,
|
|
204
|
+
string
|
|
205
|
+
] & {
|
|
206
|
+
next: string;
|
|
207
|
+
numTroves: string;
|
|
208
|
+
}>;
|
|
209
|
+
getTroveInfo(_market: string, _troveId: number | string | BN): NonPayableTransactionObject<LiquityV2View.TroveDataStructOutput>;
|
|
210
|
+
getTrovePosition(_market: string, _collIndex: number | string | BN, _troveId: number | string | BN, _numTrials: number | string | BN, _inputRandomSeed: number | string | BN): NonPayableTransactionObject<[
|
|
211
|
+
string,
|
|
212
|
+
string
|
|
213
|
+
] & {
|
|
214
|
+
prevId: string;
|
|
215
|
+
nextId: string;
|
|
216
|
+
}>;
|
|
217
|
+
isShutDown(_market: string): NonPayableTransactionObject<boolean>;
|
|
218
|
+
};
|
|
219
|
+
events: {
|
|
220
|
+
allEvents(options?: EventOptions, cb?: Callback<EventLog>): EventEmitter;
|
|
221
|
+
};
|
|
222
|
+
}
|
|
@@ -26,7 +26,6 @@ export type { CompoundLoanInfo } from "./CompoundLoanInfo";
|
|
|
26
26
|
export type { Comptroller } from "./Comptroller";
|
|
27
27
|
export type { ETHPriceFeed } from "./ETHPriceFeed";
|
|
28
28
|
export type { Erc20 } from "./Erc20";
|
|
29
|
-
export type { EulerV2View } from "./EulerV2View";
|
|
30
29
|
export type { FeedRegistry } from "./FeedRegistry";
|
|
31
30
|
export type { GHO } from "./GHO";
|
|
32
31
|
export type { GhoDiscountRateStrategy } from "./GhoDiscountRateStrategy";
|
|
@@ -35,6 +34,7 @@ export type { IVariableDebtToken } from "./IVariableDebtToken";
|
|
|
35
34
|
export type { LendingPoolAddressesProvider } from "./LendingPoolAddressesProvider";
|
|
36
35
|
export type { Lido } from "./Lido";
|
|
37
36
|
export type { LiquityActivePool } from "./LiquityActivePool";
|
|
37
|
+
export type { LiquityV2View } from "./LiquityV2View";
|
|
38
38
|
export type { LiquityView } from "./LiquityView";
|
|
39
39
|
export type { LlamaLendControllerAbi } from "./LlamaLendControllerAbi";
|
|
40
40
|
export type { LlamaLendView } from "./LlamaLendView";
|