@defisaver/positions-sdk 0.0.29 → 0.0.30-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +63 -63
- package/cjs/config/contracts.d.ts +908 -41
- package/cjs/config/contracts.js +172 -45
- package/cjs/contracts.js +4 -10
- package/cjs/curveUsd/index.js +1 -1
- package/cjs/helpers/curveUsdHelpers/index.d.ts +2 -1
- package/cjs/helpers/curveUsdHelpers/index.js +25 -17
- package/cjs/markets/aave/marketAssets.d.ts +9 -5
- package/cjs/markets/aave/marketAssets.js +16 -23
- package/cjs/markets/compound/marketsAssets.d.ts +11 -5
- package/cjs/markets/compound/marketsAssets.js +17 -19
- package/cjs/markets/spark/marketAssets.d.ts +3 -2
- package/cjs/markets/spark/marketAssets.js +5 -5
- package/cjs/moneymarket/moneymarketCommonService.js +1 -1
- package/cjs/services/utils.d.ts +4 -0
- package/cjs/services/utils.js +13 -1
- package/cjs/types/contracts/generated/CrvUSDView.d.ts +30 -4
- package/cjs/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +1 -0
- package/cjs/types/curveUsd.d.ts +6 -0
- package/esm/config/contracts.d.ts +908 -41
- package/esm/config/contracts.js +172 -45
- package/esm/contracts.js +4 -10
- package/esm/curveUsd/index.js +1 -1
- package/esm/helpers/curveUsdHelpers/index.d.ts +2 -1
- package/esm/helpers/curveUsdHelpers/index.js +26 -18
- package/esm/markets/aave/marketAssets.d.ts +9 -5
- package/esm/markets/aave/marketAssets.js +15 -22
- package/esm/markets/compound/marketsAssets.d.ts +11 -5
- package/esm/markets/compound/marketsAssets.js +16 -18
- package/esm/markets/spark/marketAssets.d.ts +3 -2
- package/esm/markets/spark/marketAssets.js +4 -4
- package/esm/moneymarket/moneymarketCommonService.js +1 -1
- package/esm/services/utils.d.ts +4 -0
- package/esm/services/utils.js +11 -0
- package/esm/types/contracts/generated/CrvUSDView.d.ts +30 -4
- package/esm/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +1 -0
- package/esm/types/curveUsd.d.ts +6 -0
- package/package.json +40 -40
- package/src/aaveV2/index.ts +226 -226
- package/src/aaveV3/index.ts +561 -561
- 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 +275 -275
- package/src/config/contracts.js +803 -676
- package/src/constants/index.ts +3 -3
- package/src/contracts.ts +120 -126
- package/src/curveUsd/index.ts +228 -228
- package/src/exchange/index.ts +17 -17
- package/src/helpers/aaveHelpers/index.ts +134 -134
- package/src/helpers/chickenBondsHelpers/index.ts +23 -23
- package/src/helpers/compoundHelpers/index.ts +181 -181
- package/src/helpers/curveUsdHelpers/index.ts +40 -32
- package/src/helpers/index.ts +5 -5
- package/src/helpers/makerHelpers/index.ts +94 -94
- package/src/helpers/sparkHelpers/index.ts +106 -106
- package/src/index.ts +40 -40
- package/src/liquity/index.ts +116 -116
- package/src/maker/index.ts +101 -101
- package/src/markets/aave/index.ts +80 -80
- package/src/markets/aave/marketAssets.ts +24 -32
- package/src/markets/compound/index.ts +141 -141
- package/src/markets/compound/marketsAssets.ts +48 -46
- package/src/markets/curveUsd/index.ts +69 -69
- package/src/markets/index.ts +3 -3
- package/src/markets/spark/index.ts +29 -29
- package/src/markets/spark/marketAssets.ts +10 -9
- package/src/moneymarket/moneymarketCommonService.ts +75 -75
- package/src/morpho/markets.ts +39 -39
- package/src/morphoAaveV2/index.ts +255 -255
- package/src/morphoAaveV3/index.ts +619 -619
- 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 +48 -35
- package/src/spark/index.ts +422 -422
- package/src/staking/staking.ts +167 -167
- package/src/types/aave.ts +256 -256
- package/src/types/chickenBonds.ts +45 -45
- package/src/types/common.ts +83 -83
- package/src/types/compound.ts +128 -128
- package/src/types/contracts/generated/CrvUSDView.ts +43 -8
- package/src/types/contracts/generated/MorphoAaveV3ProxyEthMarket.ts +2 -0
- package/src/types/curveUsd.ts +118 -112
- package/src/types/index.ts +6 -6
- package/src/types/liquity.ts +30 -30
- package/src/types/maker.ts +50 -50
- package/src/types/spark.ts +106 -106
- package/yarn-error.log +64 -0
package/cjs/curveUsd/index.js
CHANGED
|
@@ -187,7 +187,7 @@ const getCurveUsdUserData = (web3, network, address, selectedMarket, activeBand)
|
|
|
187
187
|
priceHigh,
|
|
188
188
|
priceLow, liquidationDiscount: (0, tokens_1.assetAmountInEth)(data.liquidationDiscount), numOfBands: data.N, usedAssets,
|
|
189
189
|
status }), (0, curveUsdHelpers_1.getCrvUsdAggregatedData)({
|
|
190
|
-
loanExists: data.loanExists, usedAssets, network: common_1.NetworkNumber.Eth, selectedMarket,
|
|
190
|
+
loanExists: data.loanExists, usedAssets, network: common_1.NetworkNumber.Eth, selectedMarket, numOfBands: data.N,
|
|
191
191
|
})), { userBands });
|
|
192
192
|
});
|
|
193
193
|
exports.getCurveUsdUserData = getCurveUsdUserData;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { CrvUSDAggregatedPositionData, CrvUSDMarketData, CrvUSDUsedAssets } from '../../types';
|
|
2
2
|
import { NetworkNumber } from '../../types/common';
|
|
3
|
-
export declare const getCrvUsdAggregatedData: ({ loanExists, usedAssets, network, selectedMarket, ...rest }: {
|
|
3
|
+
export declare const getCrvUsdAggregatedData: ({ loanExists, usedAssets, network, selectedMarket, numOfBands, ...rest }: {
|
|
4
4
|
loanExists: boolean;
|
|
5
5
|
usedAssets: CrvUSDUsedAssets;
|
|
6
6
|
network: NetworkNumber;
|
|
7
7
|
selectedMarket: CrvUSDMarketData;
|
|
8
|
+
numOfBands: number | string;
|
|
8
9
|
}) => CrvUSDAggregatedPositionData;
|
|
@@ -17,26 +17,34 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
exports.getCrvUsdAggregatedData = void 0;
|
|
18
18
|
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
19
19
|
const moneymarket_1 = require("../../moneymarket");
|
|
20
|
+
const utils_1 = require("../../services/utils");
|
|
20
21
|
const getCrvUsdAggregatedData = (_a) => {
|
|
21
|
-
var
|
|
22
|
-
|
|
23
|
-
const
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
22
|
+
var _b;
|
|
23
|
+
var { loanExists, usedAssets, network, selectedMarket, numOfBands } = _a, rest = __rest(_a, ["loanExists", "usedAssets", "network", "selectedMarket", "numOfBands"]);
|
|
24
|
+
const payload = {};
|
|
25
|
+
payload.supplied = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ supplied }) => supplied); // this is wrong if we are in soft-liquidations
|
|
26
|
+
payload.borrowed = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowed }) => borrowed);
|
|
27
|
+
payload.suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
|
|
28
|
+
payload.borrowedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowedUsd }) => borrowedUsd);
|
|
29
|
+
payload.ratio = loanExists
|
|
30
|
+
? new decimal_js_1.default(payload.suppliedUsd)
|
|
31
|
+
.dividedBy(payload.borrowedUsd)
|
|
29
32
|
.times(100)
|
|
30
33
|
.toString()
|
|
31
34
|
: '0';
|
|
32
|
-
//
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
35
|
+
// this is all approximation
|
|
36
|
+
payload.minAllowedRatio = (0, utils_1.mapRange)(numOfBands, 4, 50, 115, 140); // collateral ratio
|
|
37
|
+
payload.collFactor = new decimal_js_1.default(1).div(payload.minAllowedRatio).mul(100).toString(); // collateral factor = 1 / collateral ratio
|
|
38
|
+
// only take in consideration collAsset
|
|
39
|
+
payload.borrowLimitUsd = ((_b = usedAssets === null || usedAssets === void 0 ? void 0 : usedAssets[selectedMarket.collAsset]) === null || _b === void 0 ? void 0 : _b.isSupplied)
|
|
40
|
+
? new decimal_js_1.default(usedAssets[selectedMarket.collAsset].suppliedUsd).mul(payload.collFactor).toString()
|
|
41
|
+
: '0';
|
|
42
|
+
const { leveragedType, leveragedAsset } = (0, moneymarket_1.isLeveragedPos)(usedAssets);
|
|
43
|
+
payload.leveragedType = leveragedType;
|
|
44
|
+
if (leveragedType !== '') {
|
|
45
|
+
payload.leveragedAsset = leveragedAsset;
|
|
46
|
+
payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, usedAssets[selectedMarket.collAsset].price, payload.borrowedUsd, payload.borrowLimitUsd);
|
|
47
|
+
}
|
|
48
|
+
return payload;
|
|
41
49
|
};
|
|
42
50
|
exports.getCrvUsdAggregatedData = getCrvUsdAggregatedData;
|
|
@@ -1,9 +1,13 @@
|
|
|
1
|
-
export declare const aaveV2AssetsDefaultMarket:
|
|
1
|
+
export declare const aaveV2AssetsDefaultMarket: string[];
|
|
2
2
|
export declare const morphoAaveV2AssetDefaultMarket: string[];
|
|
3
3
|
export declare const morphoAaveV3AssetEthMarket: string[];
|
|
4
|
+
export declare const aaveV3AssetsDefaultMarketEth: string[];
|
|
5
|
+
export declare const aaveV3AssetsDefaultMarketOpt: string[];
|
|
6
|
+
export declare const aaveV3AssetsDefaultMarketArb: string[];
|
|
7
|
+
export declare const aaveV3AssetsDefaultMarketBase: string[];
|
|
4
8
|
export declare const aaveV3AssetsDefaultMarket: {
|
|
5
|
-
readonly 1:
|
|
6
|
-
readonly 10:
|
|
7
|
-
readonly 42161:
|
|
8
|
-
readonly 8453:
|
|
9
|
+
readonly 1: string[];
|
|
10
|
+
readonly 10: string[];
|
|
11
|
+
readonly 42161: string[];
|
|
12
|
+
readonly 8453: string[];
|
|
9
13
|
};
|
|
@@ -1,31 +1,24 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
// TODO generate this file automatically
|
|
3
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.aaveV3AssetsDefaultMarket = exports.morphoAaveV3AssetEthMarket = exports.morphoAaveV2AssetDefaultMarket = exports.aaveV2AssetsDefaultMarket = void 0;
|
|
3
|
+
exports.aaveV3AssetsDefaultMarket = exports.aaveV3AssetsDefaultMarketBase = exports.aaveV3AssetsDefaultMarketArb = exports.aaveV3AssetsDefaultMarketOpt = exports.aaveV3AssetsDefaultMarketEth = exports.morphoAaveV3AssetEthMarket = exports.morphoAaveV2AssetDefaultMarket = exports.aaveV2AssetsDefaultMarket = void 0;
|
|
5
4
|
const common_1 = require("../../types/common");
|
|
6
|
-
exports.aaveV2AssetsDefaultMarket = [
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
'
|
|
5
|
+
exports.aaveV2AssetsDefaultMarket = ['USDT', 'WBTC', 'ETH', 'YFI', 'ZRX', 'UNI', 'AAVE', 'BAT', 'BUSD', 'DAI', 'ENJ', 'KNCL', 'LINK', 'MANA', 'MKR', 'REN', 'SNX', 'SUSD', 'TUSD', 'USDC', 'CRV', 'GUSD', 'BAL', 'xSUSHI', 'RENFIL', 'RAI', 'AMPL', 'USDP', 'DPI', 'FRAX', 'FEI', 'stETH', 'ENS', 'UST', 'CVX', '1INCH', 'LUSD'];
|
|
6
|
+
exports.morphoAaveV2AssetDefaultMarket = ['DAI', 'ETH', 'USDC', 'USDT', 'WBTC', 'stETH', 'CRV'];
|
|
7
|
+
exports.morphoAaveV3AssetEthMarket = [
|
|
8
|
+
'ETH', 'wstETH', 'DAI', 'USDC', 'WBTC', 'rETH', 'cbETH', 'sDAI', 'USDT',
|
|
10
9
|
];
|
|
11
|
-
exports.
|
|
12
|
-
|
|
10
|
+
exports.aaveV3AssetsDefaultMarketEth = ['ETH', 'wstETH', 'WBTC', 'USDC', 'DAI', 'LINK', 'AAVE', 'cbETH', 'USDT', 'rETH', 'LUSD', 'CRV', 'MKR', 'SNX', 'BAL', 'UNI', 'LDO', 'ENS', '1INCH', 'FRAX', 'GHO', 'RPL', 'sDAI', 'STG', 'KNC', 'FXS', 'crvUSD'];
|
|
11
|
+
exports.aaveV3AssetsDefaultMarketOpt = [
|
|
12
|
+
'DAI', 'USDC.e', 'USDT', 'SUSD', 'AAVE', 'LINK', 'WBTC', 'ETH', 'OP', 'wstETH', 'LUSD', 'MAI', 'rETH', 'USDC',
|
|
13
13
|
];
|
|
14
|
-
exports.
|
|
15
|
-
'ETH', '
|
|
14
|
+
exports.aaveV3AssetsDefaultMarketArb = [
|
|
15
|
+
'ETH', 'DAI', 'EURS', 'USDC', 'USDT', 'AAVE', 'LINK', 'WBTC', 'wstETH', 'MAI', 'rETH', 'LUSD', 'USDC.e', 'FRAX', 'ARB',
|
|
16
16
|
];
|
|
17
|
+
exports.aaveV3AssetsDefaultMarketBase = ['ETH', 'cbETH', 'USDbC', 'wstETH', 'USDC'];
|
|
18
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
17
19
|
exports.aaveV3AssetsDefaultMarket = {
|
|
18
|
-
[common_1.NetworkNumber.Eth]:
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
],
|
|
22
|
-
[common_1.NetworkNumber.Opt]: [
|
|
23
|
-
'DAI', 'USDC.e', 'USDT', 'SUSD', 'AAVE', 'LINK', 'WBTC', 'ETH', 'OP', 'wstETH', 'LUSD', 'MAI', 'rETH',
|
|
24
|
-
],
|
|
25
|
-
[common_1.NetworkNumber.Arb]: [
|
|
26
|
-
'ETH', 'DAI', 'EURS', 'USDC', 'USDT', 'AAVE', 'LINK', 'WBTC', 'wstETH', 'MAI', 'rETH', 'LUSD', 'USDC.e', 'FRAX', 'ARB',
|
|
27
|
-
],
|
|
28
|
-
[common_1.NetworkNumber.Base]: [
|
|
29
|
-
'ETH', 'USDbC', 'cbETH', 'wstETH',
|
|
30
|
-
],
|
|
20
|
+
[common_1.NetworkNumber.Eth]: exports.aaveV3AssetsDefaultMarketEth,
|
|
21
|
+
[common_1.NetworkNumber.Opt]: exports.aaveV3AssetsDefaultMarketOpt,
|
|
22
|
+
[common_1.NetworkNumber.Arb]: exports.aaveV3AssetsDefaultMarketArb,
|
|
23
|
+
[common_1.NetworkNumber.Base]: exports.aaveV3AssetsDefaultMarketBase,
|
|
31
24
|
};
|
|
@@ -1,22 +1,28 @@
|
|
|
1
1
|
export declare const compoundV2CollateralAssets: import("@defisaver/tokens/esm/types").AssetData[];
|
|
2
|
+
export declare const v3USDCCollAssetsEth: string[];
|
|
3
|
+
export declare const v3USDCCollAssetsArb: string[];
|
|
2
4
|
export declare const v3USDCCollAssets: {
|
|
3
|
-
readonly 1:
|
|
5
|
+
readonly 1: string[];
|
|
4
6
|
readonly 10: readonly [];
|
|
5
|
-
readonly 42161:
|
|
7
|
+
readonly 42161: string[];
|
|
6
8
|
readonly 8453: readonly [];
|
|
7
9
|
};
|
|
10
|
+
export declare const v3USDCeCollAssetsArb: string[];
|
|
8
11
|
export declare const v3USDCeCollAssets: {
|
|
9
12
|
readonly 1: readonly [];
|
|
10
13
|
readonly 10: readonly [];
|
|
11
|
-
readonly 42161:
|
|
14
|
+
readonly 42161: string[];
|
|
12
15
|
readonly 8453: readonly [];
|
|
13
16
|
};
|
|
17
|
+
export declare const v3ETHCollAssetsEth: string[];
|
|
18
|
+
export declare const v3ETHCollAssetsBase: string[];
|
|
14
19
|
export declare const v3ETHCollAssets: {
|
|
15
|
-
readonly 1:
|
|
20
|
+
readonly 1: string[];
|
|
16
21
|
readonly 10: readonly [];
|
|
17
22
|
readonly 42161: readonly [];
|
|
18
|
-
readonly 8453:
|
|
23
|
+
readonly 8453: string[];
|
|
19
24
|
};
|
|
25
|
+
export declare const v3USDbCCollAssetsBase: string[];
|
|
20
26
|
export declare const v3USDbCCollAssets: {
|
|
21
27
|
1: never[];
|
|
22
28
|
10: never[];
|
|
@@ -1,45 +1,43 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.v3USDbCCollAssets = exports.v3ETHCollAssets = exports.v3USDCeCollAssets = exports.v3USDCCollAssets = exports.compoundV2CollateralAssets = void 0;
|
|
3
|
+
exports.v3USDbCCollAssets = exports.v3USDbCCollAssetsBase = exports.v3ETHCollAssets = exports.v3ETHCollAssetsBase = exports.v3ETHCollAssetsEth = exports.v3USDCeCollAssets = exports.v3USDCeCollAssetsArb = exports.v3USDCCollAssets = exports.v3USDCCollAssetsArb = exports.v3USDCCollAssetsEth = exports.compoundV2CollateralAssets = void 0;
|
|
4
4
|
const tokens_1 = require("@defisaver/tokens");
|
|
5
5
|
const common_1 = require("../../types/common");
|
|
6
6
|
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 = ['ETH', 'COMP', 'WBTC', 'UNI', 'LINK'];
|
|
11
|
+
exports.v3USDCCollAssetsArb = ['ARB', 'ETH', 'GMX', 'WBTC'];
|
|
12
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
10
13
|
exports.v3USDCCollAssets = {
|
|
11
|
-
[common_1.NetworkNumber.Eth]:
|
|
12
|
-
'ETH', 'COMP', 'WBTC', 'UNI', 'LINK',
|
|
13
|
-
],
|
|
14
|
+
[common_1.NetworkNumber.Eth]: exports.v3USDCCollAssetsEth,
|
|
14
15
|
[common_1.NetworkNumber.Opt]: [],
|
|
15
|
-
[common_1.NetworkNumber.Arb]:
|
|
16
|
-
'ARB', 'ETH', 'GMX', 'WBTC',
|
|
17
|
-
],
|
|
16
|
+
[common_1.NetworkNumber.Arb]: exports.v3USDCCollAssetsArb,
|
|
18
17
|
[common_1.NetworkNumber.Base]: [],
|
|
19
18
|
};
|
|
19
|
+
exports.v3USDCeCollAssetsArb = ['ARB', 'ETH', 'GMX', 'WBTC'];
|
|
20
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
20
21
|
exports.v3USDCeCollAssets = {
|
|
21
22
|
[common_1.NetworkNumber.Eth]: [],
|
|
22
23
|
[common_1.NetworkNumber.Opt]: [],
|
|
23
|
-
[common_1.NetworkNumber.Arb]:
|
|
24
|
-
'ARB', 'ETH', 'GMX', 'WBTC',
|
|
25
|
-
],
|
|
24
|
+
[common_1.NetworkNumber.Arb]: exports.v3USDCeCollAssetsArb,
|
|
26
25
|
[common_1.NetworkNumber.Base]: [],
|
|
27
26
|
};
|
|
27
|
+
exports.v3ETHCollAssetsEth = ['cbETH', 'wstETH', 'rETH'];
|
|
28
|
+
exports.v3ETHCollAssetsBase = ['cbETH'];
|
|
29
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
28
30
|
exports.v3ETHCollAssets = {
|
|
29
|
-
[common_1.NetworkNumber.Eth]:
|
|
30
|
-
'cbETH', 'wstETH', 'rETH',
|
|
31
|
-
],
|
|
31
|
+
[common_1.NetworkNumber.Eth]: exports.v3ETHCollAssetsEth,
|
|
32
32
|
[common_1.NetworkNumber.Opt]: [],
|
|
33
33
|
[common_1.NetworkNumber.Arb]: [],
|
|
34
|
-
[common_1.NetworkNumber.Base]:
|
|
35
|
-
'cbETH',
|
|
36
|
-
],
|
|
34
|
+
[common_1.NetworkNumber.Base]: exports.v3ETHCollAssetsBase,
|
|
37
35
|
};
|
|
36
|
+
exports.v3USDbCCollAssetsBase = ['ETH', 'cbETH'];
|
|
37
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
38
38
|
exports.v3USDbCCollAssets = {
|
|
39
39
|
[common_1.NetworkNumber.Eth]: [],
|
|
40
40
|
[common_1.NetworkNumber.Opt]: [],
|
|
41
41
|
[common_1.NetworkNumber.Arb]: [],
|
|
42
|
-
[common_1.NetworkNumber.Base]:
|
|
43
|
-
'ETH', 'cbETH',
|
|
44
|
-
],
|
|
42
|
+
[common_1.NetworkNumber.Base]: exports.v3USDbCCollAssetsBase,
|
|
45
43
|
};
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
export declare const sparkAssetsDefaultMarketEth: string[];
|
|
1
2
|
export declare const sparkAssetsDefaultMarket: {
|
|
2
|
-
readonly 1:
|
|
3
|
+
readonly 1: string[];
|
|
3
4
|
readonly 10: readonly [];
|
|
4
|
-
readonly 42161: readonly [];
|
|
5
5
|
readonly 8453: readonly [];
|
|
6
|
+
readonly 42161: readonly [];
|
|
6
7
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.sparkAssetsDefaultMarket = void 0;
|
|
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'];
|
|
6
|
+
// @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
|
|
5
7
|
exports.sparkAssetsDefaultMarket = {
|
|
6
|
-
[common_1.NetworkNumber.Eth]:
|
|
7
|
-
'ETH', 'USDC', 'DAI', 'GNO', 'rETH', 'sDAI', 'wstETH', 'WBTC',
|
|
8
|
-
],
|
|
8
|
+
[common_1.NetworkNumber.Eth]: exports.sparkAssetsDefaultMarketEth,
|
|
9
9
|
[common_1.NetworkNumber.Opt]: [],
|
|
10
|
-
[common_1.NetworkNumber.Arb]: [],
|
|
11
10
|
[common_1.NetworkNumber.Base]: [],
|
|
11
|
+
[common_1.NetworkNumber.Arb]: [],
|
|
12
12
|
};
|
|
@@ -27,7 +27,7 @@ const calcLeverageLiqPrice = (leverageType, assetPrice, borrowedUsd, borrowLimit
|
|
|
27
27
|
exports.calcLeverageLiqPrice = calcLeverageLiqPrice;
|
|
28
28
|
const calculateBorrowingAssetLimit = (assetBorrowedUsd, borrowLimitUsd) => new decimal_js_1.default(assetBorrowedUsd).div(borrowLimitUsd).times(100).toString();
|
|
29
29
|
exports.calculateBorrowingAssetLimit = calculateBorrowingAssetLimit;
|
|
30
|
-
exports.STABLE_ASSETS = ['DAI', 'USDC', 'USDT', 'TUSD', 'USDP', 'GUSD', 'BUSD', 'SUSD', 'FRAX', 'LUSD', 'USDC.e', 'GHO', 'sDAI'];
|
|
30
|
+
exports.STABLE_ASSETS = ['DAI', 'USDC', 'USDT', 'TUSD', 'USDP', 'GUSD', 'BUSD', 'SUSD', 'FRAX', 'LUSD', 'USDC.e', 'GHO', 'sDAI', 'crvUSD'];
|
|
31
31
|
const isLeveragedPos = (usedAssets, dustLimit = 5) => {
|
|
32
32
|
let borrowUnstable = 0;
|
|
33
33
|
let supplyStable = 0;
|
package/cjs/services/utils.d.ts
CHANGED
|
@@ -14,3 +14,7 @@ export declare const handleWbtcLegacy: (asset: string) => string;
|
|
|
14
14
|
export declare const wethToEthByAddress: (maybeWethAddr: string, chainId?: NetworkNumber) => string;
|
|
15
15
|
export declare const ethToWethByAddress: (maybeEthAddr: string, chainId?: NetworkNumber) => string;
|
|
16
16
|
export declare const bytesToString: (hex: string) => string;
|
|
17
|
+
/**
|
|
18
|
+
* Map an input value from one range (minInput, maxInput) to a value in another range (minOutput, maxOutput)
|
|
19
|
+
*/
|
|
20
|
+
export declare const mapRange: (input: number | string, minInput: number | string, maxInput: number | string, minOutput: number | string, maxOutput: number | string) => number;
|
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.bytesToString = exports.ethToWethByAddress = exports.wethToEthByAddress = exports.handleWbtcLegacy = exports.getEthAmountForDecimals = exports.compareAddresses = exports.isAddress = exports.ADDRESS_REGEX = exports.getAbiItem = exports.wstEthToStEth = exports.stEthToWstEth = exports.wethToEth = exports.ethToWeth = exports.addToObjectIf = exports.isLayer2Network = void 0;
|
|
6
|
+
exports.mapRange = exports.bytesToString = exports.ethToWethByAddress = exports.wethToEthByAddress = exports.handleWbtcLegacy = exports.getEthAmountForDecimals = 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");
|
|
@@ -39,3 +39,15 @@ const bytesToString = (hex) => Buffer.from(hex.replace(/^0x/, ''), 'hex')
|
|
|
39
39
|
// eslint-disable-next-line no-control-regex
|
|
40
40
|
.replace(/\x00/g, '');
|
|
41
41
|
exports.bytesToString = bytesToString;
|
|
42
|
+
/**
|
|
43
|
+
* Map an input value from one range (minInput, maxInput) to a value in another range (minOutput, maxOutput)
|
|
44
|
+
*/
|
|
45
|
+
const mapRange = (input, minInput, maxInput, minOutput, maxOutput) => {
|
|
46
|
+
// slope = 1.0 * (output_end - output_start) / (input_end - input_start)
|
|
47
|
+
const inputDiff = new decimal_js_1.default(maxInput).minus(minInput);
|
|
48
|
+
const outputDiff = new decimal_js_1.default(maxOutput).minus(minOutput);
|
|
49
|
+
const slope = new decimal_js_1.default(outputDiff).div(inputDiff);
|
|
50
|
+
// output = output_start + slope * (input - input_start)
|
|
51
|
+
return new decimal_js_1.default(minOutput).plus(new decimal_js_1.default(slope).mul(new decimal_js_1.default(input).minus(minInput))).toDP(2).toNumber();
|
|
52
|
+
};
|
|
53
|
+
exports.mapRange = mapRange;
|
|
@@ -138,7 +138,9 @@ export declare namespace CurveUsdView {
|
|
|
138
138
|
[
|
|
139
139
|
number | string | BN[],
|
|
140
140
|
number | string | BN[]
|
|
141
|
-
]
|
|
141
|
+
],
|
|
142
|
+
number | string | BN,
|
|
143
|
+
boolean
|
|
142
144
|
] | {
|
|
143
145
|
loanExists: boolean;
|
|
144
146
|
collateralPrice: number | string | BN;
|
|
@@ -152,6 +154,8 @@ export declare namespace CurveUsdView {
|
|
|
152
154
|
health: number | string | BN;
|
|
153
155
|
bandRange: [number | string | BN, number | string | BN];
|
|
154
156
|
usersBands: [number | string | BN[], number | string | BN[]];
|
|
157
|
+
collRatio: number | string | BN;
|
|
158
|
+
isInSoftLiquidation: boolean;
|
|
155
159
|
};
|
|
156
160
|
type UserDataStructOutputArray = [
|
|
157
161
|
boolean,
|
|
@@ -171,7 +175,9 @@ export declare namespace CurveUsdView {
|
|
|
171
175
|
[
|
|
172
176
|
string[],
|
|
173
177
|
string[]
|
|
174
|
-
]
|
|
178
|
+
],
|
|
179
|
+
string,
|
|
180
|
+
boolean
|
|
175
181
|
];
|
|
176
182
|
type UserDataStructOutputStruct = {
|
|
177
183
|
loanExists: boolean;
|
|
@@ -186,6 +192,8 @@ export declare namespace CurveUsdView {
|
|
|
186
192
|
health: string;
|
|
187
193
|
bandRange: [string, string];
|
|
188
194
|
usersBands: [string[], string[]];
|
|
195
|
+
collRatio: string;
|
|
196
|
+
isInSoftLiquidation: boolean;
|
|
189
197
|
};
|
|
190
198
|
type UserDataStructOutput = UserDataStructOutputArray & UserDataStructOutputStruct;
|
|
191
199
|
}
|
|
@@ -193,15 +201,33 @@ export interface CrvUSDView extends BaseContract {
|
|
|
193
201
|
constructor(jsonInterface: any[], address?: string, options?: ContractOptions): CrvUSDView;
|
|
194
202
|
clone(): CrvUSDView;
|
|
195
203
|
methods: {
|
|
204
|
+
WBTC_HEALTH_ZAP(): NonPayableTransactionObject<string>;
|
|
205
|
+
WBTC_MARKET(): NonPayableTransactionObject<string>;
|
|
196
206
|
createLoanData(market: string, collateral: number | string | BN, debt: number | string | BN, N: number | string | BN): NonPayableTransactionObject<CurveUsdView.CreateLoanDataStructOutput>;
|
|
197
207
|
getBandData(market: string, n: number | string | BN): NonPayableTransactionObject<CurveUsdView.BandStructOutput>;
|
|
198
|
-
|
|
199
|
-
|
|
208
|
+
getBandsData(market: string, from: number | string | BN, to: number | string | BN): NonPayableTransactionObject<CurveUsdView.BandStructOutput[]>;
|
|
209
|
+
getBandsDataForPosition(market: string, collateral: number | string | BN, debt: number | string | BN, N: number | string | BN): NonPayableTransactionObject<CurveUsdView.BandStructOutput[]>;
|
|
210
|
+
getCollAmountsFromAMM(_controllerAddress: string, _user: string): NonPayableTransactionObject<[
|
|
211
|
+
string,
|
|
212
|
+
string
|
|
213
|
+
] & {
|
|
214
|
+
crvUsdAmount: string;
|
|
215
|
+
collAmount: string;
|
|
216
|
+
}>;
|
|
217
|
+
getCollateralRatio(_user: string, _controllerAddr: string): NonPayableTransactionObject<[
|
|
218
|
+
string,
|
|
219
|
+
boolean
|
|
220
|
+
] & {
|
|
221
|
+
collRatio: string;
|
|
222
|
+
isInSoftLiquidation: boolean;
|
|
223
|
+
}>;
|
|
200
224
|
globalData(market: string): NonPayableTransactionObject<CurveUsdView.GlobalDataStructOutput>;
|
|
201
225
|
healthCalculator(market: string, user: string, collChange: number | string | BN, debtChange: number | string | BN, isFull: boolean, numBands: number | string | BN): NonPayableTransactionObject<string>;
|
|
226
|
+
isControllerValid(_controllerAddr: string): NonPayableTransactionObject<boolean>;
|
|
202
227
|
maxBorrow(market: string, collateral: number | string | BN, N: number | string | BN): NonPayableTransactionObject<string>;
|
|
203
228
|
minCollateral(market: string, debt: number | string | BN, N: number | string | BN): NonPayableTransactionObject<string>;
|
|
204
229
|
userData(market: string, user: string): NonPayableTransactionObject<CurveUsdView.UserDataStructOutput>;
|
|
230
|
+
userMaxWithdraw(_controllerAddress: string, _user: string): NonPayableTransactionObject<string>;
|
|
205
231
|
};
|
|
206
232
|
events: {
|
|
207
233
|
allEvents(options?: EventOptions, cb?: Callback<EventLog>): EventEmitter;
|
|
@@ -177,6 +177,7 @@ export interface MorphoAaveV3ProxyEthMarket extends BaseContract {
|
|
|
177
177
|
constructor(jsonInterface: any[], address?: string, options?: ContractOptions): MorphoAaveV3ProxyEthMarket;
|
|
178
178
|
clone(): MorphoAaveV3ProxyEthMarket;
|
|
179
179
|
methods: {
|
|
180
|
+
marketsCreated(): NonPayableTransactionObject<string[]>;
|
|
180
181
|
approveManager(manager: string, isAllowed: boolean): NonPayableTransactionObject<void>;
|
|
181
182
|
approveManagerWithSig(delegator: string, manager: string, isAllowed: boolean, nonce: number | string | BN, deadline: number | string | BN, signature: Types.SignatureStruct): NonPayableTransactionObject<void>;
|
|
182
183
|
borrow(underlying: string, amount: number | string | BN, onBehalf: string, receiver: string, maxIterations: number | string | BN): NonPayableTransactionObject<string>;
|
package/cjs/types/curveUsd.d.ts
CHANGED
|
@@ -67,6 +67,12 @@ export interface CrvUSDAggregatedPositionData {
|
|
|
67
67
|
borrowedUsd: string;
|
|
68
68
|
borrowed: string;
|
|
69
69
|
safetyRatio: string;
|
|
70
|
+
borrowLimitUsd: string;
|
|
71
|
+
minAllowedRatio: number;
|
|
72
|
+
collFactor: string;
|
|
73
|
+
leveragedType: string;
|
|
74
|
+
leveragedAsset?: string;
|
|
75
|
+
liquidationPrice?: string;
|
|
70
76
|
}
|
|
71
77
|
export interface CrvUSDUsedAsset {
|
|
72
78
|
isSupplied: boolean;
|