@clober/v2-sdk 1.0.0-beta.3 → 1.0.0-beta.30
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/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 +22 -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 +49 -13
- package/dist/cjs/constants/chain-configs/subgraph.js.map +1 -1
- package/dist/cjs/entities/analytics/apis/index.js +1 -1
- package/dist/cjs/entities/analytics/apis/index.js.map +1 -1
- package/dist/cjs/entities/pool/apis/snapshot.js +98 -28
- package/dist/cjs/entities/pool/apis/snapshot.js.map +1 -1
- package/dist/cjs/entities/swap/apis/index.js +4 -4
- 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 +3 -1
- 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/take.js +82 -0
- package/dist/cjs/views/market/take.js.map +1 -0
- package/dist/cjs/views/pool/index.js +4 -1
- package/dist/cjs/views/pool/index.js.map +1 -1
- package/dist/cjs/views/pool/market-making.js +87 -1
- 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/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/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 +22 -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 +48 -14
- package/dist/esm/constants/chain-configs/subgraph.js.map +1 -1
- package/dist/esm/entities/analytics/apis/index.js +1 -1
- package/dist/esm/entities/analytics/apis/index.js.map +1 -1
- package/dist/esm/entities/pool/apis/snapshot.js +96 -27
- package/dist/esm/entities/pool/apis/snapshot.js.map +1 -1
- package/dist/esm/entities/swap/apis/index.js +2 -2
- 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 +1 -0
- 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/take.js +78 -0
- package/dist/esm/views/market/take.js.map +1 -0
- package/dist/esm/views/pool/index.js +2 -1
- package/dist/esm/views/pool/index.js.map +1 -1
- package/dist/esm/views/pool/market-making.js +86 -1
- 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/subgraph.js +16 -1
- package/dist/esm/views/subgraph.js.map +1 -1
- package/dist/esm/views/{trade.js → swap.js} +4 -4
- package/dist/esm/views/swap.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +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/pool/apis/snapshot.d.ts +2 -0
- package/dist/types/entities/pool/apis/snapshot.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 +1 -1
- 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/events.d.ts +27 -0
- package/dist/types/types/events.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +2 -1
- 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/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/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 +1 -1
- package/dist/cjs/views/trade.js.map +0 -1
- package/dist/esm/views/trade.js.map +0 -1
- package/dist/types/views/trade.d.ts.map +0 -1
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.fetchPoolSnapshotsFromSubgraph = exports.fetchPoolSnapshotFromSubgraph = void 0;
|
|
3
|
+
exports.fetchUserPoolPositionsFromSubgraph = exports.fetchPoolSnapshotsFromSubgraph = exports.fetchPoolSnapshotFromSubgraph = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
5
6
|
const subgraph_1 = require("../../../constants/chain-configs/subgraph");
|
|
6
7
|
const views_1 = require("../../../views");
|
|
7
8
|
const fetchPoolSnapshotFromSubgraph = async (chainId, poolKey) => {
|
|
8
|
-
const { data: { pool, poolDayDatas }, } = await subgraph_1.Subgraph.get(chainId, 'getPoolSnapshot', 'query getPoolSnapshot($poolKey: ID!) { pool(id: $poolKey) { id salt tokenA { id name symbol decimals tokenDayData(orderBy: date, orderDirection: asc) { date priceUSD } } tokenB { id name symbol decimals tokenDayData(orderBy: date, orderDirection: asc) { date priceUSD } } initialTotalSupply initialTokenAAmount initialTokenBAmount initialLPPriceUSD createdAtTimestamp createdAtTransaction { id } totalValueLockedUSD totalSupply volumeUSD lpPriceUSD spreadProfitUSD } poolDayDatas( where: {pool: $poolKey, oraclePrice_gt: 0} orderBy: date orderDirection: desc first: 1000 ) { date totalValueLockedUSD totalSupply spreadProfitUSD lpPriceUSD oraclePrice priceA priceB volumeTokenA volumeTokenB volumeUSD } }', {
|
|
9
|
+
const { data: { pool, poolDayDatas, poolHourDatas }, } = await subgraph_1.Subgraph.get(chainId, 'getPoolSnapshot', 'query getPoolSnapshot($poolKey: ID!) { pool(id: $poolKey) { id salt tokenA { id name symbol decimals tokenDayData(orderBy: date, orderDirection: asc) { date priceUSD } } tokenB { id name symbol decimals tokenDayData(orderBy: date, orderDirection: asc) { date priceUSD } } initialTotalSupply initialTokenAAmount initialTokenBAmount initialLPPriceUSD createdAtTimestamp createdAtTransaction { id } totalValueLockedUSD totalSupply volumeUSD lpPriceUSD spreadProfitUSD } poolDayDatas( where: {pool: $poolKey, oraclePrice_gt: 0} orderBy: date orderDirection: desc first: 1000 ) { date totalValueLockedUSD totalSupply spreadProfitUSD lpPriceUSD oraclePrice priceA priceB volumeTokenA volumeTokenB volumeUSD } poolHourDatas( where: {pool: $poolKey, oraclePrice_gt: 0} orderBy: date orderDirection: desc first: 24 ) { date totalValueLockedUSD totalSupply spreadProfitUSD lpPriceUSD oraclePrice priceA priceB volumeTokenA volumeTokenB volumeUSD } }', {
|
|
9
10
|
poolKey: poolKey.toLowerCase(),
|
|
10
11
|
});
|
|
11
12
|
if (!pool) {
|
|
@@ -30,6 +31,49 @@ const fetchPoolSnapshotFromSubgraph = async (chainId, poolKey) => {
|
|
|
30
31
|
symbol: `CLV-${currencyB.symbol}-${currencyA.symbol}`,
|
|
31
32
|
decimals: 18,
|
|
32
33
|
};
|
|
34
|
+
const initialTokenAAmount = (0, viem_1.formatUnits)(BigInt(pool.initialTokenAAmount), Number(pool.tokenA.decimals));
|
|
35
|
+
const initialTokenBAmount = (0, viem_1.formatUnits)(BigInt(pool.initialTokenBAmount), Number(pool.tokenB.decimals));
|
|
36
|
+
const initialTotalSupply = (0, viem_1.formatUnits)(BigInt(pool.initialTotalSupply), 18);
|
|
37
|
+
const performanceHistories = poolDayDatas
|
|
38
|
+
.map((poolDayData) => {
|
|
39
|
+
const priceAUSD = pool.tokenA.tokenDayData.find(({ date }) => date === poolDayData.date)
|
|
40
|
+
?.priceUSD ?? '0';
|
|
41
|
+
const priceBUSD = pool.tokenB.tokenDayData.find(({ date }) => date === poolDayData.date)
|
|
42
|
+
?.priceUSD ?? '0';
|
|
43
|
+
const onHoldUSDValuePerLp = new bignumber_js_1.default(initialTokenAAmount)
|
|
44
|
+
.multipliedBy(priceAUSD)
|
|
45
|
+
.plus(new bignumber_js_1.default(initialTokenBAmount).multipliedBy(priceBUSD))
|
|
46
|
+
.dividedBy(initialTotalSupply)
|
|
47
|
+
.toString();
|
|
48
|
+
return {
|
|
49
|
+
timestamp: poolDayData.date,
|
|
50
|
+
spreadProfitUSD: poolDayData.spreadProfitUSD,
|
|
51
|
+
tvlUSD: poolDayData.totalValueLockedUSD,
|
|
52
|
+
lpPriceUSD: poolDayData.lpPriceUSD,
|
|
53
|
+
oraclePrice: poolDayData.oraclePrice,
|
|
54
|
+
priceA: poolDayData.priceA,
|
|
55
|
+
priceAUSD,
|
|
56
|
+
priceB: poolDayData.priceB,
|
|
57
|
+
priceBUSD,
|
|
58
|
+
volumeA: {
|
|
59
|
+
currency: currencyA,
|
|
60
|
+
value: poolDayData.volumeTokenA,
|
|
61
|
+
},
|
|
62
|
+
volumeB: {
|
|
63
|
+
currency: currencyB,
|
|
64
|
+
value: poolDayData.volumeTokenB,
|
|
65
|
+
},
|
|
66
|
+
onHoldUSDValuePerLp,
|
|
67
|
+
volumeUSD: poolDayData.volumeUSD,
|
|
68
|
+
relativePriceIndex: Number(poolDayData.lpPriceUSD) / Number(onHoldUSDValuePerLp),
|
|
69
|
+
performanceIndex: Number(poolDayData.lpPriceUSD) / Number(pool.initialLPPriceUSD),
|
|
70
|
+
};
|
|
71
|
+
})
|
|
72
|
+
.sort((a, b) => a.timestamp - b.timestamp);
|
|
73
|
+
if (performanceHistories.length > 1) {
|
|
74
|
+
performanceHistories[0].performanceIndex = 1;
|
|
75
|
+
performanceHistories[0].relativePriceIndex = 1;
|
|
76
|
+
}
|
|
33
77
|
return {
|
|
34
78
|
chainId,
|
|
35
79
|
key: poolKey,
|
|
@@ -37,15 +81,15 @@ const fetchPoolSnapshotFromSubgraph = async (chainId, poolKey) => {
|
|
|
37
81
|
initialLPInfo: {
|
|
38
82
|
currencyA: {
|
|
39
83
|
currency: currencyA,
|
|
40
|
-
value:
|
|
84
|
+
value: initialTokenAAmount,
|
|
41
85
|
},
|
|
42
86
|
currencyB: {
|
|
43
87
|
currency: currencyB,
|
|
44
|
-
value:
|
|
88
|
+
value: initialTokenBAmount,
|
|
45
89
|
},
|
|
46
90
|
lpToken: {
|
|
47
91
|
currency: lpCurrency,
|
|
48
|
-
value:
|
|
92
|
+
value: initialTotalSupply,
|
|
49
93
|
},
|
|
50
94
|
lpPriceUSD: pool.initialLPPriceUSD,
|
|
51
95
|
timestamp: Number(pool.createdAtTimestamp),
|
|
@@ -54,32 +98,17 @@ const fetchPoolSnapshotFromSubgraph = async (chainId, poolKey) => {
|
|
|
54
98
|
currencyA,
|
|
55
99
|
currencyB,
|
|
56
100
|
lpCurrency,
|
|
57
|
-
volumeUSD24h:
|
|
101
|
+
volumeUSD24h: poolHourDatas
|
|
102
|
+
.reduce((acc, data) => acc + Number(data.volumeUSD), 0)
|
|
103
|
+
.toString(),
|
|
58
104
|
lpPriceUSD: pool.lpPriceUSD,
|
|
59
105
|
totalTvlUSD: pool.totalValueLockedUSD,
|
|
60
106
|
totalSpreadProfitUSD: pool.spreadProfitUSD,
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
oraclePrice: poolDayData.oraclePrice,
|
|
67
|
-
priceA: poolDayData.priceA,
|
|
68
|
-
priceAUSD: Number(pool.tokenA.tokenDayData.find(({ date }) => date === poolDayData.date)
|
|
69
|
-
?.priceUSD ?? 0),
|
|
70
|
-
priceB: poolDayData.priceB,
|
|
71
|
-
priceBUSD: Number(pool.tokenB.tokenDayData.find(({ date }) => date === poolDayData.date)
|
|
72
|
-
?.priceUSD ?? 0),
|
|
73
|
-
volumeA: {
|
|
74
|
-
currency: currencyA,
|
|
75
|
-
value: poolDayData.volumeTokenA,
|
|
76
|
-
},
|
|
77
|
-
volumeB: {
|
|
78
|
-
currency: currencyB,
|
|
79
|
-
value: poolDayData.volumeTokenB,
|
|
80
|
-
},
|
|
81
|
-
volumeUSD: poolDayData.volumeUSD,
|
|
82
|
-
})),
|
|
107
|
+
currentPerformanceIndex: performanceHistories?.[performanceHistories.length - 1]
|
|
108
|
+
?.performanceIndex || 0,
|
|
109
|
+
currentRelativePriceIndex: performanceHistories?.[performanceHistories.length - 1]
|
|
110
|
+
?.relativePriceIndex || 0,
|
|
111
|
+
performanceHistories,
|
|
83
112
|
};
|
|
84
113
|
};
|
|
85
114
|
exports.fetchPoolSnapshotFromSubgraph = fetchPoolSnapshotFromSubgraph;
|
|
@@ -90,4 +119,45 @@ const fetchPoolSnapshotsFromSubgraph = async (chainId) => {
|
|
|
90
119
|
}));
|
|
91
120
|
};
|
|
92
121
|
exports.fetchPoolSnapshotsFromSubgraph = fetchPoolSnapshotsFromSubgraph;
|
|
122
|
+
const fetchUserPoolPositionsFromSubgraph = async (chainId, userAddress, prices) => {
|
|
123
|
+
const { data: { userPoolBalances }, } = await subgraph_1.Subgraph.get(chainId, 'getUserPoolBalances', 'query getUserPoolBalances($userAddress: String!) { userPoolBalances(where: {user: $userAddress}) { user { id } lpBalance pool { id salt totalSupply liquidityA liquidityB tokenA { id decimals symbol name } tokenB { id decimals symbol name } } lpBalanceUSD averageLPPriceUSD } }', {
|
|
124
|
+
userAddress: userAddress.toLowerCase(),
|
|
125
|
+
});
|
|
126
|
+
return userPoolBalances.map(({ user, averageLPPriceUSD, lpBalance: _lpBalance, pool }) => {
|
|
127
|
+
const lpBalance = Number((0, viem_1.formatUnits)(BigInt(_lpBalance), 18));
|
|
128
|
+
const currencyA = {
|
|
129
|
+
address: (0, viem_1.getAddress)(pool.tokenA.id),
|
|
130
|
+
name: pool.tokenA.name,
|
|
131
|
+
symbol: pool.tokenA.symbol,
|
|
132
|
+
decimals: Number(pool.tokenA.decimals),
|
|
133
|
+
};
|
|
134
|
+
const currencyB = {
|
|
135
|
+
address: (0, viem_1.getAddress)(pool.tokenB.id),
|
|
136
|
+
name: pool.tokenB.name,
|
|
137
|
+
symbol: pool.tokenB.symbol,
|
|
138
|
+
decimals: Number(pool.tokenB.decimals),
|
|
139
|
+
};
|
|
140
|
+
const totalSupply = Number((0, viem_1.formatUnits)(BigInt(pool.totalSupply), 18));
|
|
141
|
+
const liquidityA = Number((0, viem_1.formatUnits)(BigInt(pool.liquidityA), Number(pool.tokenA.decimals)));
|
|
142
|
+
const liquidityAInUSD = liquidityA *
|
|
143
|
+
(prices?.[currencyA.address.toLowerCase()] ?? 0);
|
|
144
|
+
const liquidityB = Number((0, viem_1.formatUnits)(BigInt(pool.liquidityB), Number(pool.tokenB.decimals)));
|
|
145
|
+
const liquidityBInUSD = liquidityB *
|
|
146
|
+
(prices?.[currencyB.address.toLowerCase()] ?? 0);
|
|
147
|
+
const lpPrice = (liquidityAInUSD + liquidityBInUSD) / totalSupply;
|
|
148
|
+
return {
|
|
149
|
+
chainId,
|
|
150
|
+
key: pool.id,
|
|
151
|
+
salt: pool.salt,
|
|
152
|
+
currencyA,
|
|
153
|
+
currencyB,
|
|
154
|
+
userAddress: (0, viem_1.getAddress)(user.id),
|
|
155
|
+
averageLPPriceUSD,
|
|
156
|
+
lpBalance: lpBalance.toString(),
|
|
157
|
+
lpBalanceUSD: (lpBalance * lpPrice).toString(),
|
|
158
|
+
pnlUSD: (lpBalance * (lpPrice - Number(averageLPPriceUSD))).toString(),
|
|
159
|
+
};
|
|
160
|
+
});
|
|
161
|
+
};
|
|
162
|
+
exports.fetchUserPoolPositionsFromSubgraph = fetchUserPoolPositionsFromSubgraph;
|
|
93
163
|
//# sourceMappingURL=snapshot.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../../../../../src/entities/pool/apis/snapshot.ts"],"names":[],"mappings":";;;AAAA,+BAA8C;
|
|
1
|
+
{"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../../../../../src/entities/pool/apis/snapshot.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.fetchLatestSwaps = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
5
|
const subgraph_1 = require("../../../constants/chain-configs/subgraph");
|
|
6
6
|
const apis_1 = require("../../currency/apis");
|
|
7
|
-
const
|
|
8
|
-
const { data: { swaps }, } = await subgraph_1.Subgraph.get(chainId, '
|
|
7
|
+
const fetchLatestSwaps = async (publicClient, chainId, n, useSubgraph) => {
|
|
8
|
+
const { data: { swaps }, } = await subgraph_1.Subgraph.get(chainId, 'getLatestSwaps', 'query getLatestSwaps($first: Int!) { swaps(first: $first, orderBy: timestamp, orderDirection: desc) { transaction { id gasUsed gasPrice value to from } timestamp inputToken outputToken inputAmount outputAmount amountUSD router } }', {
|
|
9
9
|
first: n,
|
|
10
10
|
});
|
|
11
11
|
const uniqueTokens = [
|
|
@@ -44,5 +44,5 @@ const fetchLatestTrades = async (publicClient, chainId, n, useSubgraph) => {
|
|
|
44
44
|
})
|
|
45
45
|
.filter((swap) => swap !== null);
|
|
46
46
|
};
|
|
47
|
-
exports.
|
|
47
|
+
exports.fetchLatestSwaps = fetchLatestSwaps;
|
|
48
48
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/entities/swap/apis/index.ts"],"names":[],"mappings":";;;AAAA,+BAA4D;AAG5D,wEAAoE;AAEpE,8CAAsD;AAoB/C,MAAM,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/entities/swap/apis/index.ts"],"names":[],"mappings":";;;AAAA,+BAA4D;AAG5D,wEAAoE;AAEpE,8CAAsD;AAoB/C,MAAM,gBAAgB,GAAG,KAAK,EACnC,YAA0B,EAC1B,OAAkB,EAClB,CAAS,EACT,WAAoB,EACH,EAAE;IACnB,MAAM,EACJ,IAAI,EAAE,EAAE,KAAK,EAAE,GAChB,GAAG,MAAM,mBAAQ,CAAC,GAAG,CAKpB,OAAO,EACP,gBAAgB,EAChB,wOAAwO,EACxO;QACE,KAAK,EAAE,CAAC;KACT,CACF,CAAA;IACD,MAAM,YAAY,GAAG;QACnB,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;KACzE,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAA,iBAAU,EAAC,OAAO,CAAC,CAAC,CAAA;IACvC,MAAM,WAAW,GAAG,MAAM,IAAA,uBAAgB,EACxC,YAAY,EACZ,OAAO,EACP,YAAY,EACZ,WAAW,CACZ,CAAA;IAED,OAAO,KAAK;SACT,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,OAAO,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC7C,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACzC,CAAC,CAAC;gBACE,WAAW,EAAE;oBACX,IAAI,EAAE,EAAmB;oBACzB,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,EAAmB;oBACxC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;oBACrC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;oBAC3C,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;oBACrC,EAAE,EAAE,IAAA,iBAAU,EAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;oBACnC,IAAI,EAAE,IAAA,iBAAU,EAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;iBACxC;gBACD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;gBACjC,UAAU,EAAE;oBACV,QAAQ,EAAE,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,UAAU,CAAC,CAAC;oBAClD,MAAM,EAAE,IAAA,kBAAW,EACjB,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EACxB,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAClD;oBACD,SAAS,EAAE,IAAI;iBAChB;gBACD,WAAW,EAAE;oBACX,QAAQ,EAAE,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBACnD,MAAM,EAAE,IAAA,kBAAW,EACjB,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EACzB,WAAW,CAAC,IAAA,iBAAU,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CACnD;oBACD,SAAS,EAAE,KAAK;iBACjB;gBACD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;gBACjC,MAAM,EAAE,IAAA,iBAAU,EAAC,IAAI,CAAC,MAAM,CAAC;aAChC;YACH,CAAC,CAAC,IAAI,CAAA;IACV,CAAC,CAAC;SACD,MAAM,CAAC,CAAC,IAAI,EAAe,EAAE,CAAC,IAAI,KAAK,IAAI,CAAW,CAAA;AAC3D,CAAC,CAAA;AAnEY,QAAA,gBAAgB,oBAmE5B"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fetchLatestTakes = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const subgraph_1 = require("../../../constants/chain-configs/subgraph");
|
|
6
|
+
const market_id_1 = require("../../market/utils/market-id");
|
|
7
|
+
const fetchLatestTakes = async (chainId, tokenA, tokenB) => {
|
|
8
|
+
const { data: { takes }, } = await subgraph_1.Subgraph.get(chainId, 'getLatestTakes', 'query TakesByTokenPair($tokenA: String!, $tokenB: String!) { takes( orderBy: timestamp orderDirection: desc where: {or: [{inputToken: $tokenA, outputToken: $tokenB}, {inputToken: $tokenB, outputToken: $tokenA}]} ) { id timestamp amountUSD inputAmount outputAmount inputToken { id decimals } outputToken { id decimals } origin } }', {
|
|
9
|
+
tokenA: tokenA.toLowerCase(),
|
|
10
|
+
tokenB: tokenB.toLowerCase(),
|
|
11
|
+
});
|
|
12
|
+
const { quoteTokenAddress } = (0, market_id_1.getMarketId)(chainId, [tokenA, tokenB]);
|
|
13
|
+
return takes.map((swap) => {
|
|
14
|
+
const side = (0, viem_1.isAddressEqual)(swap.inputToken.id, quoteTokenAddress)
|
|
15
|
+
? 'buy'
|
|
16
|
+
: 'sell';
|
|
17
|
+
const baseAmount = Number((0, viem_1.formatUnits)(BigInt(side === 'buy' ? swap.outputAmount : swap.inputAmount), side === 'buy'
|
|
18
|
+
? Number(swap.outputToken.decimals)
|
|
19
|
+
: Number(swap.inputToken.decimals)));
|
|
20
|
+
const quoteAmount = Number((0, viem_1.formatUnits)(BigInt(side === 'buy' ? swap.inputAmount : swap.outputAmount), side === 'buy'
|
|
21
|
+
? Number(swap.inputToken.decimals)
|
|
22
|
+
: Number(swap.outputToken.decimals)));
|
|
23
|
+
return {
|
|
24
|
+
transactionHash: swap.id.split('-')[0],
|
|
25
|
+
timestamp: parseInt(swap.timestamp),
|
|
26
|
+
side,
|
|
27
|
+
price: quoteAmount / baseAmount,
|
|
28
|
+
amount: baseAmount,
|
|
29
|
+
amountUSD: Number(swap.amountUSD),
|
|
30
|
+
user: (0, viem_1.getAddress)(swap.origin),
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
exports.fetchLatestTakes = fetchLatestTakes;
|
|
35
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/entities/take/apis/index.ts"],"names":[],"mappings":";;;AAAA,+BAA8D;AAE9D,wEAAoE;AAEpE,4DAA0D;AAuBnD,MAAM,gBAAgB,GAAG,KAAK,EACnC,OAAkB,EAClB,MAAqB,EACrB,MAAqB,EACrB,EAAE;IACF,MAAM,EACJ,IAAI,EAAE,EAAE,KAAK,EAAE,GAChB,GAAG,MAAM,mBAAQ,CAAC,GAAG,CAKpB,OAAO,EACP,gBAAgB,EAChB,2UAA2U,EAC3U;QACE,MAAM,EAAE,MAAM,CAAC,WAAW,EAAE;QAC5B,MAAM,EAAE,MAAM,CAAC,WAAW,EAAE;KAC7B,CACF,CAAA;IACD,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAA,uBAAW,EAAC,OAAO,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAA;IAEpE,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACxB,MAAM,IAAI,GAAG,IAAA,qBAAc,EAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,iBAAiB,CAAC;YAChE,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,MAAM,CAAA;QACV,MAAM,UAAU,GAAG,MAAM,CACvB,IAAA,kBAAW,EACT,MAAM,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,EAC7D,IAAI,KAAK,KAAK;YACZ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;YACnC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CACrC,CACF,CAAA;QACD,MAAM,WAAW,GAAG,MAAM,CACxB,IAAA,kBAAW,EACT,MAAM,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAC7D,IAAI,KAAK,KAAK;YACZ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;YAClC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CACtC,CACF,CAAA;QACD,OAAO;YACL,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAkB;YACvD,SAAS,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;YACnC,IAAI;YACJ,KAAK,EAAE,WAAW,GAAG,UAAU;YAC/B,MAAM,EAAE,UAAU;YAClB,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,IAAI,EAAE,IAAA,iBAAU,EAAC,IAAI,CAAC,MAAM,CAAC;SAC9B,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AApDY,QAAA,gBAAgB,oBAoD5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/types/events.ts"],"names":[],"mappings":""}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":";;;AAAA,0DAA4D;AAAnD,kGAAA,SAAS,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":";;;AAAA,0DAA4D;AAAnD,kGAAA,SAAS,OAAA;AAqClB,IAAY,mBAaX;AAbD,WAAY,mBAAmB;IAC7B,uCAAgB,CAAA;IAChB,0CAAmB,CAAA;IACnB,yCAAkB,CAAA;IAClB,yCAAkB,CAAA;IAClB,6CAAsB,CAAA;IACtB,4CAAqB,CAAA;IACrB,qCAAc,CAAA;IACd,sCAAe,CAAA;IACf,uCAAgB,CAAA;IAChB,sCAAe,CAAA;IACf,oCAAa,CAAA;IACb,qCAAc,CAAA;AAChB,CAAC,EAbW,mBAAmB,mCAAnB,mBAAmB,QAa9B"}
|
package/dist/cjs/views/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getUserNativeVolume = exports.getTopUsersByNativeVolume = exports.getUserDailyVolumes = exports.getProtocolAnalytics = exports.getDailyClosePriceMap = exports.getLatestPriceMap = exports.getStableCurrencies = exports.getCurrencies = exports.getReferenceCurrency = exports.getNativeCurrency = exports.getContractAddresses = exports.getSubgraphBlock = exports.getSubgraphBlockNumber = exports.getSubgraphEndpoint = exports.getOpenOrders = exports.getOpenOrder = exports.getPriceNeighborhood = exports.
|
|
3
|
+
exports.getUserNativeVolume = exports.getTopUsersByNativeVolume = exports.getUserDailyVolumes = exports.getProtocolAnalytics = exports.getDailyClosePriceMap = exports.getLatestPriceMap = exports.getStableCurrencies = exports.getCurrencies = exports.getReferenceCurrency = exports.getNativeCurrency = exports.getContractAddresses = exports.getSubgraphBlock = exports.getSubgraphBlockNumber = exports.getFallbackSubgraphEndpoint = exports.getSubgraphEndpoint = exports.getOpenOrders = exports.getOpenOrder = exports.getPriceNeighborhood = exports.getLatestSwaps = exports.watchMarketMakingEvents = exports.getLpWrappedERC20Address = exports.getLastAmounts = exports.getStrategyPrice = exports.getUserPoolPositions = exports.getPoolSnapshots = exports.getPoolSnapshot = exports.getPool = exports.watchTakeEvents = exports.parseMakeOrderIdsFromReceipt = exports.getQuoteToken = exports.getMarketSnapshot = exports.getMarketSnapshots = exports.getExpectedInput = exports.getExpectedOutput = exports.getLatestChartLog = exports.getChartLogs = exports.getMarket = void 0;
|
|
4
4
|
var market_1 = require("./market");
|
|
5
5
|
Object.defineProperty(exports, "getMarket", { enumerable: true, get: function () { return market_1.getMarket; } });
|
|
6
6
|
Object.defineProperty(exports, "getChartLogs", { enumerable: true, get: function () { return market_1.getChartLogs; } });
|
|
@@ -11,15 +11,18 @@ Object.defineProperty(exports, "getMarketSnapshots", { enumerable: true, get: fu
|
|
|
11
11
|
Object.defineProperty(exports, "getMarketSnapshot", { enumerable: true, get: function () { return market_1.getMarketSnapshot; } });
|
|
12
12
|
Object.defineProperty(exports, "getQuoteToken", { enumerable: true, get: function () { return market_1.getQuoteToken; } });
|
|
13
13
|
Object.defineProperty(exports, "parseMakeOrderIdsFromReceipt", { enumerable: true, get: function () { return market_1.parseMakeOrderIdsFromReceipt; } });
|
|
14
|
+
Object.defineProperty(exports, "watchTakeEvents", { enumerable: true, get: function () { return market_1.watchTakeEvents; } });
|
|
14
15
|
var pool_1 = require("./pool");
|
|
15
16
|
Object.defineProperty(exports, "getPool", { enumerable: true, get: function () { return pool_1.getPool; } });
|
|
16
17
|
Object.defineProperty(exports, "getPoolSnapshot", { enumerable: true, get: function () { return pool_1.getPoolSnapshot; } });
|
|
17
18
|
Object.defineProperty(exports, "getPoolSnapshots", { enumerable: true, get: function () { return pool_1.getPoolSnapshots; } });
|
|
19
|
+
Object.defineProperty(exports, "getUserPoolPositions", { enumerable: true, get: function () { return pool_1.getUserPoolPositions; } });
|
|
18
20
|
Object.defineProperty(exports, "getStrategyPrice", { enumerable: true, get: function () { return pool_1.getStrategyPrice; } });
|
|
19
21
|
Object.defineProperty(exports, "getLastAmounts", { enumerable: true, get: function () { return pool_1.getLastAmounts; } });
|
|
20
22
|
Object.defineProperty(exports, "getLpWrappedERC20Address", { enumerable: true, get: function () { return pool_1.getLpWrappedERC20Address; } });
|
|
21
|
-
|
|
22
|
-
|
|
23
|
+
Object.defineProperty(exports, "watchMarketMakingEvents", { enumerable: true, get: function () { return pool_1.watchMarketMakingEvents; } });
|
|
24
|
+
var swap_1 = require("./swap");
|
|
25
|
+
Object.defineProperty(exports, "getLatestSwaps", { enumerable: true, get: function () { return swap_1.getLatestSwaps; } });
|
|
23
26
|
var tick_1 = require("./tick");
|
|
24
27
|
Object.defineProperty(exports, "getPriceNeighborhood", { enumerable: true, get: function () { return tick_1.getPriceNeighborhood; } });
|
|
25
28
|
var open_order_1 = require("./open-order");
|
|
@@ -27,6 +30,7 @@ Object.defineProperty(exports, "getOpenOrder", { enumerable: true, get: function
|
|
|
27
30
|
Object.defineProperty(exports, "getOpenOrders", { enumerable: true, get: function () { return open_order_1.getOpenOrders; } });
|
|
28
31
|
var subgraph_1 = require("./subgraph");
|
|
29
32
|
Object.defineProperty(exports, "getSubgraphEndpoint", { enumerable: true, get: function () { return subgraph_1.getSubgraphEndpoint; } });
|
|
33
|
+
Object.defineProperty(exports, "getFallbackSubgraphEndpoint", { enumerable: true, get: function () { return subgraph_1.getFallbackSubgraphEndpoint; } });
|
|
30
34
|
Object.defineProperty(exports, "getSubgraphBlockNumber", { enumerable: true, get: function () { return subgraph_1.getSubgraphBlockNumber; } });
|
|
31
35
|
Object.defineProperty(exports, "getSubgraphBlock", { enumerable: true, get: function () { return subgraph_1.getSubgraphBlock; } });
|
|
32
36
|
var address_1 = require("./address");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/index.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/index.ts"],"names":[],"mappings":";;;AAAA,mCAWiB;AAVf,mGAAA,SAAS,OAAA;AACT,sGAAA,YAAY,OAAA;AACZ,2GAAA,iBAAiB,OAAA;AACjB,2GAAA,iBAAiB,OAAA;AACjB,0GAAA,gBAAgB,OAAA;AAChB,4GAAA,kBAAkB,OAAA;AAClB,2GAAA,iBAAiB,OAAA;AACjB,uGAAA,aAAa,OAAA;AACb,sHAAA,4BAA4B,OAAA;AAC5B,yGAAA,eAAe,OAAA;AAEjB,+BASe;AARb,+FAAA,OAAO,OAAA;AACP,uGAAA,eAAe,OAAA;AACf,wGAAA,gBAAgB,OAAA;AAChB,4GAAA,oBAAoB,OAAA;AACpB,wGAAA,gBAAgB,OAAA;AAChB,sGAAA,cAAc,OAAA;AACd,gHAAA,wBAAwB,OAAA;AACxB,+GAAA,uBAAuB,OAAA;AAEzB,+BAAuC;AAA9B,sGAAA,cAAc,OAAA;AAEvB,+BAA6C;AAApC,4GAAA,oBAAoB,OAAA;AAC7B,2CAA0D;AAAjD,0GAAA,YAAY,OAAA;AAAE,2GAAA,aAAa,OAAA;AACpC,uCAKmB;AAJjB,+GAAA,mBAAmB,OAAA;AACnB,uHAAA,2BAA2B,OAAA;AAC3B,kHAAA,sBAAsB,OAAA;AACtB,4GAAA,gBAAgB,OAAA;AAElB,qCAAgD;AAAvC,+GAAA,oBAAoB,OAAA;AAC7B,uCAOmB;AANjB,6GAAA,iBAAiB,OAAA;AACjB,gHAAA,oBAAoB,OAAA;AACpB,yGAAA,aAAa,OAAA;AACb,+GAAA,mBAAmB,OAAA;AACnB,6GAAA,iBAAiB,OAAA;AACjB,iHAAA,qBAAqB,OAAA;AAEvB,yCAKoB;AAJlB,iHAAA,oBAAoB,OAAA;AACpB,gHAAA,mBAAmB,OAAA;AACnB,sHAAA,yBAAyB,OAAA;AACzB,gHAAA,mBAAmB,OAAA"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getMarket = exports.parseMakeOrderIdsFromReceipt = exports.getQuoteToken = exports.getMarketSnapshot = exports.getMarketSnapshots = exports.getLatestChartLog = exports.getChartLogs = exports.getExpectedInput = exports.getExpectedOutput = void 0;
|
|
3
|
+
exports.getMarket = exports.parseMakeOrderIdsFromReceipt = exports.getQuoteToken = exports.getMarketSnapshot = exports.getMarketSnapshots = exports.getLatestChartLog = exports.getChartLogs = exports.getExpectedInput = exports.getExpectedOutput = exports.watchTakeEvents = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
5
|
const chain_1 = require("../../constants/chain-configs/chain");
|
|
6
6
|
const apis_1 = require("../../entities/market/apis");
|
|
7
|
+
var take_1 = require("./take");
|
|
8
|
+
Object.defineProperty(exports, "watchTakeEvents", { enumerable: true, get: function () { return take_1.watchTakeEvents; } });
|
|
7
9
|
var quote_1 = require("./quote");
|
|
8
10
|
Object.defineProperty(exports, "getExpectedOutput", { enumerable: true, get: function () { return quote_1.getExpectedOutput; } });
|
|
9
11
|
Object.defineProperty(exports, "getExpectedInput", { enumerable: true, get: function () { return quote_1.getExpectedInput; } });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/market/index.ts"],"names":[],"mappings":";;;AAAA,+BAA+D;AAE/D,+DAA0E;AAE1E,qDAAwD;AAExD,iCAA6D;AAApD,0GAAA,iBAAiB,OAAA;AAAE,yGAAA,gBAAgB,OAAA;AAC5C,yCAA6D;AAApD,yGAAA,YAAY,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AACxC,uCAAkE;AAAzD,8GAAA,kBAAkB,OAAA;AAAE,6GAAA,iBAAiB,OAAA;AAC9C,iCAAuC;AAA9B,sGAAA,aAAa,OAAA;AACtB,iCAAsD;AAA7C,qHAAA,4BAA4B,OAAA;AAmB9B,MAAM,SAAS,GAAG,KAAK,EAAE,EAC9B,OAAO,EACP,MAAM,EACN,MAAM,EACN,OAAO,GAQR,EAAmB,EAAE;IACpB,IAAI,IAAA,qBAAc,EAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA;IACxD,CAAC;IACD,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAA;IACF,MAAM,MAAM,GAAG,MAAM,IAAA,kBAAW,EAC9B,YAAY,EACZ,OAAO,EACP,CAAC,MAAM,EAAE,MAAM,CAAC,EAChB,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,CACnC,CAAA;IACD,OAAO,MAAM,CAAC,MAAM,EAAE,CAAA;AACxB,CAAC,CAAA;AA3BY,QAAA,SAAS,aA2BrB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/market/index.ts"],"names":[],"mappings":";;;AAAA,+BAA+D;AAE/D,+DAA0E;AAE1E,qDAAwD;AAExD,+BAAwC;AAA/B,uGAAA,eAAe,OAAA;AACxB,iCAA6D;AAApD,0GAAA,iBAAiB,OAAA;AAAE,yGAAA,gBAAgB,OAAA;AAC5C,yCAA6D;AAApD,yGAAA,YAAY,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AACxC,uCAAkE;AAAzD,8GAAA,kBAAkB,OAAA;AAAE,6GAAA,iBAAiB,OAAA;AAC9C,iCAAuC;AAA9B,sGAAA,aAAa,OAAA;AACtB,iCAAsD;AAA7C,qHAAA,4BAA4B,OAAA;AAmB9B,MAAM,SAAS,GAAG,KAAK,EAAE,EAC9B,OAAO,EACP,MAAM,EACN,MAAM,EACN,OAAO,GAQR,EAAmB,EAAE;IACpB,IAAI,IAAA,qBAAc,EAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA;IACxD,CAAC;IACD,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAA;IACF,MAAM,MAAM,GAAG,MAAM,IAAA,kBAAW,EAC9B,YAAY,EACZ,OAAO,EACP,CAAC,MAAM,EAAE,MAAM,CAAC,EAChB,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,CACnC,CAAA;IACD,OAAO,MAAM,CAAC,MAAM,EAAE,CAAA;AACxB,CAAC,CAAA;AA3BY,QAAA,SAAS,aA2BrB"}
|
|
@@ -7,6 +7,7 @@ const order_id_1 = require("../../entities/open-order/utils/order-id");
|
|
|
7
7
|
const parseMakeOrderIdsFromReceipt = ({ market, transactionReceipt, }) => {
|
|
8
8
|
const logs = (0, viem_1.parseEventLogs)({
|
|
9
9
|
abi: book_manager_abi_1.BOOK_MANAGER_ABI,
|
|
10
|
+
eventName: 'Make',
|
|
10
11
|
logs: transactionReceipt.logs,
|
|
11
12
|
}).filter((log) => log.eventName === 'Make');
|
|
12
13
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse.js","sourceRoot":"","sources":["../../../../src/views/market/parse.ts"],"names":[],"mappings":";;;AAAA,+BAAyD;AAEzD,iFAA6E;AAC7E,uEAAoE;AAG7D,MAAM,4BAA4B,GAAG,CAAC,EAC3C,MAAM,EACN,kBAAkB,GAInB,EAGC,EAAE;IACF,MAAM,IAAI,GAAG,IAAA,qBAAc,EAAC;QAC1B,GAAG,EAAE,mCAAgB;QACrB,IAAI,EAAE,kBAAkB,CAAC,IAAI;KAC9B,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,KAAK,MAAM,CAAC,CAAA;IAC5C,OAAO;QACL,WAAW,EAAE,IAAI;aACd,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aACtE,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAC9C,IAAA,oBAAS,EAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CACzD;QACH,WAAW,EAAE,IAAI;aACd,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aACtE,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAC9C,IAAA,oBAAS,EAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CACzD;KACJ,CAAA;AACH,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"parse.js","sourceRoot":"","sources":["../../../../src/views/market/parse.ts"],"names":[],"mappings":";;;AAAA,+BAAyD;AAEzD,iFAA6E;AAC7E,uEAAoE;AAG7D,MAAM,4BAA4B,GAAG,CAAC,EAC3C,MAAM,EACN,kBAAkB,GAInB,EAGC,EAAE;IACF,MAAM,IAAI,GAAG,IAAA,qBAAc,EAAC;QAC1B,GAAG,EAAE,mCAAgB;QACrB,SAAS,EAAE,MAAM;QACjB,IAAI,EAAE,kBAAkB,CAAC,IAAI;KAC9B,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,KAAK,MAAM,CAAC,CAAA;IAC5C,OAAO;QACL,WAAW,EAAE,IAAI;aACd,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aACtE,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAC9C,IAAA,oBAAS,EAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CACzD;QACH,WAAW,EAAE,IAAI;aACd,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aACtE,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAC9C,IAAA,oBAAS,EAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CACzD;KACJ,CAAA;AACH,CAAC,CAAA;AA3BY,QAAA,4BAA4B,gCA2BxC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.watchTakeEvents = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const chain_1 = require("../../constants/chain-configs/chain");
|
|
6
|
+
const utils_1 = require("../../utils");
|
|
7
|
+
const address_1 = require("../address");
|
|
8
|
+
const book_manager_abi_1 = require("../../constants/abis/core/book-manager-abi");
|
|
9
|
+
const apis_1 = require("../../entities/take/apis");
|
|
10
|
+
const handleTakeLog = (log, market, onEvent) => {
|
|
11
|
+
const { args } = log;
|
|
12
|
+
const isTakingBidBook = BigInt(market.bidBook.id) === args.bookId;
|
|
13
|
+
const tick = BigInt(args.tick);
|
|
14
|
+
const unit = BigInt(args.unit);
|
|
15
|
+
const price = isTakingBidBook
|
|
16
|
+
? (0, utils_1.formatPrice)((0, utils_1.toPrice)(tick), market.quote.decimals, market.base.decimals)
|
|
17
|
+
: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(tick)), market.quote.decimals, market.base.decimals);
|
|
18
|
+
const amount = isTakingBidBook
|
|
19
|
+
? (0, viem_1.formatUnits)((0, utils_1.quoteToBase)(tick, unit * BigInt(market.bidBook.unitSize), false), market.base.decimals)
|
|
20
|
+
: (0, viem_1.formatUnits)(unit * BigInt(market.askBook.unitSize), market.base.decimals);
|
|
21
|
+
onEvent({
|
|
22
|
+
transactionHash: log.transactionHash,
|
|
23
|
+
logIndex: Number(log.logIndex),
|
|
24
|
+
timestamp: Number(log.blockTimestamp),
|
|
25
|
+
blockNumber: Number(log.blockNumber),
|
|
26
|
+
price: parseFloat(price),
|
|
27
|
+
amount: parseFloat(amount),
|
|
28
|
+
amountUSD: Number(parseFloat(price) * parseFloat(amount)),
|
|
29
|
+
side: isTakingBidBook ? 'sell' : 'buy',
|
|
30
|
+
});
|
|
31
|
+
};
|
|
32
|
+
const backfillTakeEventsFromSubgraph = async ({ chainId, market, onEvent, }) => {
|
|
33
|
+
const takes = await (0, apis_1.fetchLatestTakes)(chainId, market.base.address, market.quote.address);
|
|
34
|
+
const logIndexMap = new Map();
|
|
35
|
+
for (const take of takes.reverse()) {
|
|
36
|
+
if (logIndexMap.has(take.transactionHash)) {
|
|
37
|
+
logIndexMap.set(take.transactionHash, (logIndexMap.get(take.transactionHash) ?? 0) + 1);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
logIndexMap.set(take.transactionHash, 0);
|
|
41
|
+
}
|
|
42
|
+
onEvent({
|
|
43
|
+
...take,
|
|
44
|
+
logIndex: logIndexMap.get(take.transactionHash),
|
|
45
|
+
blockNumber: 0,
|
|
46
|
+
side: take.side,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
const watchTakeEvents = async ({ chainId, market, onEvent, onError, options, }) => {
|
|
51
|
+
const publicClient = (0, viem_1.createPublicClient)({
|
|
52
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
53
|
+
transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
|
|
54
|
+
});
|
|
55
|
+
const seen = new Set();
|
|
56
|
+
await backfillTakeEventsFromSubgraph({
|
|
57
|
+
chainId,
|
|
58
|
+
market,
|
|
59
|
+
onEvent,
|
|
60
|
+
});
|
|
61
|
+
return publicClient.watchContractEvent({
|
|
62
|
+
address: (0, address_1.getContractAddresses)({ chainId }).BookManager,
|
|
63
|
+
abi: book_manager_abi_1.BOOK_MANAGER_ABI,
|
|
64
|
+
eventName: 'Take',
|
|
65
|
+
args: {
|
|
66
|
+
bookId: [BigInt(market.bidBook.id), BigInt(market.askBook.id)],
|
|
67
|
+
},
|
|
68
|
+
onLogs: (logs) => {
|
|
69
|
+
for (const log of logs) {
|
|
70
|
+
const key = `${log.transactionHash}-${log.logIndex}`;
|
|
71
|
+
if (seen.has(key)) {
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
seen.add(key);
|
|
75
|
+
handleTakeLog(log, market, onEvent);
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
onError,
|
|
79
|
+
});
|
|
80
|
+
};
|
|
81
|
+
exports.watchTakeEvents = watchTakeEvents;
|
|
82
|
+
//# sourceMappingURL=take.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"take.js","sourceRoot":"","sources":["../../../../src/views/market/take.ts"],"names":[],"mappings":";;;AAAA,+BAA4D;AAE5D,+DAA0E;AAE1E,uCAA2E;AAC3E,wCAAiD;AACjD,iFAA6E;AAC7E,mDAA2D;AAE3D,MAAM,aAAa,GAAG,CACpB,GAAQ,EACR,MAAc,EACd,OAAkC,EAClC,EAAE;IACF,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,CAAA;IAEpB,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,IAAI,CAAC,MAAM,CAAA;IACjE,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC9B,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC9B,MAAM,KAAK,GAAG,eAAe;QAC3B,CAAC,CAAC,IAAA,mBAAW,EAAC,IAAA,eAAO,EAAC,IAAI,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;QACzE,CAAC,CAAC,IAAA,mBAAW,EACT,IAAA,eAAO,EAAC,IAAA,kBAAU,EAAC,IAAI,CAAC,CAAC,EACzB,MAAM,CAAC,KAAK,CAAC,QAAQ,EACrB,MAAM,CAAC,IAAI,CAAC,QAAQ,CACrB,CAAA;IACL,MAAM,MAAM,GAAG,eAAe;QAC5B,CAAC,CAAC,IAAA,kBAAW,EACT,IAAA,mBAAW,EAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,EAChE,MAAM,CAAC,IAAI,CAAC,QAAQ,CACrB;QACH,CAAC,CAAC,IAAA,kBAAW,EAAC,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAE7E,OAAO,CAAC;QACN,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,QAAQ,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAC9B,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC;QACrC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC;QACpC,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC;QACxB,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC;QAC1B,SAAS,EAAE,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,EAAE,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK;KACvC,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,MAAM,8BAA8B,GAAG,KAAK,EAAE,EAC5C,OAAO,EACP,MAAM,EACN,OAAO,GAKR,EAAE,EAAE;IACH,MAAM,KAAK,GAAG,MAAM,IAAA,uBAAgB,EAClC,OAAO,EACP,MAAM,CAAC,IAAI,CAAC,OAAO,EACnB,MAAM,CAAC,KAAK,CAAC,OAAO,CACrB,CAAA;IAED,MAAM,WAAW,GAAG,IAAI,GAAG,EAAkB,CAAA;IAC7C,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;QACnC,IAAI,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC;YAC1C,WAAW,CAAC,GAAG,CACb,IAAI,CAAC,eAAe,EACpB,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CACjD,CAAA;QACH,CAAC;aAAM,CAAC;YACN,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAA;QAC1C,CAAC;QAED,OAAO,CAAC;YACN,GAAG,IAAI;YACP,QAAQ,EAAE,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAE;YAChD,WAAW,EAAE,CAAC;YACd,IAAI,EAAE,IAAI,CAAC,IAAsB;SAClC,CAAC,CAAA;IACJ,CAAC;AACH,CAAC,CAAA;AAEM,MAAM,eAAe,GAAG,KAAK,EAAE,EACpC,OAAO,EACP,MAAM,EACN,OAAO,EACP,OAAO,EACP,OAAO,GAOR,EAAE,EAAE;IACH,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAA;IAEF,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAA;IAE9B,MAAM,8BAA8B,CAAC;QACnC,OAAO;QACP,MAAM;QACN,OAAO;KACR,CAAC,CAAA;IAEF,OAAO,YAAY,CAAC,kBAAkB,CAAC;QACrC,OAAO,EAAE,IAAA,8BAAoB,EAAC,EAAE,OAAO,EAAE,CAAC,CAAC,WAAW;QACtD,GAAG,EAAE,mCAAgB;QACrB,SAAS,EAAE,MAAM;QACjB,IAAI,EAAE;YACJ,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;SAC/D;QACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;YACf,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;gBACvB,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC,eAAe,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAA;gBACpD,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;oBAClB,SAAQ;gBACV,CAAC;gBACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;gBAEb,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;YACrC,CAAC;QACH,CAAC;QAED,OAAO;KACR,CAAC,CAAA;AACJ,CAAC,CAAA;AA/CY,QAAA,eAAe,mBA+C3B"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getLpWrappedERC20Address = exports.getPool = exports.getPoolSnapshots = exports.getPoolSnapshot = exports.getLastAmounts = exports.getStrategyPrice = void 0;
|
|
3
|
+
exports.getLpWrappedERC20Address = exports.getPool = exports.getUserPoolPositions = exports.getPoolSnapshots = exports.getPoolSnapshot = exports.watchMarketMakingEvents = exports.getLastAmounts = exports.getStrategyPrice = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
5
|
const chain_1 = require("../../constants/chain-configs/chain");
|
|
6
6
|
const apis_1 = require("../../entities/pool/apis");
|
|
@@ -9,9 +9,12 @@ const wrapped_6909_factory_abi_1 = require("../../constants/abis/rebalancer/wrap
|
|
|
9
9
|
var market_making_1 = require("./market-making");
|
|
10
10
|
Object.defineProperty(exports, "getStrategyPrice", { enumerable: true, get: function () { return market_making_1.getStrategyPrice; } });
|
|
11
11
|
Object.defineProperty(exports, "getLastAmounts", { enumerable: true, get: function () { return market_making_1.getLastAmounts; } });
|
|
12
|
+
Object.defineProperty(exports, "watchMarketMakingEvents", { enumerable: true, get: function () { return market_making_1.watchMarketMakingEvents; } });
|
|
12
13
|
var snapshot_1 = require("./snapshot");
|
|
13
14
|
Object.defineProperty(exports, "getPoolSnapshot", { enumerable: true, get: function () { return snapshot_1.getPoolSnapshot; } });
|
|
14
15
|
Object.defineProperty(exports, "getPoolSnapshots", { enumerable: true, get: function () { return snapshot_1.getPoolSnapshots; } });
|
|
16
|
+
var position_1 = require("./position");
|
|
17
|
+
Object.defineProperty(exports, "getUserPoolPositions", { enumerable: true, get: function () { return position_1.getUserPoolPositions; } });
|
|
15
18
|
const getPool = async ({ chainId, token0, token1, salt, options, }) => {
|
|
16
19
|
if ((0, viem_1.isAddressEqual)(token0, token1)) {
|
|
17
20
|
throw new Error('Token0 and token1 must be different');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/pool/index.ts"],"names":[],"mappings":";;;AAAA,+BAA+D;AAE/D,+DAA0E;AAO1E,mDAAoD;AACpD,uEAA4E;AAC5E,uGAAmG;AAEnG,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/pool/index.ts"],"names":[],"mappings":";;;AAAA,+BAA+D;AAE/D,+DAA0E;AAO1E,mDAAoD;AACpD,uEAA4E;AAC5E,uGAAmG;AAEnG,iDAIwB;AAHtB,iHAAA,gBAAgB,OAAA;AAChB,+GAAA,cAAc,OAAA;AACd,wHAAA,uBAAuB,OAAA;AAEzB,uCAA8D;AAArD,2GAAA,eAAe,OAAA;AAAE,4GAAA,gBAAgB,OAAA;AAC1C,uCAAiD;AAAxC,gHAAA,oBAAoB,OAAA;AAsBtB,MAAM,OAAO,GAAG,KAAK,EAAE,EAC5B,OAAO,EACP,MAAM,EACN,MAAM,EACN,IAAI,EACJ,OAAO,GAWR,EAAiB,EAAE;IAClB,IAAI,IAAA,qBAAc,EAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA;IACxD,CAAC;IACD,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAA;IACF,MAAM,IAAI,GAAG,MAAM,IAAA,gBAAS,EAC1B,YAAY,EACZ,OAAO,EACP,CAAC,MAAM,EAAE,MAAM,CAAC,EAChB,IAAI,EACJ,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,EAClC,OAAO,EAAE,MAAM,CAChB,CAAA;IACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;IACvC,CAAC;IACD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAA;AACtB,CAAC,CAAA;AApCY,QAAA,OAAO,WAoCnB;AAEM,MAAM,wBAAwB,GAAG,CAAC,EACvC,OAAO,EACP,OAAO,EACP,OAAO,GAOR,EAAE,EAAE;IACH,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAA;IACF,OAAO,YAAY,CAAC,YAAY,CAAC;QAC/B,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,kBAAkB;QACxD,GAAG,EAAE,mDAAwB;QAC7B,YAAY,EAAE,uBAAuB;QACrC,IAAI,EAAE,CAAC,8BAAkB,CAAC,OAAO,CAAE,CAAC,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;KACjE,CAAC,CAAA;AACJ,CAAC,CAAA;AArBY,QAAA,wBAAwB,4BAqBpC"}
|
|
@@ -1,9 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getLastAmounts = exports.getStrategyPrice = void 0;
|
|
3
|
+
exports.watchMarketMakingEvents = exports.getLastAmounts = exports.getStrategyPrice = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
5
6
|
const chain_1 = require("../../constants/chain-configs/chain");
|
|
6
7
|
const strategy_1 = require("../../entities/pool/apis/strategy");
|
|
8
|
+
const rebalancer_abi_1 = require("../../constants/abis/rebalancer/rebalancer-abi");
|
|
9
|
+
const address_1 = require("../address");
|
|
10
|
+
const order_id_1 = require("../../entities/open-order/utils/order-id");
|
|
11
|
+
const utils_1 = require("../../utils");
|
|
7
12
|
const getStrategyPrice = async ({ chainId, poolKey, options, }) => {
|
|
8
13
|
const publicClient = (0, viem_1.createPublicClient)({
|
|
9
14
|
chain: chain_1.CHAIN_MAP[chainId],
|
|
@@ -20,4 +25,85 @@ const getLastAmounts = async ({ chainId, poolKey, options, }) => {
|
|
|
20
25
|
return (0, strategy_1.fetchLastAmounts)(publicClient, chainId, poolKey);
|
|
21
26
|
};
|
|
22
27
|
exports.getLastAmounts = getLastAmounts;
|
|
28
|
+
const handleRebalanceLog = (log, poolSnapshot, onEvent) => {
|
|
29
|
+
const { args } = log;
|
|
30
|
+
onEvent({
|
|
31
|
+
transactionHash: log.transactionHash,
|
|
32
|
+
logIndex: Number(log.logIndex),
|
|
33
|
+
timestamp: Number(log.blockTimestamp),
|
|
34
|
+
blockNumber: Number(log.blockNumber),
|
|
35
|
+
bidOrderList: args.orderListA.map((orderId) => {
|
|
36
|
+
const tick = (0, order_id_1.fromOrderId)(orderId).tick;
|
|
37
|
+
const price = (0, utils_1.formatPrice)((0, utils_1.toPrice)(tick), poolSnapshot.currencyA.decimals, poolSnapshot.currencyB.decimals);
|
|
38
|
+
const amount = (0, viem_1.formatUnits)(args.amountA, poolSnapshot.currencyA.decimals);
|
|
39
|
+
return {
|
|
40
|
+
price,
|
|
41
|
+
size: new bignumber_js_1.default(amount)
|
|
42
|
+
.dividedBy(new bignumber_js_1.default(price))
|
|
43
|
+
.toFixed(poolSnapshot.currencyB.decimals),
|
|
44
|
+
};
|
|
45
|
+
}),
|
|
46
|
+
askOrderList: args.orderListB.map((orderId) => {
|
|
47
|
+
const tick = (0, order_id_1.fromOrderId)(orderId).tick;
|
|
48
|
+
return {
|
|
49
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(tick)), poolSnapshot.currencyA.decimals, poolSnapshot.currencyB.decimals),
|
|
50
|
+
size: (0, viem_1.formatUnits)(args.amountB, poolSnapshot.currencyB.decimals),
|
|
51
|
+
};
|
|
52
|
+
}),
|
|
53
|
+
quoteReserve: (0, viem_1.formatUnits)(args.reserveA, poolSnapshot.currencyA.decimals),
|
|
54
|
+
baseReserve: (0, viem_1.formatUnits)(args.reserveB, poolSnapshot.currencyB.decimals),
|
|
55
|
+
});
|
|
56
|
+
};
|
|
57
|
+
const backfillRebalanceEvents = async ({ publicClient, chainId, poolSnapshot, backfillBlocks, onEvent, }) => {
|
|
58
|
+
const currentBlock = await publicClient.getBlockNumber();
|
|
59
|
+
const fromBlock = currentBlock > backfillBlocks ? currentBlock - backfillBlocks : 0n;
|
|
60
|
+
const logs = await publicClient.getLogs({
|
|
61
|
+
address: (0, address_1.getContractAddresses)({ chainId }).Rebalancer,
|
|
62
|
+
event: (0, viem_1.parseAbiItem)('event Rebalance(bytes32 indexed key,address indexed caller,uint256[] orderListA,uint256[] orderListB,uint256 amountA,uint256 amountB,uint256 reserveA,uint256 reserveB)'),
|
|
63
|
+
args: {
|
|
64
|
+
key: poolSnapshot.key,
|
|
65
|
+
},
|
|
66
|
+
fromBlock,
|
|
67
|
+
toBlock: currentBlock,
|
|
68
|
+
});
|
|
69
|
+
for (const log of logs) {
|
|
70
|
+
handleRebalanceLog(log, poolSnapshot, onEvent);
|
|
71
|
+
}
|
|
72
|
+
return currentBlock;
|
|
73
|
+
};
|
|
74
|
+
const watchMarketMakingEvents = async ({ chainId, poolSnapshot, options, onEvent, onError, }) => {
|
|
75
|
+
const publicClient = (0, viem_1.createPublicClient)({
|
|
76
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
77
|
+
transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
|
|
78
|
+
});
|
|
79
|
+
const seen = new Set();
|
|
80
|
+
const lastBackfilledBlock = await backfillRebalanceEvents({
|
|
81
|
+
publicClient,
|
|
82
|
+
chainId,
|
|
83
|
+
poolSnapshot,
|
|
84
|
+
backfillBlocks: options?.backfillBlocks ?? 100n,
|
|
85
|
+
onEvent,
|
|
86
|
+
});
|
|
87
|
+
return publicClient.watchContractEvent({
|
|
88
|
+
address: (0, address_1.getContractAddresses)({ chainId }).Rebalancer,
|
|
89
|
+
abi: rebalancer_abi_1.REBALANCER_ABI,
|
|
90
|
+
eventName: 'Rebalance',
|
|
91
|
+
args: {
|
|
92
|
+
key: poolSnapshot.key,
|
|
93
|
+
},
|
|
94
|
+
fromBlock: lastBackfilledBlock + 1n,
|
|
95
|
+
onLogs: (logs) => {
|
|
96
|
+
for (const log of logs) {
|
|
97
|
+
const key = `${log.blockNumber}-${log.logIndex}`;
|
|
98
|
+
if (seen.has(key)) {
|
|
99
|
+
continue;
|
|
100
|
+
}
|
|
101
|
+
seen.add(key);
|
|
102
|
+
handleRebalanceLog(log, poolSnapshot, onEvent);
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
onError,
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
exports.watchMarketMakingEvents = watchMarketMakingEvents;
|
|
23
109
|
//# sourceMappingURL=market-making.js.map
|