@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.
Files changed (89) hide show
  1. package/README.md +63 -63
  2. package/cjs/config/contracts.d.ts +908 -41
  3. package/cjs/config/contracts.js +172 -45
  4. package/cjs/contracts.js +4 -10
  5. package/cjs/curveUsd/index.js +1 -1
  6. package/cjs/helpers/curveUsdHelpers/index.d.ts +2 -1
  7. package/cjs/helpers/curveUsdHelpers/index.js +25 -17
  8. package/cjs/markets/aave/marketAssets.d.ts +9 -5
  9. package/cjs/markets/aave/marketAssets.js +16 -23
  10. package/cjs/markets/compound/marketsAssets.d.ts +11 -5
  11. package/cjs/markets/compound/marketsAssets.js +17 -19
  12. package/cjs/markets/spark/marketAssets.d.ts +3 -2
  13. package/cjs/markets/spark/marketAssets.js +5 -5
  14. package/cjs/moneymarket/moneymarketCommonService.js +1 -1
  15. package/cjs/services/utils.d.ts +4 -0
  16. package/cjs/services/utils.js +13 -1
  17. package/cjs/types/contracts/generated/CrvUSDView.d.ts +30 -4
  18. package/cjs/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +1 -0
  19. package/cjs/types/curveUsd.d.ts +6 -0
  20. package/esm/config/contracts.d.ts +908 -41
  21. package/esm/config/contracts.js +172 -45
  22. package/esm/contracts.js +4 -10
  23. package/esm/curveUsd/index.js +1 -1
  24. package/esm/helpers/curveUsdHelpers/index.d.ts +2 -1
  25. package/esm/helpers/curveUsdHelpers/index.js +26 -18
  26. package/esm/markets/aave/marketAssets.d.ts +9 -5
  27. package/esm/markets/aave/marketAssets.js +15 -22
  28. package/esm/markets/compound/marketsAssets.d.ts +11 -5
  29. package/esm/markets/compound/marketsAssets.js +16 -18
  30. package/esm/markets/spark/marketAssets.d.ts +3 -2
  31. package/esm/markets/spark/marketAssets.js +4 -4
  32. package/esm/moneymarket/moneymarketCommonService.js +1 -1
  33. package/esm/services/utils.d.ts +4 -0
  34. package/esm/services/utils.js +11 -0
  35. package/esm/types/contracts/generated/CrvUSDView.d.ts +30 -4
  36. package/esm/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +1 -0
  37. package/esm/types/curveUsd.d.ts +6 -0
  38. package/package.json +40 -40
  39. package/src/aaveV2/index.ts +226 -226
  40. package/src/aaveV3/index.ts +561 -561
  41. package/src/assets/index.ts +60 -60
  42. package/src/chickenBonds/index.ts +123 -123
  43. package/src/compoundV2/index.ts +219 -219
  44. package/src/compoundV3/index.ts +275 -275
  45. package/src/config/contracts.js +803 -676
  46. package/src/constants/index.ts +3 -3
  47. package/src/contracts.ts +120 -126
  48. package/src/curveUsd/index.ts +228 -228
  49. package/src/exchange/index.ts +17 -17
  50. package/src/helpers/aaveHelpers/index.ts +134 -134
  51. package/src/helpers/chickenBondsHelpers/index.ts +23 -23
  52. package/src/helpers/compoundHelpers/index.ts +181 -181
  53. package/src/helpers/curveUsdHelpers/index.ts +40 -32
  54. package/src/helpers/index.ts +5 -5
  55. package/src/helpers/makerHelpers/index.ts +94 -94
  56. package/src/helpers/sparkHelpers/index.ts +106 -106
  57. package/src/index.ts +40 -40
  58. package/src/liquity/index.ts +116 -116
  59. package/src/maker/index.ts +101 -101
  60. package/src/markets/aave/index.ts +80 -80
  61. package/src/markets/aave/marketAssets.ts +24 -32
  62. package/src/markets/compound/index.ts +141 -141
  63. package/src/markets/compound/marketsAssets.ts +48 -46
  64. package/src/markets/curveUsd/index.ts +69 -69
  65. package/src/markets/index.ts +3 -3
  66. package/src/markets/spark/index.ts +29 -29
  67. package/src/markets/spark/marketAssets.ts +10 -9
  68. package/src/moneymarket/moneymarketCommonService.ts +75 -75
  69. package/src/morpho/markets.ts +39 -39
  70. package/src/morphoAaveV2/index.ts +255 -255
  71. package/src/morphoAaveV3/index.ts +619 -619
  72. package/src/multicall/index.ts +22 -22
  73. package/src/services/dsrService.ts +15 -15
  74. package/src/services/priceService.ts +21 -21
  75. package/src/services/utils.ts +48 -35
  76. package/src/spark/index.ts +422 -422
  77. package/src/staking/staking.ts +167 -167
  78. package/src/types/aave.ts +256 -256
  79. package/src/types/chickenBonds.ts +45 -45
  80. package/src/types/common.ts +83 -83
  81. package/src/types/compound.ts +128 -128
  82. package/src/types/contracts/generated/CrvUSDView.ts +43 -8
  83. package/src/types/contracts/generated/MorphoAaveV3ProxyEthMarket.ts +2 -0
  84. package/src/types/curveUsd.ts +118 -112
  85. package/src/types/index.ts +6 -6
  86. package/src/types/liquity.ts +30 -30
  87. package/src/types/maker.ts +50 -50
  88. package/src/types/spark.ts +106 -106
  89. package/yarn-error.log +64 -0
