@clober/v2-sdk 1.0.0 → 1.0.1
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/dist/cjs/calls/approval/token.js +1 -1
- package/dist/cjs/calls/approval/token.js.map +1 -1
- package/dist/cjs/calls/market/cancel.js +1 -1
- package/dist/cjs/calls/market/cancel.js.map +1 -1
- package/dist/cjs/calls/market/claim.js +1 -1
- package/dist/cjs/calls/market/claim.js.map +1 -1
- package/dist/cjs/calls/market/limit.js +1 -1
- package/dist/cjs/calls/market/limit.js.map +1 -1
- package/dist/cjs/calls/market/make.js +1 -1
- package/dist/cjs/calls/market/make.js.map +1 -1
- package/dist/cjs/calls/market/market.js +1 -1
- package/dist/cjs/calls/market/market.js.map +1 -1
- package/dist/cjs/calls/market/open.js +1 -1
- package/dist/cjs/calls/market/open.js.map +1 -1
- package/dist/cjs/calls/pool/burn.js +1 -1
- package/dist/cjs/calls/pool/burn.js.map +1 -1
- package/dist/cjs/calls/pool/market-making/adjust.js +1 -1
- package/dist/cjs/calls/pool/market-making/adjust.js.map +1 -1
- package/dist/cjs/calls/pool/market-making/pause.js +1 -1
- package/dist/cjs/calls/pool/market-making/pause.js.map +1 -1
- package/dist/cjs/calls/pool/market-making/refill.js +1 -1
- package/dist/cjs/calls/pool/market-making/refill.js.map +1 -1
- package/dist/cjs/calls/pool/market-making/resume.js +1 -1
- package/dist/cjs/calls/pool/market-making/resume.js.map +1 -1
- package/dist/cjs/calls/pool/mint.js +1 -1
- package/dist/cjs/calls/pool/mint.js.map +1 -1
- package/dist/cjs/calls/pool/open.js +1 -1
- package/dist/cjs/calls/pool/open.js.map +1 -1
- package/dist/cjs/calls/pool/wrap.js +2 -2
- package/dist/cjs/calls/pool/wrap.js.map +1 -1
- package/dist/cjs/constants/abis/core/book-manager-abi.js +31 -0
- package/dist/cjs/constants/abis/core/book-manager-abi.js.map +1 -1
- package/dist/cjs/constants/abis/rebalancer/rebalancer-abi.js +42 -0
- package/dist/cjs/constants/abis/rebalancer/rebalancer-abi.js.map +1 -1
- package/dist/cjs/constants/chain-configs/addresses.js +10 -0
- package/dist/cjs/constants/chain-configs/addresses.js.map +1 -1
- package/dist/cjs/constants/chain-configs/chain.js +2 -0
- package/dist/cjs/constants/chain-configs/chain.js.map +1 -1
- package/dist/cjs/constants/chain-configs/currency.js +46 -0
- package/dist/cjs/constants/chain-configs/currency.js.map +1 -1
- package/dist/cjs/constants/chain-configs/fee.js +2 -0
- package/dist/cjs/constants/chain-configs/fee.js.map +1 -1
- package/dist/cjs/constants/chain-configs/subgraph.js +51 -15
- package/dist/cjs/constants/chain-configs/subgraph.js.map +1 -1
- package/dist/cjs/entities/analytics/apis/index.js +26 -7
- package/dist/cjs/entities/analytics/apis/index.js.map +1 -1
- package/dist/cjs/entities/book/apis/index.js +2 -1
- package/dist/cjs/entities/book/apis/index.js.map +1 -1
- package/dist/cjs/entities/currency/apis/index.js +8 -6
- package/dist/cjs/entities/currency/apis/index.js.map +1 -1
- package/dist/cjs/entities/currency/apis/total-supply.js +4 -2
- package/dist/cjs/entities/currency/apis/total-supply.js.map +1 -1
- package/dist/cjs/entities/market/apis/index.js +4 -4
- package/dist/cjs/entities/market/apis/index.js.map +1 -1
- package/dist/cjs/entities/market/apis/snapshot.js +4 -4
- package/dist/cjs/entities/market/apis/snapshot.js.map +1 -1
- package/dist/cjs/entities/open-order/apis/index.js +12 -4
- package/dist/cjs/entities/open-order/apis/index.js.map +1 -1
- package/dist/cjs/entities/pool/apis/index.js +3 -2
- package/dist/cjs/entities/pool/apis/index.js.map +1 -1
- package/dist/cjs/entities/pool/apis/snapshot.js +114 -31
- package/dist/cjs/entities/pool/apis/snapshot.js.map +1 -1
- package/dist/cjs/entities/pool/apis/strategy.js +4 -2
- package/dist/cjs/entities/pool/apis/strategy.js.map +1 -1
- package/dist/cjs/entities/swap/apis/index.js +5 -5
- package/dist/cjs/entities/swap/apis/index.js.map +1 -1
- package/dist/cjs/entities/take/apis/index.js +35 -0
- package/dist/cjs/entities/take/apis/index.js.map +1 -0
- package/dist/cjs/types/events.js +3 -0
- package/dist/cjs/types/events.js.map +1 -0
- package/dist/cjs/types/index.js.map +1 -1
- package/dist/cjs/views/index.js +7 -3
- package/dist/cjs/views/index.js.map +1 -1
- package/dist/cjs/views/market/index.js +4 -2
- package/dist/cjs/views/market/index.js.map +1 -1
- package/dist/cjs/views/market/parse.js +1 -0
- package/dist/cjs/views/market/parse.js.map +1 -1
- package/dist/cjs/views/market/quote.js +2 -2
- package/dist/cjs/views/market/quote.js.map +1 -1
- package/dist/cjs/views/market/snapshot.js +2 -2
- package/dist/cjs/views/market/snapshot.js.map +1 -1
- package/dist/cjs/views/market/take.js +82 -0
- package/dist/cjs/views/market/take.js.map +1 -0
- package/dist/cjs/views/pool/index.js +5 -2
- package/dist/cjs/views/pool/index.js.map +1 -1
- package/dist/cjs/views/pool/market-making.js +89 -3
- package/dist/cjs/views/pool/market-making.js.map +1 -1
- package/dist/cjs/views/pool/position.js +12 -0
- package/dist/cjs/views/pool/position.js.map +1 -0
- package/dist/cjs/views/pool/snapshot.js +4 -4
- package/dist/cjs/views/pool/snapshot.js.map +1 -1
- package/dist/cjs/views/subgraph.js +5 -1
- package/dist/cjs/views/subgraph.js.map +1 -1
- package/dist/cjs/views/{trade.js → swap.js} +5 -5
- package/dist/cjs/views/swap.js.map +1 -0
- package/dist/esm/calls/approval/token.js +1 -1
- package/dist/esm/calls/approval/token.js.map +1 -1
- package/dist/esm/calls/market/cancel.js +1 -1
- package/dist/esm/calls/market/cancel.js.map +1 -1
- package/dist/esm/calls/market/claim.js +1 -1
- package/dist/esm/calls/market/claim.js.map +1 -1
- package/dist/esm/calls/market/limit.js +1 -1
- package/dist/esm/calls/market/limit.js.map +1 -1
- package/dist/esm/calls/market/make.js +1 -1
- package/dist/esm/calls/market/make.js.map +1 -1
- package/dist/esm/calls/market/market.js +1 -1
- package/dist/esm/calls/market/market.js.map +1 -1
- package/dist/esm/calls/market/open.js +1 -1
- package/dist/esm/calls/market/open.js.map +1 -1
- package/dist/esm/calls/pool/burn.js +1 -1
- package/dist/esm/calls/pool/burn.js.map +1 -1
- package/dist/esm/calls/pool/market-making/adjust.js +1 -1
- package/dist/esm/calls/pool/market-making/adjust.js.map +1 -1
- package/dist/esm/calls/pool/market-making/pause.js +1 -1
- package/dist/esm/calls/pool/market-making/pause.js.map +1 -1
- package/dist/esm/calls/pool/market-making/refill.js +1 -1
- package/dist/esm/calls/pool/market-making/refill.js.map +1 -1
- package/dist/esm/calls/pool/market-making/resume.js +1 -1
- package/dist/esm/calls/pool/market-making/resume.js.map +1 -1
- package/dist/esm/calls/pool/mint.js +1 -1
- package/dist/esm/calls/pool/mint.js.map +1 -1
- package/dist/esm/calls/pool/open.js +1 -1
- package/dist/esm/calls/pool/open.js.map +1 -1
- package/dist/esm/calls/pool/wrap.js +2 -2
- package/dist/esm/calls/pool/wrap.js.map +1 -1
- package/dist/esm/constants/abis/core/book-manager-abi.js +31 -0
- package/dist/esm/constants/abis/core/book-manager-abi.js.map +1 -1
- package/dist/esm/constants/abis/rebalancer/rebalancer-abi.js +42 -0
- package/dist/esm/constants/abis/rebalancer/rebalancer-abi.js.map +1 -1
- package/dist/esm/constants/chain-configs/addresses.js +10 -9
- package/dist/esm/constants/chain-configs/addresses.js.map +1 -1
- package/dist/esm/constants/chain-configs/chain.js +3 -3
- package/dist/esm/constants/chain-configs/chain.js.map +1 -1
- package/dist/esm/constants/chain-configs/currency.js +46 -10
- package/dist/esm/constants/chain-configs/currency.js.map +1 -1
- package/dist/esm/constants/chain-configs/fee.js +2 -2
- package/dist/esm/constants/chain-configs/fee.js.map +1 -1
- package/dist/esm/constants/chain-configs/subgraph.js +50 -18
- package/dist/esm/constants/chain-configs/subgraph.js.map +1 -1
- package/dist/esm/entities/analytics/apis/index.js +28 -7
- package/dist/esm/entities/analytics/apis/index.js.map +1 -1
- package/dist/esm/entities/book/apis/index.js +2 -1
- package/dist/esm/entities/book/apis/index.js.map +1 -1
- package/dist/esm/entities/currency/apis/index.js +9 -7
- package/dist/esm/entities/currency/apis/index.js.map +1 -1
- package/dist/esm/entities/currency/apis/total-supply.js +4 -2
- package/dist/esm/entities/currency/apis/total-supply.js.map +1 -1
- package/dist/esm/entities/market/apis/index.js +4 -4
- package/dist/esm/entities/market/apis/index.js.map +1 -1
- package/dist/esm/entities/market/apis/snapshot.js +4 -4
- package/dist/esm/entities/market/apis/snapshot.js.map +1 -1
- package/dist/esm/entities/open-order/apis/index.js +12 -4
- package/dist/esm/entities/open-order/apis/index.js.map +1 -1
- package/dist/esm/entities/pool/apis/index.js +3 -2
- package/dist/esm/entities/pool/apis/index.js.map +1 -1
- package/dist/esm/entities/pool/apis/snapshot.js +113 -31
- package/dist/esm/entities/pool/apis/snapshot.js.map +1 -1
- package/dist/esm/entities/pool/apis/strategy.js +4 -2
- package/dist/esm/entities/pool/apis/strategy.js.map +1 -1
- package/dist/esm/entities/swap/apis/index.js +3 -3
- package/dist/esm/entities/swap/apis/index.js.map +1 -1
- package/dist/esm/entities/take/apis/index.js +31 -0
- package/dist/esm/entities/take/apis/index.js.map +1 -0
- package/dist/esm/types/events.js +2 -0
- package/dist/esm/types/events.js.map +1 -0
- package/dist/esm/types/index.js.map +1 -1
- package/dist/esm/views/index.js +4 -4
- package/dist/esm/views/index.js.map +1 -1
- package/dist/esm/views/market/index.js +2 -1
- package/dist/esm/views/market/index.js.map +1 -1
- package/dist/esm/views/market/parse.js +1 -0
- package/dist/esm/views/market/parse.js.map +1 -1
- package/dist/esm/views/market/quote.js +2 -2
- package/dist/esm/views/market/quote.js.map +1 -1
- package/dist/esm/views/market/snapshot.js +2 -2
- package/dist/esm/views/market/snapshot.js.map +1 -1
- package/dist/esm/views/market/take.js +78 -0
- package/dist/esm/views/market/take.js.map +1 -0
- package/dist/esm/views/pool/index.js +3 -2
- package/dist/esm/views/pool/index.js.map +1 -1
- package/dist/esm/views/pool/market-making.js +88 -3
- package/dist/esm/views/pool/market-making.js.map +1 -1
- package/dist/esm/views/pool/position.js +8 -0
- package/dist/esm/views/pool/position.js.map +1 -0
- package/dist/esm/views/pool/snapshot.js +4 -4
- package/dist/esm/views/pool/snapshot.js.map +1 -1
- package/dist/esm/views/subgraph.js +16 -1
- package/dist/esm/views/subgraph.js.map +1 -1
- package/dist/esm/views/swap.js +11 -0
- package/dist/esm/views/swap.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/calls/market/cancel.d.ts.map +1 -1
- package/dist/types/calls/market/claim.d.ts.map +1 -1
- package/dist/types/calls/market/limit.d.ts.map +1 -1
- package/dist/types/calls/market/make.d.ts.map +1 -1
- package/dist/types/calls/market/market.d.ts.map +1 -1
- package/dist/types/calls/market/open.d.ts.map +1 -1
- package/dist/types/calls/pool/burn.d.ts.map +1 -1
- package/dist/types/calls/pool/market-making/adjust.d.ts.map +1 -1
- package/dist/types/calls/pool/market-making/pause.d.ts.map +1 -1
- package/dist/types/calls/pool/market-making/refill.d.ts.map +1 -1
- package/dist/types/calls/pool/market-making/resume.d.ts.map +1 -1
- package/dist/types/calls/pool/mint.d.ts.map +1 -1
- package/dist/types/calls/pool/open.d.ts.map +1 -1
- package/dist/types/calls/pool/wrap.d.ts.map +1 -1
- package/dist/types/constants/abis/core/book-manager-abi.d.ts +25 -0
- package/dist/types/constants/abis/core/book-manager-abi.d.ts.map +1 -1
- package/dist/types/constants/abis/rebalancer/rebalancer-abi.d.ts +35 -0
- package/dist/types/constants/abis/rebalancer/rebalancer-abi.d.ts.map +1 -1
- package/dist/types/constants/chain-configs/addresses.d.ts.map +1 -1
- package/dist/types/constants/chain-configs/chain.d.ts +1 -0
- package/dist/types/constants/chain-configs/chain.d.ts.map +1 -1
- package/dist/types/constants/chain-configs/currency.d.ts.map +1 -1
- package/dist/types/constants/chain-configs/subgraph.d.ts +3 -0
- package/dist/types/constants/chain-configs/subgraph.d.ts.map +1 -1
- package/dist/types/entities/analytics/apis/index.d.ts.map +1 -1
- package/dist/types/entities/analytics/types.d.ts +7 -2
- package/dist/types/entities/analytics/types.d.ts.map +1 -1
- package/dist/types/entities/book/apis/index.d.ts +2 -2
- package/dist/types/entities/book/apis/index.d.ts.map +1 -1
- package/dist/types/entities/currency/apis/index.d.ts +3 -3
- package/dist/types/entities/currency/apis/index.d.ts.map +1 -1
- package/dist/types/entities/currency/apis/total-supply.d.ts +3 -3
- package/dist/types/entities/currency/apis/total-supply.d.ts.map +1 -1
- package/dist/types/entities/market/apis/index.d.ts +2 -2
- package/dist/types/entities/market/apis/index.d.ts.map +1 -1
- package/dist/types/entities/market/apis/snapshot.d.ts +3 -3
- package/dist/types/entities/market/apis/snapshot.d.ts.map +1 -1
- package/dist/types/entities/open-order/apis/index.d.ts +2 -2
- package/dist/types/entities/open-order/apis/index.d.ts.map +1 -1
- package/dist/types/entities/pool/apis/index.d.ts +2 -2
- package/dist/types/entities/pool/apis/index.d.ts.map +1 -1
- package/dist/types/entities/pool/apis/snapshot.d.ts +4 -2
- package/dist/types/entities/pool/apis/snapshot.d.ts.map +1 -1
- package/dist/types/entities/pool/apis/strategy.d.ts +3 -3
- package/dist/types/entities/pool/apis/strategy.d.ts.map +1 -1
- package/dist/types/entities/pool/types.d.ts +19 -2
- package/dist/types/entities/pool/types.d.ts.map +1 -1
- package/dist/types/entities/swap/apis/index.d.ts +2 -2
- package/dist/types/entities/swap/apis/index.d.ts.map +1 -1
- package/dist/types/entities/take/apis/index.d.ts +11 -0
- package/dist/types/entities/take/apis/index.d.ts.map +1 -0
- package/dist/types/types/default-options.d.ts +2 -0
- package/dist/types/types/default-options.d.ts.map +1 -1
- package/dist/types/types/events.d.ts +27 -0
- package/dist/types/types/events.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +3 -2
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/types/views/index.d.ts +4 -4
- package/dist/types/views/index.d.ts.map +1 -1
- package/dist/types/views/market/index.d.ts +1 -0
- package/dist/types/views/market/index.d.ts.map +1 -1
- package/dist/types/views/market/parse.d.ts.map +1 -1
- package/dist/types/views/market/quote.d.ts.map +1 -1
- package/dist/types/views/market/snapshot.d.ts.map +1 -1
- package/dist/types/views/market/take.d.ts +12 -0
- package/dist/types/views/market/take.d.ts.map +1 -0
- package/dist/types/views/pool/index.d.ts +2 -1
- package/dist/types/views/pool/index.d.ts.map +1 -1
- package/dist/types/views/pool/market-making.d.ts +13 -1
- package/dist/types/views/pool/market-making.d.ts.map +1 -1
- package/dist/types/views/pool/position.d.ts +8 -0
- package/dist/types/views/pool/position.d.ts.map +1 -0
- package/dist/types/views/pool/snapshot.d.ts +4 -2
- package/dist/types/views/pool/snapshot.d.ts.map +1 -1
- package/dist/types/views/subgraph.d.ts +15 -0
- package/dist/types/views/subgraph.d.ts.map +1 -1
- package/dist/types/views/{trade.d.ts → swap.d.ts} +2 -2
- package/dist/types/views/swap.d.ts.map +1 -0
- package/package.json +2 -1
- package/dist/cjs/views/trade.js.map +0 -1
- package/dist/esm/views/trade.js +0 -11
- package/dist/esm/views/trade.js.map +0 -1
- package/dist/types/views/trade.d.ts.map +0 -1
|
@@ -1,18 +1,103 @@
|
|
|
1
|
-
import { createPublicClient, http } from 'viem';
|
|
1
|
+
import { createPublicClient, formatUnits, http, parseAbiItem } from 'viem';
|
|
2
|
+
import BigNumber from 'bignumber.js';
|
|
2
3
|
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
4
|
import { fetchLastAmounts, fetchStrategyPosition, } from '../../entities/pool/apis/strategy';
|
|
5
|
+
import { REBALANCER_ABI } from '../../constants/abis/rebalancer/rebalancer-abi';
|
|
6
|
+
import { getContractAddresses } from '../address';
|
|
7
|
+
import { fromOrderId } from '../../entities/open-order/utils/order-id';
|
|
8
|
+
import { formatPrice, invertTick, toPrice } from '../../utils';
|
|
4
9
|
export const getStrategyPrice = async ({ chainId, poolKey, options, }) => {
|
|
5
10
|
const publicClient = createPublicClient({
|
|
6
11
|
chain: CHAIN_MAP[chainId],
|
|
7
12
|
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
8
13
|
});
|
|
9
|
-
return fetchStrategyPosition(publicClient, chainId, poolKey);
|
|
14
|
+
return fetchStrategyPosition(publicClient, chainId, poolKey, options?.blockTag ?? 'latest');
|
|
10
15
|
};
|
|
11
16
|
export const getLastAmounts = async ({ chainId, poolKey, options, }) => {
|
|
12
17
|
const publicClient = createPublicClient({
|
|
13
18
|
chain: CHAIN_MAP[chainId],
|
|
14
19
|
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
15
20
|
});
|
|
16
|
-
return fetchLastAmounts(publicClient, chainId, poolKey);
|
|
21
|
+
return fetchLastAmounts(publicClient, chainId, poolKey, options?.blockTag ?? 'latest');
|
|
22
|
+
};
|
|
23
|
+
const handleRebalanceLog = (log, poolSnapshot, onEvent) => {
|
|
24
|
+
const { args } = log;
|
|
25
|
+
onEvent({
|
|
26
|
+
transactionHash: log.transactionHash,
|
|
27
|
+
logIndex: Number(log.logIndex),
|
|
28
|
+
timestamp: Number(log.blockTimestamp),
|
|
29
|
+
blockNumber: Number(log.blockNumber),
|
|
30
|
+
bidOrderList: args.orderListA.map((orderId) => {
|
|
31
|
+
const tick = fromOrderId(orderId).tick;
|
|
32
|
+
const price = formatPrice(toPrice(tick), poolSnapshot.currencyA.decimals, poolSnapshot.currencyB.decimals);
|
|
33
|
+
const amount = formatUnits(args.amountA, poolSnapshot.currencyA.decimals);
|
|
34
|
+
return {
|
|
35
|
+
price,
|
|
36
|
+
size: new BigNumber(amount)
|
|
37
|
+
.dividedBy(new BigNumber(price))
|
|
38
|
+
.toFixed(poolSnapshot.currencyB.decimals),
|
|
39
|
+
};
|
|
40
|
+
}),
|
|
41
|
+
askOrderList: args.orderListB.map((orderId) => {
|
|
42
|
+
const tick = fromOrderId(orderId).tick;
|
|
43
|
+
return {
|
|
44
|
+
price: formatPrice(toPrice(invertTick(tick)), poolSnapshot.currencyA.decimals, poolSnapshot.currencyB.decimals),
|
|
45
|
+
size: formatUnits(args.amountB, poolSnapshot.currencyB.decimals),
|
|
46
|
+
};
|
|
47
|
+
}),
|
|
48
|
+
quoteReserve: formatUnits(args.reserveA, poolSnapshot.currencyA.decimals),
|
|
49
|
+
baseReserve: formatUnits(args.reserveB, poolSnapshot.currencyB.decimals),
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
const backfillRebalanceEvents = async ({ publicClient, chainId, poolSnapshot, backfillBlocks, onEvent, }) => {
|
|
53
|
+
const currentBlock = await publicClient.getBlockNumber();
|
|
54
|
+
const fromBlock = currentBlock > backfillBlocks ? currentBlock - backfillBlocks : 0n;
|
|
55
|
+
const logs = await publicClient.getLogs({
|
|
56
|
+
address: getContractAddresses({ chainId }).Rebalancer,
|
|
57
|
+
event: parseAbiItem('event Rebalance(bytes32 indexed key,address indexed caller,uint256[] orderListA,uint256[] orderListB,uint256 amountA,uint256 amountB,uint256 reserveA,uint256 reserveB)'),
|
|
58
|
+
args: {
|
|
59
|
+
key: poolSnapshot.key,
|
|
60
|
+
},
|
|
61
|
+
fromBlock,
|
|
62
|
+
toBlock: currentBlock,
|
|
63
|
+
});
|
|
64
|
+
for (const log of logs) {
|
|
65
|
+
handleRebalanceLog(log, poolSnapshot, onEvent);
|
|
66
|
+
}
|
|
67
|
+
return currentBlock;
|
|
68
|
+
};
|
|
69
|
+
export const watchMarketMakingEvents = async ({ chainId, poolSnapshot, options, onEvent, onError, }) => {
|
|
70
|
+
const publicClient = createPublicClient({
|
|
71
|
+
chain: CHAIN_MAP[chainId],
|
|
72
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
73
|
+
});
|
|
74
|
+
const seen = new Set();
|
|
75
|
+
const lastBackfilledBlock = await backfillRebalanceEvents({
|
|
76
|
+
publicClient,
|
|
77
|
+
chainId,
|
|
78
|
+
poolSnapshot,
|
|
79
|
+
backfillBlocks: options?.backfillBlocks ?? 100n,
|
|
80
|
+
onEvent,
|
|
81
|
+
});
|
|
82
|
+
return publicClient.watchContractEvent({
|
|
83
|
+
address: getContractAddresses({ chainId }).Rebalancer,
|
|
84
|
+
abi: REBALANCER_ABI,
|
|
85
|
+
eventName: 'Rebalance',
|
|
86
|
+
args: {
|
|
87
|
+
key: poolSnapshot.key,
|
|
88
|
+
},
|
|
89
|
+
fromBlock: lastBackfilledBlock + 1n,
|
|
90
|
+
onLogs: (logs) => {
|
|
91
|
+
for (const log of logs) {
|
|
92
|
+
const key = `${log.blockNumber}-${log.logIndex}`;
|
|
93
|
+
if (seen.has(key)) {
|
|
94
|
+
continue;
|
|
95
|
+
}
|
|
96
|
+
seen.add(key);
|
|
97
|
+
handleRebalanceLog(log, poolSnapshot, onEvent);
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
onError,
|
|
101
|
+
});
|
|
17
102
|
};
|
|
18
103
|
//# sourceMappingURL=market-making.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"market-making.js","sourceRoot":"","sources":["../../../../src/views/pool/market-making.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"market-making.js","sourceRoot":"","sources":["../../../../src/views/pool/market-making.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { fetchUserPoolPositionsFromSubgraph } from '../../entities/pool/apis/snapshot';
|
|
2
|
+
export const getUserPoolPositions = async ({ chainId, userAddress, prices, }) => {
|
|
3
|
+
return fetchUserPoolPositionsFromSubgraph(chainId, userAddress, Object.entries(prices).reduce((acc, [key, value]) => {
|
|
4
|
+
acc[key.toLowerCase()] = value;
|
|
5
|
+
return acc;
|
|
6
|
+
}, {}));
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=position.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"position.js","sourceRoot":"","sources":["../../../../src/views/pool/position.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kCAAkC,EAAE,MAAM,mCAAmC,CAAA;AAGtF,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,EAAE,EACzC,OAAO,EACP,WAAW,EACX,MAAM,GAKP,EAA+B,EAAE;IAChC,OAAO,kCAAkC,CACvC,OAAO,EACP,WAAW,EACX,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAC3B,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QACpB,GAAG,CAAC,GAAG,CAAC,WAAW,EAAmB,CAAC,GAAG,KAAK,CAAA;QAC/C,OAAO,GAAG,CAAA;IACZ,CAAC,EACD,EAAmC,CACpC,CACF,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { fetchPoolSnapshotFromSubgraph, fetchPoolSnapshotsFromSubgraph, } from '../../entities/pool/apis/snapshot';
|
|
2
|
-
export const getPoolSnapshot = async ({ chainId, poolKey, }) => {
|
|
3
|
-
const poolSnapshot = await fetchPoolSnapshotFromSubgraph(chainId, poolKey);
|
|
2
|
+
export const getPoolSnapshot = async ({ chainId, poolKey, prices, }) => {
|
|
3
|
+
const poolSnapshot = await fetchPoolSnapshotFromSubgraph(chainId, poolKey, prices ?? {});
|
|
4
4
|
if (!poolSnapshot) {
|
|
5
5
|
throw new Error('Pool is not existed');
|
|
6
6
|
}
|
|
7
7
|
return poolSnapshot;
|
|
8
8
|
};
|
|
9
|
-
export const getPoolSnapshots = async ({ chainId, }) => {
|
|
10
|
-
return fetchPoolSnapshotsFromSubgraph(chainId);
|
|
9
|
+
export const getPoolSnapshots = async ({ chainId, prices, }) => {
|
|
10
|
+
return fetchPoolSnapshotsFromSubgraph(chainId, prices ?? {});
|
|
11
11
|
};
|
|
12
12
|
//# sourceMappingURL=snapshot.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../../../../src/views/pool/snapshot.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,6BAA6B,EAC7B,8BAA8B,GAC/B,MAAM,mCAAmC,CAAA;AAE1C,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAAE,EACpC,OAAO,EACP,OAAO,
|
|
1
|
+
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../../../../src/views/pool/snapshot.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,6BAA6B,EAC7B,8BAA8B,GAC/B,MAAM,mCAAmC,CAAA;AAE1C,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAAE,EACpC,OAAO,EACP,OAAO,EACP,MAAM,GAKP,EAAyB,EAAE;IAC1B,MAAM,YAAY,GAAG,MAAM,6BAA6B,CACtD,OAAO,EACP,OAAO,EACP,MAAM,IAAI,EAAE,CACb,CAAA;IACD,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAA;IACxC,CAAC;IACD,OAAO,YAAY,CAAA;AACrB,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EAAE,EACrC,OAAO,EACP,MAAM,GAIP,EAA2B,EAAE;IAC5B,OAAO,8BAA8B,CAAC,OAAO,EAAE,MAAM,IAAI,EAAE,CAAC,CAAA;AAC9D,CAAC,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Subgraph, SUBGRAPH_URL } from '../constants/chain-configs/subgraph';
|
|
1
|
+
import { FALLBACK_SUBGRAPH_URL, Subgraph, SUBGRAPH_URL, } from '../constants/chain-configs/subgraph';
|
|
2
2
|
/**
|
|
3
3
|
* Get subgraph endpoint by chain id
|
|
4
4
|
* @param chainId - chain id from {@link CHAIN_IDS}
|
|
@@ -14,6 +14,21 @@ import { Subgraph, SUBGRAPH_URL } from '../constants/chain-configs/subgraph';
|
|
|
14
14
|
export const getSubgraphEndpoint = ({ chainId }) => {
|
|
15
15
|
return SUBGRAPH_URL[chainId];
|
|
16
16
|
};
|
|
17
|
+
/**
|
|
18
|
+
* Get fallback subgraph endpoint by chain id
|
|
19
|
+
* @param chainId - chain id from {@link CHAIN_IDS}
|
|
20
|
+
* @returns Subgraph endpoint
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* import { getFallbackSubgraphEndpoint } from '@clober/v2-sdk'
|
|
24
|
+
*
|
|
25
|
+
* const endpoint = await getFallbackSubgraphEndpoint({
|
|
26
|
+
* chainId: 421614,
|
|
27
|
+
* })
|
|
28
|
+
*/
|
|
29
|
+
export const getFallbackSubgraphEndpoint = ({ chainId, }) => {
|
|
30
|
+
return FALLBACK_SUBGRAPH_URL[chainId];
|
|
31
|
+
};
|
|
17
32
|
/**
|
|
18
33
|
* Get subgraph block number by chain id
|
|
19
34
|
* @param chainId - chain id from {@link CHAIN_IDS}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"subgraph.js","sourceRoot":"","sources":["../../../src/views/subgraph.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"subgraph.js","sourceRoot":"","sources":["../../../src/views/subgraph.ts"],"names":[],"mappings":"AACA,OAAO,EACL,qBAAqB,EACrB,QAAQ,EACR,YAAY,GACb,MAAM,qCAAqC,CAAA;AAE5C;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,EAAE,OAAO,EAA0B,EAAE,EAAE;IACzE,OAAO,YAAY,CAAC,OAAO,CAAC,CAAA;AAC9B,CAAC,CAAA;AAED;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,EAC1C,OAAO,GAGR,EAAE,EAAE;IACH,OAAO,qBAAqB,CAAC,OAAO,CAAC,CAAA;AACvC,CAAC,CAAA;AAED;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EAAE,EAC3C,OAAO,GAGR,EAAE,EAAE;IACH,MAAM,EACJ,IAAI,EAAE,EACJ,KAAK,EAAE,EACL,KAAK,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,GAC/B,GACF,GACF,GAAG,MAAM,QAAQ,CAAC,GAAG,CAOpB,OAAO,EACP,sBAAsB,EACtB,2DAA2D,EAC3D,EAAE,CACH,CAAA;IACD,OAAO,WAAW,CAAA;AACpB,CAAC,CAAA;AAED;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EAAE,EAAE,OAAO,EAA0B,EAAE,EAAE;IAC5E,MAAM,EACJ,IAAI,EAAE,EACJ,KAAK,EAAE,EACL,KAAK,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,GAC5D,GACF,GACF,GAAG,MAAM,QAAQ,CAAC,GAAG,CAYpB,OAAO,EACP,gBAAgB,EAChB,+EAA+E,EAC/E,EAAE,CACH,CAAA;IACD,OAAO;QACL,WAAW;QACX,IAAI;QACJ,SAAS;QACT,UAAU;KACX,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { createPublicClient, http } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../constants/chain-configs/chain';
|
|
3
|
+
import { fetchLatestSwaps } from '../entities/swap/apis';
|
|
4
|
+
export const getLatestSwaps = async ({ chainId, n, options, }) => {
|
|
5
|
+
const publicClient = createPublicClient({
|
|
6
|
+
chain: CHAIN_MAP[chainId],
|
|
7
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
8
|
+
});
|
|
9
|
+
return fetchLatestSwaps(publicClient, chainId, n, !!(options && options.useSubgraph), options?.blockTag ?? 'latest');
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=swap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"swap.js","sourceRoot":"","sources":["../../../src/views/swap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAE/C,OAAO,EAAa,SAAS,EAAE,MAAM,kCAAkC,CAAA;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAExD,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EAAE,EACnC,OAAO,EACP,CAAC,EACD,OAAO,GAOR,EAAmB,EAAE;IACpB,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;KAC3D,CAAC,CAAA;IACF,OAAO,gBAAgB,CACrB,YAAY,EACZ,OAAO,EACP,CAAC,EACD,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,EAClC,OAAO,EAAE,QAAQ,IAAI,QAAQ,CAC9B,CAAA;AACH,CAAC,CAAA"}
|