@defisaver/positions-sdk 2.1.11 → 2.1.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mocharc.json +4 -4
- package/.nvmrc +1 -1
- package/README.md +64 -64
- package/cjs/aaveV3/index.js +1 -1
- package/cjs/contracts.d.ts +100947 -134653
- package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
- package/cjs/markets/aave/marketAssets.js +1 -1
- package/cjs/services/viem.d.ts +2 -3254
- package/cjs/staking/staking.d.ts +1 -1
- package/cjs/staking/staking.js +17 -14
- package/esm/aaveV3/index.js +1 -1
- package/esm/contracts.d.ts +100947 -134653
- package/esm/helpers/morphoBlueHelpers/index.js +66 -66
- package/esm/markets/aave/marketAssets.js +1 -1
- package/esm/services/viem.d.ts +2 -3254
- package/esm/staking/staking.d.ts +1 -1
- package/esm/staking/staking.js +17 -14
- package/package.json +47 -47
- package/src/aaveV2/index.ts +240 -240
- package/src/aaveV3/index.ts +614 -614
- package/src/aaveV3/merit.ts +97 -97
- package/src/aaveV3/merkl.ts +74 -74
- package/src/claiming/aaveV3.ts +154 -154
- package/src/claiming/compV3.ts +22 -22
- package/src/claiming/index.ts +12 -12
- package/src/claiming/king.ts +66 -66
- package/src/claiming/morphoBlue.ts +118 -118
- package/src/claiming/spark.ts +225 -225
- package/src/compoundV2/index.ts +244 -244
- package/src/compoundV3/index.ts +274 -274
- package/src/config/contracts.ts +1251 -1251
- package/src/constants/index.ts +10 -10
- package/src/contracts.ts +120 -120
- package/src/curveUsd/index.ts +254 -254
- package/src/eulerV2/index.ts +324 -324
- package/src/exchange/index.ts +25 -25
- package/src/fluid/index.ts +1668 -1668
- package/src/helpers/aaveHelpers/index.ts +187 -187
- package/src/helpers/compoundHelpers/index.ts +283 -283
- package/src/helpers/curveUsdHelpers/index.ts +40 -40
- package/src/helpers/eulerHelpers/index.ts +222 -222
- package/src/helpers/fluidHelpers/index.ts +326 -326
- package/src/helpers/index.ts +10 -10
- package/src/helpers/liquityV2Helpers/index.ts +82 -82
- package/src/helpers/llamaLendHelpers/index.ts +53 -53
- package/src/helpers/makerHelpers/index.ts +52 -52
- package/src/helpers/morphoBlueHelpers/index.ts +396 -396
- package/src/helpers/sparkHelpers/index.ts +158 -158
- package/src/index.ts +47 -47
- package/src/liquity/index.ts +159 -159
- package/src/liquityV2/index.ts +657 -657
- package/src/llamaLend/index.ts +305 -305
- package/src/maker/index.ts +223 -223
- package/src/markets/aave/index.ts +116 -116
- package/src/markets/aave/marketAssets.ts +54 -54
- package/src/markets/compound/index.ts +238 -238
- package/src/markets/compound/marketsAssets.ts +97 -97
- package/src/markets/curveUsd/index.ts +69 -69
- package/src/markets/euler/index.ts +26 -26
- package/src/markets/fluid/index.ts +2460 -2460
- package/src/markets/index.ts +25 -25
- package/src/markets/liquityV2/index.ts +102 -102
- package/src/markets/llamaLend/contractAddresses.ts +141 -141
- package/src/markets/llamaLend/index.ts +235 -235
- package/src/markets/morphoBlue/index.ts +895 -895
- package/src/markets/spark/index.ts +29 -29
- package/src/markets/spark/marketAssets.ts +12 -12
- package/src/moneymarket/moneymarketCommonService.ts +80 -80
- package/src/morphoBlue/index.ts +274 -274
- package/src/portfolio/index.ts +570 -570
- package/src/services/priceService.ts +159 -159
- package/src/services/utils.ts +115 -115
- package/src/services/viem.ts +34 -34
- package/src/setup.ts +8 -8
- package/src/spark/index.ts +456 -456
- package/src/staking/eligibility.ts +53 -53
- package/src/staking/index.ts +1 -1
- package/src/staking/staking.ts +177 -172
- package/src/types/aave.ts +189 -189
- package/src/types/claiming.ts +109 -109
- package/src/types/common.ts +107 -107
- package/src/types/compound.ts +136 -136
- package/src/types/curveUsd.ts +123 -123
- package/src/types/euler.ts +175 -175
- package/src/types/fluid.ts +452 -452
- package/src/types/index.ts +13 -13
- package/src/types/liquity.ts +30 -30
- package/src/types/liquityV2.ts +126 -126
- package/src/types/llamaLend.ts +159 -159
- package/src/types/maker.ts +63 -63
- package/src/types/merit.ts +1 -1
- package/src/types/merkl.ts +70 -70
- package/src/types/morphoBlue.ts +194 -194
- package/src/types/portfolio.ts +60 -60
- package/src/types/spark.ts +133 -133
- package/src/umbrella/index.ts +69 -69
- package/src/umbrella/umbrellaUtils.ts +29 -29
|
@@ -1,159 +1,159 @@
|
|
|
1
|
-
import Dec from 'decimal.js';
|
|
2
|
-
import { getAssetInfo } from '@defisaver/tokens';
|
|
3
|
-
import { Client, PublicClient } from 'viem';
|
|
4
|
-
import {
|
|
5
|
-
COMPPriceFeedContractViem,
|
|
6
|
-
BTCPriceFeedContractViem,
|
|
7
|
-
ETHPriceFeedContractViem,
|
|
8
|
-
USDCPriceFeedContractViem,
|
|
9
|
-
WstETHPriceFeedContractViem,
|
|
10
|
-
WeETHPriceFeedContractViem,
|
|
11
|
-
} from '../contracts';
|
|
12
|
-
import { EthAddress, NetworkNumber } from '../types/common';
|
|
13
|
-
import { getEthAmountForDecimals } from './utils';
|
|
14
|
-
|
|
15
|
-
export const getEthPrice = async (client: Client) => {
|
|
16
|
-
const contract = ETHPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
17
|
-
const price = await contract.read.latestAnswer();
|
|
18
|
-
return new Dec(price.toString()).div(1e8).toString();
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export const getUSDCPrice = async (client: Client) => {
|
|
22
|
-
const contract = USDCPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
23
|
-
const price = await contract.read.latestAnswer();
|
|
24
|
-
return new Dec(price.toString()).div(1e8).toString();
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
export const getCompPrice = async (client: Client) => {
|
|
28
|
-
const contract = COMPPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
29
|
-
const price = await contract.read.latestAnswer();
|
|
30
|
-
return new Dec(price.toString()).div(1e8).toString();
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
export const getWstETHPrice = async (client: Client, network: NetworkNumber = NetworkNumber.Eth) => {
|
|
34
|
-
const wstETHFeedContract = WstETHPriceFeedContractViem(client, network);
|
|
35
|
-
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
36
|
-
|
|
37
|
-
const [ethPriceWei, wstETHRateWei, decimals] = await Promise.all([
|
|
38
|
-
ethFeedContract.read.latestAnswer(),
|
|
39
|
-
wstETHFeedContract.read.latestRoundData(),
|
|
40
|
-
wstETHFeedContract.read.decimals(),
|
|
41
|
-
]);
|
|
42
|
-
|
|
43
|
-
const ethPrice = new Dec(ethPriceWei.toString()).div(1e8);
|
|
44
|
-
|
|
45
|
-
const wstETHRate = getEthAmountForDecimals(wstETHRateWei[1].toString(), decimals);
|
|
46
|
-
|
|
47
|
-
return new Dec(ethPrice).mul(wstETHRate).toString();
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
export const getWeETHPrice = async (client: Client, network: NetworkNumber = NetworkNumber.Eth) => {
|
|
51
|
-
const weETHFeedContract = WeETHPriceFeedContractViem(client, network);
|
|
52
|
-
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
53
|
-
|
|
54
|
-
const [ethPriceWei, weETHRateWei, decimals] = await Promise.all([
|
|
55
|
-
ethFeedContract.read.latestAnswer(),
|
|
56
|
-
weETHFeedContract.read.latestRoundData(),
|
|
57
|
-
weETHFeedContract.read.decimals(),
|
|
58
|
-
]);
|
|
59
|
-
|
|
60
|
-
const ethPrice = new Dec(ethPriceWei.toString()).div(1e8);
|
|
61
|
-
|
|
62
|
-
const weETHRate = getEthAmountForDecimals(weETHRateWei[1].toString(), decimals);
|
|
63
|
-
|
|
64
|
-
return new Dec(ethPrice).mul(weETHRate).toString();
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
export const getWstETHChainLinkPriceCalls = (client: PublicClient, network: NetworkNumber) => {
|
|
68
|
-
const wstETHFeedContract = WstETHPriceFeedContractViem(client, network);
|
|
69
|
-
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
70
|
-
const calls = [
|
|
71
|
-
{
|
|
72
|
-
address: ethFeedContract.address,
|
|
73
|
-
abi: ethFeedContract.abi,
|
|
74
|
-
functionName: 'latestAnswer',
|
|
75
|
-
args: [],
|
|
76
|
-
},
|
|
77
|
-
{
|
|
78
|
-
address: wstETHFeedContract.address,
|
|
79
|
-
abi: wstETHFeedContract.abi,
|
|
80
|
-
functionName: 'latestRoundData',
|
|
81
|
-
args: [],
|
|
82
|
-
},
|
|
83
|
-
{
|
|
84
|
-
address: wstETHFeedContract.address,
|
|
85
|
-
abi: wstETHFeedContract.abi,
|
|
86
|
-
functionName: 'decimals',
|
|
87
|
-
args: [],
|
|
88
|
-
},
|
|
89
|
-
];
|
|
90
|
-
return calls;
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
export const getWeETHChainLinkPriceCalls = (client: PublicClient, network: NetworkNumber) => {
|
|
94
|
-
const weETHFeedContract = WeETHPriceFeedContractViem(client, network);
|
|
95
|
-
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
96
|
-
const calls = [
|
|
97
|
-
{
|
|
98
|
-
address: ethFeedContract.address,
|
|
99
|
-
abi: ethFeedContract.abi,
|
|
100
|
-
functionName: 'latestAnswer',
|
|
101
|
-
args: [],
|
|
102
|
-
},
|
|
103
|
-
{
|
|
104
|
-
address: weETHFeedContract.address,
|
|
105
|
-
abi: weETHFeedContract.abi,
|
|
106
|
-
functionName: 'latestRoundData',
|
|
107
|
-
args: [],
|
|
108
|
-
},
|
|
109
|
-
{
|
|
110
|
-
address: weETHFeedContract.address,
|
|
111
|
-
abi: weETHFeedContract.abi,
|
|
112
|
-
functionName: 'decimals',
|
|
113
|
-
args: [],
|
|
114
|
-
},
|
|
115
|
-
];
|
|
116
|
-
return calls;
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
export const parseWstETHPriceCalls = (_ethPrice: string, wstETHrateAnswer: string, decimals: string) => {
|
|
120
|
-
const ethPrice = new Dec(_ethPrice).div(1e8);
|
|
121
|
-
const wstETHRate = getEthAmountForDecimals(wstETHrateAnswer, decimals);
|
|
122
|
-
return { ethPrice, wstETHRate };
|
|
123
|
-
};
|
|
124
|
-
|
|
125
|
-
export const parseWeETHPriceCalls = (_ethPrice: string, weETHrateAnswer: string, decimals: string) => {
|
|
126
|
-
const ethPrice = new Dec(_ethPrice).div(1e8);
|
|
127
|
-
const weETHRate = getEthAmountForDecimals(weETHrateAnswer, decimals);
|
|
128
|
-
return { ethPrice, weETHRate };
|
|
129
|
-
};
|
|
130
|
-
|
|
131
|
-
// this is a fixed version, the original version is above but requires to refactor comp v3 function, so it's easier to just copy the function for now
|
|
132
|
-
export const getWstETHPriceFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
133
|
-
const calls = getWstETHChainLinkPriceCalls(client, network);
|
|
134
|
-
const results = await client.multicall({ contracts: calls });
|
|
135
|
-
// @ts-ignore
|
|
136
|
-
const { ethPrice, wstETHRate } = parseWstETHPriceCalls(results[0].result!.toString(), results[1].result[1]!.toString(), results[2].result!.toString());
|
|
137
|
-
|
|
138
|
-
return new Dec(ethPrice).mul(wstETHRate).toString();
|
|
139
|
-
};
|
|
140
|
-
|
|
141
|
-
export const getBTCPriceForFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
142
|
-
const contract = BTCPriceFeedContractViem(client, network);
|
|
143
|
-
const price = await contract.read.latestAnswer();
|
|
144
|
-
return new Dec(price).div(1e8).toString();
|
|
145
|
-
};
|
|
146
|
-
|
|
147
|
-
export const getEthPriceForFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
148
|
-
const contract = ETHPriceFeedContractViem(client, network);
|
|
149
|
-
const price = await contract.read.latestAnswer();
|
|
150
|
-
return new Dec(price).div(1e8).toString();
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
// chainlink price feed available only on mainnet
|
|
154
|
-
export const getChainlinkAssetAddress = (symbol: string, network: NetworkNumber): EthAddress => {
|
|
155
|
-
// Chainlink only has BTC/USD feed so we use that for BTC derivatives
|
|
156
|
-
if (['WBTC', 'RENBTC'].includes(symbol?.toUpperCase())) return '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB';
|
|
157
|
-
if (symbol?.toUpperCase() === 'WETH') return getAssetInfo('ETH').addresses[network] as EthAddress;
|
|
158
|
-
return getAssetInfo(symbol).addresses[network] as EthAddress;
|
|
159
|
-
};
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import { getAssetInfo } from '@defisaver/tokens';
|
|
3
|
+
import { Client, PublicClient } from 'viem';
|
|
4
|
+
import {
|
|
5
|
+
COMPPriceFeedContractViem,
|
|
6
|
+
BTCPriceFeedContractViem,
|
|
7
|
+
ETHPriceFeedContractViem,
|
|
8
|
+
USDCPriceFeedContractViem,
|
|
9
|
+
WstETHPriceFeedContractViem,
|
|
10
|
+
WeETHPriceFeedContractViem,
|
|
11
|
+
} from '../contracts';
|
|
12
|
+
import { EthAddress, NetworkNumber } from '../types/common';
|
|
13
|
+
import { getEthAmountForDecimals } from './utils';
|
|
14
|
+
|
|
15
|
+
export const getEthPrice = async (client: Client) => {
|
|
16
|
+
const contract = ETHPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
17
|
+
const price = await contract.read.latestAnswer();
|
|
18
|
+
return new Dec(price.toString()).div(1e8).toString();
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export const getUSDCPrice = async (client: Client) => {
|
|
22
|
+
const contract = USDCPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
23
|
+
const price = await contract.read.latestAnswer();
|
|
24
|
+
return new Dec(price.toString()).div(1e8).toString();
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export const getCompPrice = async (client: Client) => {
|
|
28
|
+
const contract = COMPPriceFeedContractViem(client, NetworkNumber.Eth);
|
|
29
|
+
const price = await contract.read.latestAnswer();
|
|
30
|
+
return new Dec(price.toString()).div(1e8).toString();
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
export const getWstETHPrice = async (client: Client, network: NetworkNumber = NetworkNumber.Eth) => {
|
|
34
|
+
const wstETHFeedContract = WstETHPriceFeedContractViem(client, network);
|
|
35
|
+
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
36
|
+
|
|
37
|
+
const [ethPriceWei, wstETHRateWei, decimals] = await Promise.all([
|
|
38
|
+
ethFeedContract.read.latestAnswer(),
|
|
39
|
+
wstETHFeedContract.read.latestRoundData(),
|
|
40
|
+
wstETHFeedContract.read.decimals(),
|
|
41
|
+
]);
|
|
42
|
+
|
|
43
|
+
const ethPrice = new Dec(ethPriceWei.toString()).div(1e8);
|
|
44
|
+
|
|
45
|
+
const wstETHRate = getEthAmountForDecimals(wstETHRateWei[1].toString(), decimals);
|
|
46
|
+
|
|
47
|
+
return new Dec(ethPrice).mul(wstETHRate).toString();
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
export const getWeETHPrice = async (client: Client, network: NetworkNumber = NetworkNumber.Eth) => {
|
|
51
|
+
const weETHFeedContract = WeETHPriceFeedContractViem(client, network);
|
|
52
|
+
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
53
|
+
|
|
54
|
+
const [ethPriceWei, weETHRateWei, decimals] = await Promise.all([
|
|
55
|
+
ethFeedContract.read.latestAnswer(),
|
|
56
|
+
weETHFeedContract.read.latestRoundData(),
|
|
57
|
+
weETHFeedContract.read.decimals(),
|
|
58
|
+
]);
|
|
59
|
+
|
|
60
|
+
const ethPrice = new Dec(ethPriceWei.toString()).div(1e8);
|
|
61
|
+
|
|
62
|
+
const weETHRate = getEthAmountForDecimals(weETHRateWei[1].toString(), decimals);
|
|
63
|
+
|
|
64
|
+
return new Dec(ethPrice).mul(weETHRate).toString();
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export const getWstETHChainLinkPriceCalls = (client: PublicClient, network: NetworkNumber) => {
|
|
68
|
+
const wstETHFeedContract = WstETHPriceFeedContractViem(client, network);
|
|
69
|
+
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
70
|
+
const calls = [
|
|
71
|
+
{
|
|
72
|
+
address: ethFeedContract.address,
|
|
73
|
+
abi: ethFeedContract.abi,
|
|
74
|
+
functionName: 'latestAnswer',
|
|
75
|
+
args: [],
|
|
76
|
+
},
|
|
77
|
+
{
|
|
78
|
+
address: wstETHFeedContract.address,
|
|
79
|
+
abi: wstETHFeedContract.abi,
|
|
80
|
+
functionName: 'latestRoundData',
|
|
81
|
+
args: [],
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
address: wstETHFeedContract.address,
|
|
85
|
+
abi: wstETHFeedContract.abi,
|
|
86
|
+
functionName: 'decimals',
|
|
87
|
+
args: [],
|
|
88
|
+
},
|
|
89
|
+
];
|
|
90
|
+
return calls;
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
export const getWeETHChainLinkPriceCalls = (client: PublicClient, network: NetworkNumber) => {
|
|
94
|
+
const weETHFeedContract = WeETHPriceFeedContractViem(client, network);
|
|
95
|
+
const ethFeedContract = ETHPriceFeedContractViem(client, network);
|
|
96
|
+
const calls = [
|
|
97
|
+
{
|
|
98
|
+
address: ethFeedContract.address,
|
|
99
|
+
abi: ethFeedContract.abi,
|
|
100
|
+
functionName: 'latestAnswer',
|
|
101
|
+
args: [],
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
address: weETHFeedContract.address,
|
|
105
|
+
abi: weETHFeedContract.abi,
|
|
106
|
+
functionName: 'latestRoundData',
|
|
107
|
+
args: [],
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
address: weETHFeedContract.address,
|
|
111
|
+
abi: weETHFeedContract.abi,
|
|
112
|
+
functionName: 'decimals',
|
|
113
|
+
args: [],
|
|
114
|
+
},
|
|
115
|
+
];
|
|
116
|
+
return calls;
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
export const parseWstETHPriceCalls = (_ethPrice: string, wstETHrateAnswer: string, decimals: string) => {
|
|
120
|
+
const ethPrice = new Dec(_ethPrice).div(1e8);
|
|
121
|
+
const wstETHRate = getEthAmountForDecimals(wstETHrateAnswer, decimals);
|
|
122
|
+
return { ethPrice, wstETHRate };
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
export const parseWeETHPriceCalls = (_ethPrice: string, weETHrateAnswer: string, decimals: string) => {
|
|
126
|
+
const ethPrice = new Dec(_ethPrice).div(1e8);
|
|
127
|
+
const weETHRate = getEthAmountForDecimals(weETHrateAnswer, decimals);
|
|
128
|
+
return { ethPrice, weETHRate };
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
// this is a fixed version, the original version is above but requires to refactor comp v3 function, so it's easier to just copy the function for now
|
|
132
|
+
export const getWstETHPriceFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
133
|
+
const calls = getWstETHChainLinkPriceCalls(client, network);
|
|
134
|
+
const results = await client.multicall({ contracts: calls });
|
|
135
|
+
// @ts-ignore
|
|
136
|
+
const { ethPrice, wstETHRate } = parseWstETHPriceCalls(results[0].result!.toString(), results[1].result[1]!.toString(), results[2].result!.toString());
|
|
137
|
+
|
|
138
|
+
return new Dec(ethPrice).mul(wstETHRate).toString();
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
export const getBTCPriceForFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
142
|
+
const contract = BTCPriceFeedContractViem(client, network);
|
|
143
|
+
const price = await contract.read.latestAnswer();
|
|
144
|
+
return new Dec(price).div(1e8).toString();
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
export const getEthPriceForFluid = async (client: PublicClient, network: NetworkNumber) => {
|
|
148
|
+
const contract = ETHPriceFeedContractViem(client, network);
|
|
149
|
+
const price = await contract.read.latestAnswer();
|
|
150
|
+
return new Dec(price).div(1e8).toString();
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
// chainlink price feed available only on mainnet
|
|
154
|
+
export const getChainlinkAssetAddress = (symbol: string, network: NetworkNumber): EthAddress => {
|
|
155
|
+
// Chainlink only has BTC/USD feed so we use that for BTC derivatives
|
|
156
|
+
if (['WBTC', 'RENBTC'].includes(symbol?.toUpperCase())) return '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB';
|
|
157
|
+
if (symbol?.toUpperCase() === 'WETH') return getAssetInfo('ETH').addresses[network] as EthAddress;
|
|
158
|
+
return getAssetInfo(symbol).addresses[network] as EthAddress;
|
|
159
|
+
};
|
package/src/services/utils.ts
CHANGED
|
@@ -1,116 +1,116 @@
|
|
|
1
|
-
import Dec from 'decimal.js';
|
|
2
|
-
import { getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
3
|
-
import { NetworkNumber } from '../types/common';
|
|
4
|
-
|
|
5
|
-
export const isLayer2Network = (networkId: NetworkNumber) => [NetworkNumber.Opt, NetworkNumber.Arb, NetworkNumber.Base, NetworkNumber.Linea, NetworkNumber.Plasma].includes(+networkId);
|
|
6
|
-
|
|
7
|
-
export const addToObjectIf = (condition: any, item: any) => (condition ? item : {});
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
export const addToArrayIf = (condition: any, ...items: any[]) => (condition ? items : []);
|
|
11
|
-
|
|
12
|
-
export const stEthToWstEth = (maybeStEth: any) => maybeStEth?.replace(/^stETH$/, 'wstETH');
|
|
13
|
-
|
|
14
|
-
export const wstEthToStEth = (maybeStEth: any) => maybeStEth?.replace(/^wstETH$/, 'stETH');
|
|
15
|
-
|
|
16
|
-
export const getAbiItem = (abi: any, methodName: string) => abi.find((i: any) => i.name === methodName);
|
|
17
|
-
|
|
18
|
-
export const ADDRESS_REGEX = /0x[0-9a-fA-F]{40}/;
|
|
19
|
-
export const isAddress = (address: string) => typeof address === 'string' && (new RegExp(ADDRESS_REGEX).test(address));
|
|
20
|
-
|
|
21
|
-
export const compareAddresses = (addr1 = '', addr2 = '') => addr1.toLowerCase() === addr2.toLowerCase();
|
|
22
|
-
|
|
23
|
-
export const getWeiAmountForDecimals = (amount: string | number, decimals: number) => new Dec(amount).mul(10 ** decimals).floor().toString();
|
|
24
|
-
|
|
25
|
-
export const getEthAmountForDecimals = (amount: string | number, decimals: string | number) => new Dec(amount).div(10 ** +decimals).toString();
|
|
26
|
-
|
|
27
|
-
export const handleWbtcLegacy = (asset: string) => (asset === 'WBTC Legacy' ? 'WBTC' : asset);
|
|
28
|
-
|
|
29
|
-
export const bytesToString = (hex: string) => Buffer.from(hex.replace(/^0x/, ''), 'hex')
|
|
30
|
-
.toString()
|
|
31
|
-
// eslint-disable-next-line no-control-regex
|
|
32
|
-
.replace(/\x00/g, '');
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Map an input value from one range (minInput, maxInput) to a value in another range (minOutput, maxOutput)
|
|
36
|
-
*/
|
|
37
|
-
export const mapRange = (input: number | string, minInput: number | string, maxInput: number | string, minOutput:number | string, maxOutput: number | string) => {
|
|
38
|
-
// slope = 1.0 * (output_end - output_start) / (input_end - input_start)
|
|
39
|
-
const inputDiff = new Dec(maxInput).minus(minInput);
|
|
40
|
-
const outputDiff = new Dec(maxOutput).minus(minOutput);
|
|
41
|
-
const slope = new Dec(outputDiff).div(inputDiff);
|
|
42
|
-
|
|
43
|
-
// output = output_start + slope * (input - input_start)
|
|
44
|
-
return new Dec(minOutput).plus(new Dec(slope).mul(new Dec(input).minus(minInput))).toDP(2).toNumber();
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
// eslint-disable-next-line no-bitwise
|
|
48
|
-
export const isEnabledOnBitmap = (bitmap: number, assetId: number) => (BigInt(bitmap) >> BigInt(assetId)) & BigInt(1);
|
|
49
|
-
|
|
50
|
-
export const MAXUINT:string = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
|
|
51
|
-
|
|
52
|
-
export const isMaxuint = (amount: string) => compareAddresses(MAXUINT, amount);
|
|
53
|
-
|
|
54
|
-
export const isMainnetNetwork = (network: NetworkNumber) => network === NetworkNumber.Eth;
|
|
55
|
-
|
|
56
|
-
export const DEFAULT_TIMEOUT = 2000; // 2 seconds
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* Converts web3 hybrid response (that can be used as objects and arrays, so has duplicated values) to objects.
|
|
60
|
-
* @param value
|
|
61
|
-
*/
|
|
62
|
-
export const convertHybridArraysToObjects = (value: any): any => {
|
|
63
|
-
if (Array.isArray(value)) {
|
|
64
|
-
const keys = Object.keys(value);
|
|
65
|
-
const hasNamedKeys = keys.some((key) => Number.isNaN(Number(key)));
|
|
66
|
-
|
|
67
|
-
// If array has named keys, treat it as an object and keep only those
|
|
68
|
-
if (hasNamedKeys) {
|
|
69
|
-
const result: Record<string, any> = {};
|
|
70
|
-
for (const [key, val] of Object.entries(value)) {
|
|
71
|
-
if (Number.isNaN(Number(key))) {
|
|
72
|
-
result[key] = convertHybridArraysToObjects(val);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
return result;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
// Else, treat as a regular array
|
|
79
|
-
return value.map(convertHybridArraysToObjects);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// If it's an object (but not an array), recurse into its values
|
|
83
|
-
if (value && typeof value === 'object') {
|
|
84
|
-
const result: Record<string, any> = {};
|
|
85
|
-
for (const [key, val] of Object.entries(value)) {
|
|
86
|
-
result[key] = convertHybridArraysToObjects(val);
|
|
87
|
-
}
|
|
88
|
-
return result;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return value;
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
export const ethToWeth = (maybeEth: string) => maybeEth?.replace(/^ETH$/, 'WETH');
|
|
95
|
-
|
|
96
|
-
export const wethToEth = (maybeWeth: string) => maybeWeth?.replace(/^WETH$/, 'ETH');
|
|
97
|
-
|
|
98
|
-
export const wethToEthByAddress = (maybeWethAddr: string, chainId = NetworkNumber.Eth) => getAssetInfo(wethToEth(getAssetInfoByAddress(maybeWethAddr, chainId).symbol), chainId).address;
|
|
99
|
-
|
|
100
|
-
export const ethToWethByAddress = (maybeEthAddr: string, chainId = NetworkNumber.Eth) => getAssetInfo(ethToWeth(getAssetInfoByAddress(maybeEthAddr, chainId).symbol), chainId).address;
|
|
101
|
-
|
|
102
|
-
export const xplToWxpl = (maybeXpl: string) => maybeXpl?.replace(/^XPL$/, 'WXPL');
|
|
103
|
-
|
|
104
|
-
export const wxplToXpl = (maybeWxpl: string) => maybeWxpl?.replace(/^WXPL$/, 'XPL');
|
|
105
|
-
|
|
106
|
-
export const getWrappedNativeAssetFromUnwrapped = (symbol: string) => {
|
|
107
|
-
if (symbol === 'ETH') return 'WETH';
|
|
108
|
-
if (symbol === 'XPL') return 'WXPL';
|
|
109
|
-
return symbol;
|
|
110
|
-
};
|
|
111
|
-
|
|
112
|
-
export const getNativeAssetFromWrapped = (symbol: string) => {
|
|
113
|
-
if (symbol === 'WETH') return 'ETH';
|
|
114
|
-
if (symbol === 'WXPL') return 'XPL';
|
|
115
|
-
return symbol;
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import { getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
3
|
+
import { NetworkNumber } from '../types/common';
|
|
4
|
+
|
|
5
|
+
export const isLayer2Network = (networkId: NetworkNumber) => [NetworkNumber.Opt, NetworkNumber.Arb, NetworkNumber.Base, NetworkNumber.Linea, NetworkNumber.Plasma].includes(+networkId);
|
|
6
|
+
|
|
7
|
+
export const addToObjectIf = (condition: any, item: any) => (condition ? item : {});
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
export const addToArrayIf = (condition: any, ...items: any[]) => (condition ? items : []);
|
|
11
|
+
|
|
12
|
+
export const stEthToWstEth = (maybeStEth: any) => maybeStEth?.replace(/^stETH$/, 'wstETH');
|
|
13
|
+
|
|
14
|
+
export const wstEthToStEth = (maybeStEth: any) => maybeStEth?.replace(/^wstETH$/, 'stETH');
|
|
15
|
+
|
|
16
|
+
export const getAbiItem = (abi: any, methodName: string) => abi.find((i: any) => i.name === methodName);
|
|
17
|
+
|
|
18
|
+
export const ADDRESS_REGEX = /0x[0-9a-fA-F]{40}/;
|
|
19
|
+
export const isAddress = (address: string) => typeof address === 'string' && (new RegExp(ADDRESS_REGEX).test(address));
|
|
20
|
+
|
|
21
|
+
export const compareAddresses = (addr1 = '', addr2 = '') => addr1.toLowerCase() === addr2.toLowerCase();
|
|
22
|
+
|
|
23
|
+
export const getWeiAmountForDecimals = (amount: string | number, decimals: number) => new Dec(amount).mul(10 ** decimals).floor().toString();
|
|
24
|
+
|
|
25
|
+
export const getEthAmountForDecimals = (amount: string | number, decimals: string | number) => new Dec(amount).div(10 ** +decimals).toString();
|
|
26
|
+
|
|
27
|
+
export const handleWbtcLegacy = (asset: string) => (asset === 'WBTC Legacy' ? 'WBTC' : asset);
|
|
28
|
+
|
|
29
|
+
export const bytesToString = (hex: string) => Buffer.from(hex.replace(/^0x/, ''), 'hex')
|
|
30
|
+
.toString()
|
|
31
|
+
// eslint-disable-next-line no-control-regex
|
|
32
|
+
.replace(/\x00/g, '');
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Map an input value from one range (minInput, maxInput) to a value in another range (minOutput, maxOutput)
|
|
36
|
+
*/
|
|
37
|
+
export const mapRange = (input: number | string, minInput: number | string, maxInput: number | string, minOutput:number | string, maxOutput: number | string) => {
|
|
38
|
+
// slope = 1.0 * (output_end - output_start) / (input_end - input_start)
|
|
39
|
+
const inputDiff = new Dec(maxInput).minus(minInput);
|
|
40
|
+
const outputDiff = new Dec(maxOutput).minus(minOutput);
|
|
41
|
+
const slope = new Dec(outputDiff).div(inputDiff);
|
|
42
|
+
|
|
43
|
+
// output = output_start + slope * (input - input_start)
|
|
44
|
+
return new Dec(minOutput).plus(new Dec(slope).mul(new Dec(input).minus(minInput))).toDP(2).toNumber();
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
// eslint-disable-next-line no-bitwise
|
|
48
|
+
export const isEnabledOnBitmap = (bitmap: number, assetId: number) => (BigInt(bitmap) >> BigInt(assetId)) & BigInt(1);
|
|
49
|
+
|
|
50
|
+
export const MAXUINT:string = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
|
|
51
|
+
|
|
52
|
+
export const isMaxuint = (amount: string) => compareAddresses(MAXUINT, amount);
|
|
53
|
+
|
|
54
|
+
export const isMainnetNetwork = (network: NetworkNumber) => network === NetworkNumber.Eth;
|
|
55
|
+
|
|
56
|
+
export const DEFAULT_TIMEOUT = 2000; // 2 seconds
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Converts web3 hybrid response (that can be used as objects and arrays, so has duplicated values) to objects.
|
|
60
|
+
* @param value
|
|
61
|
+
*/
|
|
62
|
+
export const convertHybridArraysToObjects = (value: any): any => {
|
|
63
|
+
if (Array.isArray(value)) {
|
|
64
|
+
const keys = Object.keys(value);
|
|
65
|
+
const hasNamedKeys = keys.some((key) => Number.isNaN(Number(key)));
|
|
66
|
+
|
|
67
|
+
// If array has named keys, treat it as an object and keep only those
|
|
68
|
+
if (hasNamedKeys) {
|
|
69
|
+
const result: Record<string, any> = {};
|
|
70
|
+
for (const [key, val] of Object.entries(value)) {
|
|
71
|
+
if (Number.isNaN(Number(key))) {
|
|
72
|
+
result[key] = convertHybridArraysToObjects(val);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return result;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// Else, treat as a regular array
|
|
79
|
+
return value.map(convertHybridArraysToObjects);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// If it's an object (but not an array), recurse into its values
|
|
83
|
+
if (value && typeof value === 'object') {
|
|
84
|
+
const result: Record<string, any> = {};
|
|
85
|
+
for (const [key, val] of Object.entries(value)) {
|
|
86
|
+
result[key] = convertHybridArraysToObjects(val);
|
|
87
|
+
}
|
|
88
|
+
return result;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return value;
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
export const ethToWeth = (maybeEth: string) => maybeEth?.replace(/^ETH$/, 'WETH');
|
|
95
|
+
|
|
96
|
+
export const wethToEth = (maybeWeth: string) => maybeWeth?.replace(/^WETH$/, 'ETH');
|
|
97
|
+
|
|
98
|
+
export const wethToEthByAddress = (maybeWethAddr: string, chainId = NetworkNumber.Eth) => getAssetInfo(wethToEth(getAssetInfoByAddress(maybeWethAddr, chainId).symbol), chainId).address;
|
|
99
|
+
|
|
100
|
+
export const ethToWethByAddress = (maybeEthAddr: string, chainId = NetworkNumber.Eth) => getAssetInfo(ethToWeth(getAssetInfoByAddress(maybeEthAddr, chainId).symbol), chainId).address;
|
|
101
|
+
|
|
102
|
+
export const xplToWxpl = (maybeXpl: string) => maybeXpl?.replace(/^XPL$/, 'WXPL');
|
|
103
|
+
|
|
104
|
+
export const wxplToXpl = (maybeWxpl: string) => maybeWxpl?.replace(/^WXPL$/, 'XPL');
|
|
105
|
+
|
|
106
|
+
export const getWrappedNativeAssetFromUnwrapped = (symbol: string) => {
|
|
107
|
+
if (symbol === 'ETH') return 'WETH';
|
|
108
|
+
if (symbol === 'XPL') return 'WXPL';
|
|
109
|
+
return symbol;
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
export const getNativeAssetFromWrapped = (symbol: string) => {
|
|
113
|
+
if (symbol === 'WETH') return 'ETH';
|
|
114
|
+
if (symbol === 'WXPL') return 'XPL';
|
|
115
|
+
return symbol;
|
|
116
116
|
};
|
package/src/services/viem.ts
CHANGED
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
import { createPublicClient, custom } from 'viem';
|
|
2
|
-
import {
|
|
3
|
-
arbitrum, base, mainnet, optimism, linea, plasma,
|
|
4
|
-
} from 'viem/chains';
|
|
5
|
-
import { Blockish, EthereumProvider, NetworkNumber } from '../types/common';
|
|
6
|
-
|
|
7
|
-
export const getViemChain = (network: NetworkNumber) => {
|
|
8
|
-
switch (network) {
|
|
9
|
-
case NetworkNumber.Eth:
|
|
10
|
-
return mainnet;
|
|
11
|
-
case NetworkNumber.Opt:
|
|
12
|
-
return optimism;
|
|
13
|
-
case NetworkNumber.Arb:
|
|
14
|
-
return arbitrum;
|
|
15
|
-
case NetworkNumber.Base:
|
|
16
|
-
return base;
|
|
17
|
-
case NetworkNumber.Linea:
|
|
18
|
-
return linea;
|
|
19
|
-
case NetworkNumber.Plasma:
|
|
20
|
-
return plasma;
|
|
21
|
-
default:
|
|
22
|
-
throw new Error(`Unsupported network: ${network}`);
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
export const getViemProvider = (provider: EthereumProvider, network: NetworkNumber, options?: any) => createPublicClient({
|
|
27
|
-
transport: custom(provider),
|
|
28
|
-
chain: getViemChain(network),
|
|
29
|
-
...options,
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
export const setViemBlockNumber = (block: Blockish) => {
|
|
33
|
-
if (block === 'latest') return {};
|
|
34
|
-
return { blockNumber: BigInt(block) };
|
|
1
|
+
import { createPublicClient, custom } from 'viem';
|
|
2
|
+
import {
|
|
3
|
+
arbitrum, base, mainnet, optimism, linea, plasma,
|
|
4
|
+
} from 'viem/chains';
|
|
5
|
+
import { Blockish, EthereumProvider, NetworkNumber } from '../types/common';
|
|
6
|
+
|
|
7
|
+
export const getViemChain = (network: NetworkNumber) => {
|
|
8
|
+
switch (network) {
|
|
9
|
+
case NetworkNumber.Eth:
|
|
10
|
+
return mainnet;
|
|
11
|
+
case NetworkNumber.Opt:
|
|
12
|
+
return optimism;
|
|
13
|
+
case NetworkNumber.Arb:
|
|
14
|
+
return arbitrum;
|
|
15
|
+
case NetworkNumber.Base:
|
|
16
|
+
return base;
|
|
17
|
+
case NetworkNumber.Linea:
|
|
18
|
+
return linea;
|
|
19
|
+
case NetworkNumber.Plasma:
|
|
20
|
+
return plasma;
|
|
21
|
+
default:
|
|
22
|
+
throw new Error(`Unsupported network: ${network}`);
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export const getViemProvider = (provider: EthereumProvider, network: NetworkNumber, options?: any) => createPublicClient({
|
|
27
|
+
transport: custom(provider),
|
|
28
|
+
chain: getViemChain(network),
|
|
29
|
+
...options,
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
export const setViemBlockNumber = (block: Blockish) => {
|
|
33
|
+
if (block === 'latest') return {};
|
|
34
|
+
return { blockNumber: BigInt(block) };
|
|
35
35
|
};
|
package/src/setup.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import Decimal from 'decimal.js';
|
|
2
|
-
|
|
3
|
-
Decimal.set({
|
|
4
|
-
rounding: Decimal.ROUND_DOWN,
|
|
5
|
-
toExpPos: 9e15,
|
|
6
|
-
toExpNeg: -9e15,
|
|
7
|
-
precision: 50,
|
|
8
|
-
});
|
|
1
|
+
import Decimal from 'decimal.js';
|
|
2
|
+
|
|
3
|
+
Decimal.set({
|
|
4
|
+
rounding: Decimal.ROUND_DOWN,
|
|
5
|
+
toExpPos: 9e15,
|
|
6
|
+
toExpNeg: -9e15,
|
|
7
|
+
precision: 50,
|
|
8
|
+
});
|