@@ -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 { loanExists, usedAssets, network, selectedMarket } = _a, rest = __rest(_a, ["loanExists", "usedAssets", "network", "selectedMarket"]);
22
- const _supplied = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ supplied }) => supplied); // this is wrong if we are in soft-liquidations
23
- const _borrowed = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowed }) => borrowed);
24
- const _suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
25
- const _borrowedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowedUsd }) => borrowedUsd);
26
- const ratio = loanExists
27
- ? new decimal_js_1.default(_suppliedUsd)
28
- .dividedBy(_borrowedUsd)
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
- // we don't have borrowLimitUsd here
33
- return {
34
- ratio,
35
- supplied: _supplied,
36
- suppliedUsd: _suppliedUsd,
37
- borrowedUsd: _borrowedUsd,
38
- borrowed: _borrowed,
39
- safetyRatio: ratio,
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: readonly ["AAVE", "BAL", "BAT", "BUSD", "CRV", "DAI", "ENJ", "ETH", "GUSD", "LINK", "MANA", "MKR", "REN", "SNX", "SUSD", "TUSD", "UNI", "USDC", "USDT", "WBTC", "YFI", "xSUSHI", "ZRX", "RAI", "AMPL", "DPI", "USDP", "RENFIL", "FRAX", "FEI", "stETH", "ENS", "UST", "CVX", "1INCH", "LUSD"];
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: readonly ["WBTC", "ETH", "wstETH", "USDC", "DAI", "LINK", "AAVE", "cbETH", "USDT", "rETH", "LUSD", "UNI", "MKR", "SNX", "BAL", "LDO", "CRV", "ENS", "1INCH", "GHO", "FRAX", "RPL", "sDAI"];
6
- readonly 10: readonly ["DAI", "USDC.e", "USDT", "SUSD", "AAVE", "LINK", "WBTC", "ETH", "OP", "wstETH", "LUSD", "MAI", "rETH"];
7
- readonly 42161: readonly ["ETH", "DAI", "EURS", "USDC", "USDT", "AAVE", "LINK", "WBTC", "wstETH", "MAI", "rETH", "LUSD", "USDC.e", "FRAX", "ARB"];
8
- readonly 8453: readonly ["ETH", "USDbC", "cbETH", "wstETH"];
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
- 'AAVE', 'BAL', 'BAT', 'BUSD', 'CRV', 'DAI', 'ENJ', 'ETH', 'GUSD', 'LINK', 'MANA', 'MKR',
8
- 'REN', 'SNX', 'SUSD', 'TUSD', 'UNI', 'USDC', 'USDT', 'WBTC', 'YFI', 'xSUSHI', 'ZRX', 'RAI',
9
- 'AMPL', 'DPI', 'USDP', 'RENFIL', 'FRAX', 'FEI', 'stETH', 'ENS', 'UST', 'CVX', '1INCH', 'LUSD',
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.morphoAaveV2AssetDefaultMarket = [
12
- 'ETH', 'stETH', 'USDC', 'WBTC', 'USDT', 'DAI', 'CRV',
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.morphoAaveV3AssetEthMarket = [
15
- 'ETH', 'wstETH', 'DAI', 'USDC', 'WBTC', 'rETH', 'cbETH',
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
- 'WBTC', 'ETH', 'wstETH', 'USDC', 'DAI', 'LINK', 'AAVE', 'cbETH', 'USDT', 'rETH', 'LUSD', 'UNI', 'MKR', 'SNX', 'BAL',
20
- 'LDO', 'CRV', 'ENS', '1INCH', 'GHO', 'FRAX', 'RPL', 'sDAI',
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: readonly ["ETH", "COMP", "WBTC", "UNI", "LINK"];
5
+ readonly 1: string[];
4
6
  readonly 10: readonly [];
5
- readonly 42161: readonly ["ARB", "ETH", "GMX", "WBTC"];
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: readonly ["ARB", "ETH", "GMX", "WBTC"];
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: readonly ["cbETH", "wstETH", "rETH"];
20
+ readonly 1: string[];
16
21
  readonly 10: readonly [];
17
22
  readonly 42161: readonly [];
18
- readonly 8453: readonly ["cbETH"];
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: readonly ["ETH", "USDC", "DAI", "GNO", "rETH", "sDAI", "wstETH", "WBTC"];
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;
@@ -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;
@@ -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
- "getBandsData(address,uint256,uint256,uint256)"(market: string, collateral: number | string | BN, debt: number | string | BN, N: number | string | BN): NonPayableTransactionObject<CurveUsdView.BandStructOutput[]>;
199
- "getBandsData(address,int256,int256)"(market: string, from: number | string | BN, to: number | string | BN): NonPayableTransactionObject<CurveUsdView.BandStructOutput[]>;
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>;
@@ -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;