@defisaver/positions-sdk 0.0.59 → 0.0.60

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 (66) hide show
  1. package/README.md +63 -63
  2. package/cjs/aaveV3/index.js +2 -1
  3. package/cjs/config/contracts.d.ts +9 -0
  4. package/cjs/config/contracts.js +10 -1
  5. package/cjs/llamaLend/index.js +0 -3
  6. package/esm/aaveV3/index.js +2 -1
  7. package/esm/config/contracts.d.ts +9 -0
  8. package/esm/config/contracts.js +10 -1
  9. package/esm/llamaLend/index.js +0 -3
  10. package/package.json +40 -40
  11. package/src/aaveV2/index.ts +227 -227
  12. package/src/aaveV3/index.ts +562 -561
  13. package/src/assets/index.ts +60 -60
  14. package/src/chickenBonds/index.ts +123 -123
  15. package/src/compoundV2/index.ts +219 -219
  16. package/src/compoundV3/index.ts +273 -273
  17. package/src/config/contracts.js +860 -851
  18. package/src/constants/index.ts +5 -5
  19. package/src/contracts.ts +126 -126
  20. package/src/curveUsd/index.ts +229 -229
  21. package/src/exchange/index.ts +17 -17
  22. package/src/helpers/aaveHelpers/index.ts +134 -134
  23. package/src/helpers/chickenBondsHelpers/index.ts +23 -23
  24. package/src/helpers/compoundHelpers/index.ts +181 -181
  25. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  26. package/src/helpers/index.ts +7 -7
  27. package/src/helpers/llamaLendHelpers/index.ts +45 -45
  28. package/src/helpers/makerHelpers/index.ts +94 -94
  29. package/src/helpers/morphoBlueHelpers/index.ts +56 -56
  30. package/src/helpers/sparkHelpers/index.ts +106 -106
  31. package/src/index.ts +46 -46
  32. package/src/liquity/index.ts +116 -116
  33. package/src/llamaLend/index.ts +276 -279
  34. package/src/maker/index.ts +117 -117
  35. package/src/markets/aave/index.ts +80 -80
  36. package/src/markets/aave/marketAssets.ts +24 -24
  37. package/src/markets/compound/index.ts +141 -141
  38. package/src/markets/compound/marketsAssets.ts +48 -48
  39. package/src/markets/curveUsd/index.ts +69 -69
  40. package/src/markets/index.ts +5 -5
  41. package/src/markets/llamaLend/index.ts +65 -65
  42. package/src/markets/morphoBlue/index.ts +262 -262
  43. package/src/markets/spark/index.ts +29 -29
  44. package/src/markets/spark/marketAssets.ts +10 -10
  45. package/src/moneymarket/moneymarketCommonService.ts +75 -75
  46. package/src/morphoAaveV2/index.ts +256 -256
  47. package/src/morphoAaveV3/index.ts +619 -619
  48. package/src/morphoBlue/index.ts +177 -177
  49. package/src/multicall/index.ts +22 -22
  50. package/src/services/dsrService.ts +15 -15
  51. package/src/services/priceService.ts +21 -21
  52. package/src/services/utils.ts +51 -51
  53. package/src/setup.ts +8 -8
  54. package/src/spark/index.ts +422 -422
  55. package/src/staking/staking.ts +174 -174
  56. package/src/types/aave.ts +256 -256
  57. package/src/types/chickenBonds.ts +45 -45
  58. package/src/types/common.ts +83 -83
  59. package/src/types/compound.ts +128 -128
  60. package/src/types/curveUsd.ts +118 -118
  61. package/src/types/index.ts +8 -8
  62. package/src/types/liquity.ts +30 -30
  63. package/src/types/llamaLend.ts +119 -119
  64. package/src/types/maker.ts +50 -50
  65. package/src/types/morphoBlue.ts +107 -107
  66. package/src/types/spark.ts +106 -106
@@ -1,76 +1,76 @@
1
- import Dec from 'decimal.js';
2
- import { BLOCKS_IN_A_YEAR } from '../constants';
3
- import { MMUsedAssets } from '../types/common';
4
-
5
- export const getAssetsTotal = (assets: object, filter: any, transform: any) => (Object.values(assets) as any)
6
- .filter(filter)
7
- .map(transform)
8
- .reduce((acc: any, data: any) => new Dec(acc).add(data), '0')
9
- .toString();
10
-
11
- export const calcLongLiqPrice = (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => new Dec(assetPrice).mul(borrowedUsd).div(borrowLimitUsd).toString();
12
- export const calcShortLiqPrice = (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => new Dec(assetPrice).div(borrowedUsd).mul(borrowLimitUsd).toString();
13
-
14
- export const calcLeverageLiqPrice = (leverageType: string, assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => {
15
- if (leverageType === 'short') return calcShortLiqPrice(assetPrice, borrowedUsd, borrowLimitUsd);
16
- if (leverageType === 'long' || leverageType === 'lsd-leverage') return calcLongLiqPrice(assetPrice, borrowedUsd, borrowLimitUsd);
17
- console.error('invalid leverageType', leverageType);
18
- return '0';
19
- };
20
-
21
- export const calculateBorrowingAssetLimit = (assetBorrowedUsd: string, borrowLimitUsd: string) => new Dec(assetBorrowedUsd).div(borrowLimitUsd).times(100).toString();
22
-
23
- export const STABLE_ASSETS = ['DAI', 'USDC', 'USDT', 'TUSD', 'USDP', 'GUSD', 'BUSD', 'SUSD', 'FRAX', 'LUSD', 'USDC.e', 'GHO', 'sDAI', 'crvUSD'];
24
-
25
- export const isLeveragedPos = (usedAssets: MMUsedAssets, dustLimit = 5) => {
26
- let borrowUnstable = 0;
27
- let supplyStable = 0;
28
- let borrowStable = 0;
29
- let supplyUnstable = 0;
30
- let longAsset = '';
31
- let shortAsset = '';
32
- Object.values(usedAssets).forEach(({
33
- symbol, suppliedUsd, borrowedUsd, collateral,
34
- }) => {
35
- const isSupplied = (+suppliedUsd) > dustLimit; // ignore dust like <limit leftover supply
36
- const isBorrowed = (+borrowedUsd) > dustLimit; // ignore dust like <limit leftover supply
37
- if (isSupplied && STABLE_ASSETS.includes(symbol) && collateral) supplyStable += 1;
38
- if (isBorrowed && STABLE_ASSETS.includes(symbol)) borrowStable += 1;
39
- if (isBorrowed && !STABLE_ASSETS.includes(symbol)) {
40
- borrowUnstable += 1;
41
- shortAsset = symbol;
42
- }
43
- if (isSupplied && !STABLE_ASSETS.includes(symbol) && collateral) {
44
- supplyUnstable += 1;
45
- longAsset = symbol;
46
- }
47
- });
48
- const isLong = borrowStable > 0 && borrowUnstable === 0 && supplyUnstable === 1 && supplyStable === 0;
49
- const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
50
- // lsd -> liquid staking derivative
51
- const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH'].includes(longAsset);
52
- if (isLong) {
53
- return {
54
- leveragedType: 'long',
55
- leveragedAsset: longAsset,
56
- };
57
- }
58
- if (isShort) {
59
- return {
60
- leveragedType: 'short',
61
- leveragedAsset: shortAsset,
62
- };
63
- }
64
- if (isLsdLeveraged) {
65
- return {
66
- leveragedType: 'lsd-leverage',
67
- leveragedAsset: longAsset,
68
- };
69
- }
70
- return {
71
- leveragedType: '',
72
- leveragedAsset: '',
73
- };
74
- };
75
-
1
+ import Dec from 'decimal.js';
2
+ import { BLOCKS_IN_A_YEAR } from '../constants';
3
+ import { MMUsedAssets } from '../types/common';
4
+
5
+ export const getAssetsTotal = (assets: object, filter: any, transform: any) => (Object.values(assets) as any)
6
+ .filter(filter)
7
+ .map(transform)
8
+ .reduce((acc: any, data: any) => new Dec(acc).add(data), '0')
9
+ .toString();
10
+
11
+ export const calcLongLiqPrice = (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => new Dec(assetPrice).mul(borrowedUsd).div(borrowLimitUsd).toString();
12
+ export const calcShortLiqPrice = (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => new Dec(assetPrice).div(borrowedUsd).mul(borrowLimitUsd).toString();
13
+
14
+ export const calcLeverageLiqPrice = (leverageType: string, assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => {
15
+ if (leverageType === 'short') return calcShortLiqPrice(assetPrice, borrowedUsd, borrowLimitUsd);
16
+ if (leverageType === 'long' || leverageType === 'lsd-leverage') return calcLongLiqPrice(assetPrice, borrowedUsd, borrowLimitUsd);
17
+ console.error('invalid leverageType', leverageType);
18
+ return '0';
19
+ };
20
+
21
+ export const calculateBorrowingAssetLimit = (assetBorrowedUsd: string, borrowLimitUsd: string) => new Dec(assetBorrowedUsd).div(borrowLimitUsd).times(100).toString();
22
+
23
+ export const STABLE_ASSETS = ['DAI', 'USDC', 'USDT', 'TUSD', 'USDP', 'GUSD', 'BUSD', 'SUSD', 'FRAX', 'LUSD', 'USDC.e', 'GHO', 'sDAI', 'crvUSD'];
24
+
25
+ export const isLeveragedPos = (usedAssets: MMUsedAssets, dustLimit = 5) => {
26
+ let borrowUnstable = 0;
27
+ let supplyStable = 0;
28
+ let borrowStable = 0;
29
+ let supplyUnstable = 0;
30
+ let longAsset = '';
31
+ let shortAsset = '';
32
+ Object.values(usedAssets).forEach(({
33
+ symbol, suppliedUsd, borrowedUsd, collateral,
34
+ }) => {
35
+ const isSupplied = (+suppliedUsd) > dustLimit; // ignore dust like <limit leftover supply
36
+ const isBorrowed = (+borrowedUsd) > dustLimit; // ignore dust like <limit leftover supply
37
+ if (isSupplied && STABLE_ASSETS.includes(symbol) && collateral) supplyStable += 1;
38
+ if (isBorrowed && STABLE_ASSETS.includes(symbol)) borrowStable += 1;
39
+ if (isBorrowed && !STABLE_ASSETS.includes(symbol)) {
40
+ borrowUnstable += 1;
41
+ shortAsset = symbol;
42
+ }
43
+ if (isSupplied && !STABLE_ASSETS.includes(symbol) && collateral) {
44
+ supplyUnstable += 1;
45
+ longAsset = symbol;
46
+ }
47
+ });
48
+ const isLong = borrowStable > 0 && borrowUnstable === 0 && supplyUnstable === 1 && supplyStable === 0;
49
+ const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
50
+ // lsd -> liquid staking derivative
51
+ const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH'].includes(longAsset);
52
+ if (isLong) {
53
+ return {
54
+ leveragedType: 'long',
55
+ leveragedAsset: longAsset,
56
+ };
57
+ }
58
+ if (isShort) {
59
+ return {
60
+ leveragedType: 'short',
61
+ leveragedAsset: shortAsset,
62
+ };
63
+ }
64
+ if (isLsdLeveraged) {
65
+ return {
66
+ leveragedType: 'lsd-leverage',
67
+ leveragedAsset: longAsset,
68
+ };
69
+ }
70
+ return {
71
+ leveragedType: '',
72
+ leveragedAsset: '',
73
+ };
74
+ };
75
+
76
76
  export const aprToApy = (interest: string | number, frequency = BLOCKS_IN_A_YEAR) => ((1 + (+interest / 100) / frequency) ** frequency - 1) * 100; // eslint-disable-line