@clober/v2-sdk 0.0.6 → 0.0.7-5.dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -4
- package/dist/cjs/abis/core/book-manager-abi.js +112 -0
- package/dist/cjs/abis/core/book-manager-abi.js.map +1 -0
- package/dist/cjs/abis/core/book-viewer-abi.js +137 -5
- package/dist/cjs/abis/core/book-viewer-abi.js.map +1 -1
- package/dist/cjs/abis/core/controller-abi.js +29 -24
- package/dist/cjs/abis/core/controller-abi.js.map +1 -1
- package/dist/cjs/abis/rebalancer/minter-abi.js +230 -0
- package/dist/cjs/abis/rebalancer/minter-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/mock-swap-abi.js +95 -0
- package/dist/cjs/abis/rebalancer/mock-swap-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/operator-abi.js +375 -0
- package/dist/cjs/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/rebalancer-abi.js +1367 -0
- package/dist/cjs/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/strategy-abi.js +780 -0
- package/dist/cjs/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/cjs/apis/chart-logs.js +163 -0
- package/dist/cjs/apis/chart-logs.js.map +1 -0
- package/dist/cjs/apis/market.js +40 -21
- package/dist/cjs/apis/market.js.map +1 -1
- package/dist/cjs/apis/odos.js +100 -0
- package/dist/cjs/apis/odos.js.map +1 -0
- package/dist/cjs/apis/open-order.js +60 -28
- package/dist/cjs/apis/open-order.js.map +1 -1
- package/dist/cjs/apis/pool.js +79 -0
- package/dist/cjs/apis/pool.js.map +1 -0
- package/dist/cjs/apis/strategy.js +30 -0
- package/dist/cjs/apis/strategy.js.map +1 -0
- package/dist/cjs/approval.js +85 -31
- package/dist/cjs/approval.js.map +1 -1
- package/dist/cjs/call.js +837 -155
- package/dist/cjs/call.js.map +1 -1
- package/dist/cjs/constants/addresses.js +50 -1
- package/dist/cjs/constants/addresses.js.map +1 -1
- package/dist/cjs/constants/bera-bartio-chain.js +30 -0
- package/dist/cjs/constants/bera-bartio-chain.js.map +1 -0
- package/dist/cjs/constants/chain.js +18 -2
- package/dist/cjs/constants/chain.js.map +1 -1
- package/dist/cjs/constants/currency.js +56 -3
- package/dist/cjs/constants/currency.js.map +1 -1
- package/dist/cjs/constants/fee.js +17 -2
- package/dist/cjs/constants/fee.js.map +1 -1
- package/dist/cjs/constants/permit.js +14 -0
- package/dist/cjs/constants/permit.js.map +1 -0
- package/dist/cjs/constants/price.js +2 -1
- package/dist/cjs/constants/price.js.map +1 -1
- package/dist/cjs/constants/subgraph.js +35 -0
- package/dist/cjs/constants/subgraph.js.map +1 -0
- package/dist/cjs/constants/test-chain.js +50 -0
- package/dist/cjs/constants/test-chain.js.map +1 -0
- package/dist/cjs/constants/tick.js +6 -0
- package/dist/cjs/constants/tick.js.map +1 -0
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/model/book.js +62 -35
- package/dist/cjs/model/book.js.map +1 -1
- package/dist/cjs/model/chart-log.js +3 -0
- package/dist/cjs/model/chart-log.js.map +1 -0
- package/dist/cjs/model/market.js +61 -26
- package/dist/cjs/model/market.js.map +1 -1
- package/dist/cjs/model/pool.js +240 -0
- package/dist/cjs/model/pool.js.map +1 -0
- package/dist/cjs/type.js +16 -1
- package/dist/cjs/type.js.map +1 -1
- package/dist/cjs/utils/allowance.js +39 -0
- package/dist/cjs/utils/allowance.js.map +1 -0
- package/dist/cjs/utils/approval.js +2 -3
- package/dist/cjs/utils/approval.js.map +1 -1
- package/dist/cjs/utils/bigint.js +13 -0
- package/dist/cjs/utils/bigint.js.map +1 -0
- package/dist/cjs/utils/book-id.js +7 -7
- package/dist/cjs/utils/book-id.js.map +1 -1
- package/dist/cjs/utils/build-transaction.js +9 -9
- package/dist/cjs/utils/build-transaction.js.map +1 -1
- package/dist/cjs/utils/currency.js +95 -11
- package/dist/cjs/utils/currency.js.map +1 -1
- package/dist/cjs/utils/market.js +1 -1
- package/dist/cjs/utils/market.js.map +1 -1
- package/dist/cjs/utils/math.js +3 -1
- package/dist/cjs/utils/math.js.map +1 -1
- package/dist/cjs/utils/open.js +35 -25
- package/dist/cjs/utils/open.js.map +1 -1
- package/dist/cjs/utils/order.js +115 -0
- package/dist/cjs/utils/order.js.map +1 -0
- package/dist/cjs/utils/pool-key.js +17 -0
- package/dist/cjs/utils/pool-key.js.map +1 -0
- package/dist/cjs/utils/pool.js +88 -0
- package/dist/cjs/utils/pool.js.map +1 -0
- package/dist/cjs/utils/prices.js +40 -5
- package/dist/cjs/utils/prices.js.map +1 -1
- package/dist/cjs/utils/tick.js +12 -1
- package/dist/cjs/utils/tick.js.map +1 -1
- package/dist/cjs/utils/unit-size.js +48 -0
- package/dist/cjs/utils/unit-size.js.map +1 -0
- package/dist/cjs/utils.js +16 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/cjs/view.js +271 -40
- package/dist/cjs/view.js.map +1 -1
- package/dist/esm/abis/core/book-manager-abi.js +109 -0
- package/dist/esm/abis/core/book-manager-abi.js.map +1 -0
- package/dist/esm/abis/core/book-viewer-abi.js +137 -5
- package/dist/esm/abis/core/book-viewer-abi.js.map +1 -1
- package/dist/esm/abis/core/controller-abi.js +29 -24
- package/dist/esm/abis/core/controller-abi.js.map +1 -1
- package/dist/esm/abis/rebalancer/minter-abi.js +227 -0
- package/dist/esm/abis/rebalancer/minter-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/mock-swap-abi.js +92 -0
- package/dist/esm/abis/rebalancer/mock-swap-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/operator-abi.js +372 -0
- package/dist/esm/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/rebalancer-abi.js +1364 -0
- package/dist/esm/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/strategy-abi.js +777 -0
- package/dist/esm/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/esm/apis/chart-logs.js +159 -0
- package/dist/esm/apis/chart-logs.js.map +1 -0
- package/dist/esm/apis/market.js +41 -22
- package/dist/esm/apis/market.js.map +1 -1
- package/dist/esm/apis/odos.js +94 -0
- package/dist/esm/apis/odos.js.map +1 -0
- package/dist/esm/apis/open-order.js +61 -28
- package/dist/esm/apis/open-order.js.map +1 -1
- package/dist/esm/apis/pool.js +74 -0
- package/dist/esm/apis/pool.js.map +1 -0
- package/dist/esm/apis/strategy.js +26 -0
- package/dist/esm/apis/strategy.js.map +1 -0
- package/dist/esm/approval.js +122 -45
- package/dist/esm/approval.js.map +1 -1
- package/dist/esm/call.js +942 -270
- package/dist/esm/call.js.map +1 -1
- package/dist/esm/constants/addresses.js +51 -2
- package/dist/esm/constants/addresses.js.map +1 -1
- package/dist/esm/constants/bera-bartio-chain.js +27 -0
- package/dist/esm/constants/bera-bartio-chain.js.map +1 -0
- package/dist/esm/constants/chain.js +17 -2
- package/dist/esm/constants/chain.js.map +1 -1
- package/dist/esm/constants/currency.js +57 -2
- package/dist/esm/constants/currency.js.map +1 -1
- package/dist/esm/constants/fee.js +17 -2
- package/dist/esm/constants/fee.js.map +1 -1
- package/dist/esm/constants/permit.js +11 -0
- package/dist/esm/constants/permit.js.map +1 -0
- package/dist/esm/constants/price.js +1 -0
- package/dist/esm/constants/price.js.map +1 -1
- package/dist/esm/constants/subgraph.js +31 -0
- package/dist/esm/constants/subgraph.js.map +1 -0
- package/dist/esm/constants/test-chain.js +47 -0
- package/dist/esm/constants/test-chain.js.map +1 -0
- package/dist/esm/constants/tick.js +3 -0
- package/dist/esm/constants/tick.js.map +1 -0
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/model/book.js +62 -35
- package/dist/esm/model/book.js.map +1 -1
- package/dist/esm/model/chart-log.js +2 -0
- package/dist/esm/model/chart-log.js.map +1 -0
- package/dist/esm/model/market.js +63 -28
- package/dist/esm/model/market.js.map +1 -1
- package/dist/esm/model/pool.js +237 -0
- package/dist/esm/model/pool.js.map +1 -0
- package/dist/esm/type.js +15 -0
- package/dist/esm/type.js.map +1 -1
- package/dist/esm/utils/allowance.js +35 -0
- package/dist/esm/utils/allowance.js.map +1 -0
- package/dist/esm/utils/approval.js +2 -3
- package/dist/esm/utils/approval.js.map +1 -1
- package/dist/esm/utils/bigint.js +7 -0
- package/dist/esm/utils/bigint.js.map +1 -0
- package/dist/esm/utils/book-id.js +7 -7
- package/dist/esm/utils/book-id.js.map +1 -1
- package/dist/esm/utils/build-transaction.js +9 -9
- package/dist/esm/utils/build-transaction.js.map +1 -1
- package/dist/esm/utils/currency.js +93 -10
- package/dist/esm/utils/currency.js.map +1 -1
- package/dist/esm/utils/market.js +1 -1
- package/dist/esm/utils/market.js.map +1 -1
- package/dist/esm/utils/math.js +1 -0
- package/dist/esm/utils/math.js.map +1 -1
- package/dist/esm/utils/open.js +33 -23
- package/dist/esm/utils/open.js.map +1 -1
- package/dist/esm/utils/order.js +110 -0
- package/dist/esm/utils/order.js.map +1 -0
- package/dist/esm/utils/pool-key.js +12 -0
- package/dist/esm/utils/pool-key.js.map +1 -0
- package/dist/esm/utils/pool.js +84 -0
- package/dist/esm/utils/pool.js.map +1 -0
- package/dist/esm/utils/prices.js +39 -5
- package/dist/esm/utils/prices.js.map +1 -1
- package/dist/esm/utils/tick.js +11 -1
- package/dist/esm/utils/tick.js.map +1 -1
- package/dist/esm/utils/unit-size.js +44 -0
- package/dist/esm/utils/unit-size.js.map +1 -0
- package/dist/esm/utils.js +4 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/esm/view.js +410 -79
- package/dist/esm/view.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/abis/core/book-manager-abi.d.ts +82 -0
- package/dist/types/abis/core/book-manager-abi.d.ts.map +1 -0
- package/dist/types/abis/core/book-viewer-abi.d.ts +107 -5
- package/dist/types/abis/core/book-viewer-abi.d.ts.map +1 -1
- package/dist/types/abis/core/controller-abi.d.ts +23 -19
- package/dist/types/abis/core/controller-abi.d.ts.map +1 -1
- package/dist/types/abis/rebalancer/minter-abi.d.ts +174 -0
- package/dist/types/abis/rebalancer/minter-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/mock-swap-abi.d.ts +70 -0
- package/dist/types/abis/rebalancer/mock-swap-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/operator-abi.d.ts +287 -0
- package/dist/types/abis/rebalancer/operator-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/rebalancer-abi.d.ts +1056 -0
- package/dist/types/abis/rebalancer/rebalancer-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/strategy-abi.d.ts +602 -0
- package/dist/types/abis/rebalancer/strategy-abi.d.ts.map +1 -0
- package/dist/types/apis/chart-logs.d.ts +5 -0
- package/dist/types/apis/chart-logs.d.ts.map +1 -0
- package/dist/types/apis/market.d.ts +2 -1
- package/dist/types/apis/market.d.ts.map +1 -1
- package/dist/types/apis/odos.d.ts +28 -0
- package/dist/types/apis/odos.d.ts.map +1 -0
- package/dist/types/apis/open-order.d.ts +4 -2
- package/dist/types/apis/open-order.d.ts.map +1 -1
- package/dist/types/apis/pool.d.ts +12 -0
- package/dist/types/apis/pool.d.ts.map +1 -0
- package/dist/types/apis/strategy.d.ts +5 -0
- package/dist/types/apis/strategy.d.ts.map +1 -0
- package/dist/types/approval.d.ts +49 -17
- package/dist/types/approval.d.ts.map +1 -1
- package/dist/types/call.d.ts +311 -133
- package/dist/types/call.d.ts.map +1 -1
- package/dist/types/constants/addresses.d.ts +4 -0
- package/dist/types/constants/addresses.d.ts.map +1 -1
- package/dist/types/constants/bera-bartio-chain.d.ts +33 -0
- package/dist/types/constants/bera-bartio-chain.d.ts.map +1 -0
- package/dist/types/constants/chain.d.ts +7 -2
- package/dist/types/constants/chain.d.ts.map +1 -1
- package/dist/types/constants/currency.d.ts +6 -0
- package/dist/types/constants/currency.d.ts.map +1 -1
- package/dist/types/constants/fee.d.ts +7 -2
- package/dist/types/constants/fee.d.ts.map +1 -1
- package/dist/types/constants/permit.d.ts +10 -0
- package/dist/types/constants/permit.d.ts.map +1 -0
- package/dist/types/constants/price.d.ts +1 -0
- package/dist/types/constants/price.d.ts.map +1 -1
- package/dist/types/constants/subgraph.d.ts +5 -0
- package/dist/types/constants/subgraph.d.ts.map +1 -0
- package/dist/types/constants/test-chain.d.ts +4 -0
- package/dist/types/constants/test-chain.d.ts.map +1 -0
- package/dist/types/constants/tick.d.ts +3 -0
- package/dist/types/constants/tick.d.ts.map +1 -0
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/model/book.d.ts +25 -33
- package/dist/types/model/book.d.ts.map +1 -1
- package/dist/types/model/chart-log.d.ts +9 -0
- package/dist/types/model/chart-log.d.ts.map +1 -0
- package/dist/types/model/currency.d.ts +7 -0
- package/dist/types/model/currency.d.ts.map +1 -1
- package/dist/types/model/depth.d.ts +4 -3
- package/dist/types/model/depth.d.ts.map +1 -1
- package/dist/types/model/market.d.ts +24 -13
- package/dist/types/model/market.d.ts.map +1 -1
- package/dist/types/model/open-order.d.ts +20 -27
- package/dist/types/model/open-order.d.ts.map +1 -1
- package/dist/types/model/pool.d.ts +71 -0
- package/dist/types/model/pool.d.ts.map +1 -0
- package/dist/types/type.d.ts +112 -6
- package/dist/types/type.d.ts.map +1 -1
- package/dist/types/utils/allowance.d.ts +3 -0
- package/dist/types/utils/allowance.d.ts.map +1 -0
- package/dist/types/utils/approval.d.ts +2 -1
- package/dist/types/utils/approval.d.ts.map +1 -1
- package/dist/types/utils/bigint.d.ts +4 -0
- package/dist/types/utils/bigint.d.ts.map +1 -0
- package/dist/types/utils/book-id.d.ts +2 -1
- package/dist/types/utils/book-id.d.ts.map +1 -1
- package/dist/types/utils/build-transaction.d.ts +3 -3
- package/dist/types/utils/build-transaction.d.ts.map +1 -1
- package/dist/types/utils/currency.d.ts +5 -1
- package/dist/types/utils/currency.d.ts.map +1 -1
- package/dist/types/utils/math.d.ts +1 -0
- package/dist/types/utils/math.d.ts.map +1 -1
- package/dist/types/utils/open.d.ts +2 -1
- package/dist/types/utils/open.d.ts.map +1 -1
- package/dist/types/utils/order.d.ts +10 -0
- package/dist/types/utils/order.d.ts.map +1 -0
- package/dist/types/utils/pool-key.d.ts +3 -0
- package/dist/types/utils/pool-key.d.ts.map +1 -0
- package/dist/types/utils/pool.d.ts +11 -0
- package/dist/types/utils/pool.d.ts.map +1 -0
- package/dist/types/utils/prices.d.ts +13 -2
- package/dist/types/utils/prices.d.ts.map +1 -1
- package/dist/types/utils/tick.d.ts +1 -0
- package/dist/types/utils/tick.d.ts.map +1 -1
- package/dist/types/utils/unit-size.d.ts +5 -0
- package/dist/types/utils/unit-size.d.ts.map +1 -0
- package/dist/types/utils.d.ts +4 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/dist/types/view.d.ts +309 -51
- package/dist/types/view.d.ts.map +1 -1
- package/package.json +3 -2
- package/dist/cjs/abis/core/params-abi.js +0 -62
- package/dist/cjs/abis/core/params-abi.js.map +0 -1
- package/dist/cjs/apis/subgraph.js +0 -26
- package/dist/cjs/apis/subgraph.js.map +0 -1
- package/dist/cjs/constants/client.js +0 -14
- package/dist/cjs/constants/client.js.map +0 -1
- package/dist/cjs/constants/subgraph-url.js +0 -8
- package/dist/cjs/constants/subgraph-url.js.map +0 -1
- package/dist/cjs/signature.js +0 -141
- package/dist/cjs/signature.js.map +0 -1
- package/dist/cjs/utils/decorator.js +0 -13
- package/dist/cjs/utils/decorator.js.map +0 -1
- package/dist/cjs/utils/unit.js +0 -34
- package/dist/cjs/utils/unit.js.map +0 -1
- package/dist/esm/abis/core/params-abi.js +0 -59
- package/dist/esm/abis/core/params-abi.js.map +0 -1
- package/dist/esm/apis/subgraph.js +0 -22
- package/dist/esm/apis/subgraph.js.map +0 -1
- package/dist/esm/constants/client.js +0 -10
- package/dist/esm/constants/client.js.map +0 -1
- package/dist/esm/constants/subgraph-url.js +0 -5
- package/dist/esm/constants/subgraph-url.js.map +0 -1
- package/dist/esm/signature.js +0 -171
- package/dist/esm/signature.js.map +0 -1
- package/dist/esm/utils/decorator.js +0 -9
- package/dist/esm/utils/decorator.js.map +0 -1
- package/dist/esm/utils/unit.js +0 -30
- package/dist/esm/utils/unit.js.map +0 -1
- package/dist/types/abis/core/params-abi.d.ts +0 -21
- package/dist/types/abis/core/params-abi.d.ts.map +0 -1
- package/dist/types/apis/subgraph.d.ts +0 -3
- package/dist/types/apis/subgraph.d.ts.map +0 -1
- package/dist/types/constants/client.d.ts +0 -5
- package/dist/types/constants/client.d.ts.map +0 -1
- package/dist/types/constants/subgraph-url.d.ts +0 -5
- package/dist/types/constants/subgraph-url.d.ts.map +0 -1
- package/dist/types/signature.d.ts +0 -44
- package/dist/types/signature.d.ts.map +0 -1
- package/dist/types/utils/decorator.d.ts +0 -6
- package/dist/types/utils/decorator.d.ts.map +0 -1
- package/dist/types/utils/unit.d.ts +0 -4
- package/dist/types/utils/unit.d.ts.map +0 -1
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { Pool } from '../model/pool';
|
|
2
|
+
import { CONTRACT_ADDRESSES } from '../constants/addresses';
|
|
3
|
+
import { toPoolKey } from '../utils/pool-key';
|
|
4
|
+
import { REBALANCER_ABI } from '../abis/rebalancer/rebalancer-abi';
|
|
5
|
+
import { Subgraph } from '../constants/subgraph';
|
|
6
|
+
import { fetchMarket } from './market';
|
|
7
|
+
export const fetchPoolPerformance = async (chainId, poolKey, volumeFromTimestamp, snapshotFromTimestamp) => {
|
|
8
|
+
return Subgraph.get(chainId, 'getPoolPerformanceData', 'query getPoolPerformanceData($poolKey: String!, $volumeFrom: BigInt!, $snapshotFrom: BigInt!) { poolVolumes(where: { poolKey: $poolKey, intervalType: "1d", timestamp_gte: $volumeFrom, }) { id poolKey intervalType timestamp currencyAVolume currencyBVolume bookACurrencyAVolume bookACurrencyBVolume bookBCurrencyAVolume bookBCurrencyBVolume } poolSnapshots( where: { poolKey: $poolKey, intervalType: "1h", timestamp_gte: $snapshotFrom, } ) { id poolKey intervalType timestamp price liquidityA liquidityB totalSupply } }', {
|
|
9
|
+
poolKey,
|
|
10
|
+
volumeFrom: BigInt(volumeFromTimestamp),
|
|
11
|
+
snapshotFrom: BigInt(snapshotFromTimestamp),
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
export async function fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
15
|
+
if (tokenAddresses.length !== 2) {
|
|
16
|
+
throw new Error('Invalid token pair');
|
|
17
|
+
}
|
|
18
|
+
if (!market) {
|
|
19
|
+
market = (await fetchMarket(publicClient, chainId, tokenAddresses, useSubgraph)).toJson();
|
|
20
|
+
}
|
|
21
|
+
const poolKey = toPoolKey(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
22
|
+
const [{ bookIdA, bookIdB, reserveA, reserveB, orderListA, orderListB, paused }, totalSupply, [totalLiquidityA, totalLiquidityB],] = await publicClient.multicall({
|
|
23
|
+
allowFailure: false,
|
|
24
|
+
contracts: [
|
|
25
|
+
{
|
|
26
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
27
|
+
abi: REBALANCER_ABI,
|
|
28
|
+
functionName: 'getPool',
|
|
29
|
+
args: [poolKey],
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
33
|
+
abi: REBALANCER_ABI,
|
|
34
|
+
functionName: 'totalSupply',
|
|
35
|
+
args: [BigInt(poolKey)],
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
39
|
+
abi: REBALANCER_ABI,
|
|
40
|
+
functionName: 'getLiquidity',
|
|
41
|
+
args: [poolKey],
|
|
42
|
+
},
|
|
43
|
+
],
|
|
44
|
+
});
|
|
45
|
+
const liquidityA = totalLiquidityA.reserve +
|
|
46
|
+
totalLiquidityA.cancelable +
|
|
47
|
+
totalLiquidityA.claimable;
|
|
48
|
+
const liquidityB = totalLiquidityB.reserve +
|
|
49
|
+
totalLiquidityB.cancelable +
|
|
50
|
+
totalLiquidityB.claimable;
|
|
51
|
+
return new Pool({
|
|
52
|
+
chainId,
|
|
53
|
+
market,
|
|
54
|
+
isOpened: bookIdA > 0 && bookIdB > 0,
|
|
55
|
+
bookIdA,
|
|
56
|
+
bookIdB,
|
|
57
|
+
salt,
|
|
58
|
+
poolKey,
|
|
59
|
+
totalSupply: BigInt(totalSupply),
|
|
60
|
+
decimals: 18,
|
|
61
|
+
liquidityA: BigInt(liquidityA),
|
|
62
|
+
liquidityB: BigInt(liquidityB),
|
|
63
|
+
cancelableA: BigInt(totalLiquidityA.cancelable),
|
|
64
|
+
cancelableB: BigInt(totalLiquidityB.cancelable),
|
|
65
|
+
claimableA: BigInt(totalLiquidityA.claimable),
|
|
66
|
+
claimableB: BigInt(totalLiquidityB.claimable),
|
|
67
|
+
reserveA: BigInt(reserveA),
|
|
68
|
+
reserveB: BigInt(reserveB),
|
|
69
|
+
orderListA: orderListA.map((id) => BigInt(id)),
|
|
70
|
+
orderListB: orderListB.map((id) => BigInt(id)),
|
|
71
|
+
paused,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../../src/apis/pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { CONTRACT_ADDRESSES } from '../constants/addresses';
|
|
2
|
+
import { STRATEGY_ABI } from '../abis/rebalancer/strategy-abi';
|
|
3
|
+
import { toPoolKey } from '../utils/pool-key';
|
|
4
|
+
import { fetchPool } from './pool';
|
|
5
|
+
export async function fetchStrategyPrice(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
6
|
+
let poolKey = undefined;
|
|
7
|
+
if (market) {
|
|
8
|
+
poolKey = toPoolKey(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
const pool = await fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph);
|
|
12
|
+
poolKey = pool.key;
|
|
13
|
+
}
|
|
14
|
+
const getPriceResult = await publicClient.readContract({
|
|
15
|
+
address: CONTRACT_ADDRESSES[chainId].Strategy,
|
|
16
|
+
abi: STRATEGY_ABI,
|
|
17
|
+
functionName: 'getPrice',
|
|
18
|
+
args: [poolKey],
|
|
19
|
+
});
|
|
20
|
+
return {
|
|
21
|
+
oraclePrice: BigInt(getPriceResult.oraclePrice),
|
|
22
|
+
bidTick: BigInt(getPriceResult.tickA),
|
|
23
|
+
askTick: BigInt(getPriceResult.tickB),
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.js","sourceRoot":"","sources":["../../../src/apis/strategy.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAA;AAE3D,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAElC,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,YAA0B,EAC1B,OAAkB,EAClB,cAA+B,EAC/B,IAAmB,EACnB,WAAoB,EACpB,MAAe;IAEf,IAAI,OAAO,GAA8B,SAAS,CAAA;IAClD,IAAI,MAAM,EAAE,CAAC;QACX,OAAO,GAAG,SAAS,CACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EACzB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EACzB,IAAI,CACL,CAAA;IACH,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,GAAG,MAAM,SAAS,CAC1B,YAAY,EACZ,OAAO,EACP,cAAc,EACd,IAAI,EACJ,WAAW,CACZ,CAAA;QACD,OAAO,GAAG,IAAI,CAAC,GAAG,CAAA;IACpB,CAAC;IACD,MAAM,cAAc,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC;QACrD,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,QAAQ;QAC9C,GAAG,EAAE,YAAY;QACjB,YAAY,EAAE,UAAU;QACxB,IAAI,EAAE,CAAC,OAAO,CAAC;KAChB,CAAC,CAAA;IACF,OAAO;QACL,WAAW,EAAE,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC;QAC/C,OAAO,EAAE,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;QACrC,OAAO,EAAE,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;KACtC,CAAA;AACH,CAAC"}
|
package/dist/esm/approval.js
CHANGED
|
@@ -1,71 +1,148 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { createPublicClient, http, parseUnits } from 'viem';
|
|
2
2
|
import { CHAIN_MAP } from './constants/chain';
|
|
3
3
|
import { CONTRACT_ADDRESSES } from './constants/addresses';
|
|
4
4
|
import { fetchIsApprovedForAll } from './utils/approval';
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
{
|
|
8
|
-
inputs: [
|
|
9
|
-
{
|
|
10
|
-
internalType: 'address',
|
|
11
|
-
name: 'operator',
|
|
12
|
-
type: 'address',
|
|
13
|
-
},
|
|
14
|
-
{
|
|
15
|
-
internalType: 'bool',
|
|
16
|
-
name: 'approved',
|
|
17
|
-
type: 'bool',
|
|
18
|
-
},
|
|
19
|
-
],
|
|
20
|
-
name: 'setApprovalForAll',
|
|
21
|
-
outputs: [],
|
|
22
|
-
stateMutability: 'nonpayable',
|
|
23
|
-
type: 'function',
|
|
24
|
-
},
|
|
25
|
-
];
|
|
5
|
+
import { fetchAllowance } from './utils/allowance';
|
|
6
|
+
import { fetchCurrency } from './utils/currency';
|
|
26
7
|
/**
|
|
8
|
+
* @dev This function relates with `viem` dependency
|
|
27
9
|
* Sets approval of all open orders for the specified account on the given chain.
|
|
28
10
|
*
|
|
29
11
|
* @param {CHAIN_IDS} chainId The chain ID.
|
|
30
|
-
* @param {
|
|
12
|
+
* @param {WalletClient} walletClient The wallet client.
|
|
31
13
|
* @param {Object} [options] Optional parameters for setting approval.
|
|
32
14
|
* @param {string} options.rpcUrl The RPC URL to use for executing the transaction.
|
|
33
15
|
* @returns {Promise<`0x${string}` | undefined>} Promise resolving to the transaction hash. If the account is already approved for all, the promise resolves to `undefined`.
|
|
34
16
|
* @example
|
|
35
17
|
* import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
|
|
36
|
-
* import { privateKeyToAccount } from 'viem/accounts'
|
|
37
|
-
*
|
|
38
|
-
* const hash = await setApprovalOfOpenOrdersForAll(
|
|
39
|
-
* 421614,
|
|
40
|
-
* privateKeyToAccount('0x...')
|
|
41
|
-
* )
|
|
42
|
-
*
|
|
43
|
-
* @example
|
|
44
|
-
* import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
|
|
45
18
|
* import { mnemonicToAccount } from 'viem/accounts'
|
|
46
19
|
*
|
|
47
|
-
* const
|
|
48
|
-
*
|
|
49
|
-
* mnemonicToAccount('legal ...')
|
|
50
|
-
* )
|
|
20
|
+
* const walletClient = createWalletClient({
|
|
21
|
+
* chain: arbitrumSepolia,
|
|
22
|
+
* account: mnemonicToAccount('legal ...'),
|
|
23
|
+
* transport: http(),
|
|
24
|
+
* })
|
|
25
|
+
*
|
|
26
|
+
* const hash = await setApprovalOfOpenOrdersForAll({
|
|
27
|
+
* chainId: 421614,
|
|
28
|
+
* walletClient
|
|
29
|
+
* })
|
|
51
30
|
*/
|
|
52
|
-
export const setApprovalOfOpenOrdersForAll =
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
return undefined;
|
|
31
|
+
export const setApprovalOfOpenOrdersForAll = async ({ chainId, walletClient, options, }) => {
|
|
32
|
+
if (!walletClient.account) {
|
|
33
|
+
throw new Error('Account is not found');
|
|
56
34
|
}
|
|
57
|
-
const
|
|
35
|
+
const publicClient = createPublicClient({
|
|
58
36
|
chain: CHAIN_MAP[chainId],
|
|
59
|
-
account,
|
|
60
37
|
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
61
38
|
});
|
|
39
|
+
const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, walletClient.account.address);
|
|
40
|
+
if (isApprovedForAll) {
|
|
41
|
+
return undefined;
|
|
42
|
+
}
|
|
62
43
|
return walletClient.writeContract({
|
|
63
|
-
account,
|
|
44
|
+
account: walletClient.account,
|
|
64
45
|
chain: CHAIN_MAP[chainId],
|
|
65
46
|
address: CONTRACT_ADDRESSES[chainId].BookManager,
|
|
66
|
-
abi:
|
|
47
|
+
abi: [
|
|
48
|
+
{
|
|
49
|
+
inputs: [
|
|
50
|
+
{
|
|
51
|
+
internalType: 'address',
|
|
52
|
+
name: 'operator',
|
|
53
|
+
type: 'address',
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
internalType: 'bool',
|
|
57
|
+
name: 'approved',
|
|
58
|
+
type: 'bool',
|
|
59
|
+
},
|
|
60
|
+
],
|
|
61
|
+
name: 'setApprovalForAll',
|
|
62
|
+
outputs: [],
|
|
63
|
+
stateMutability: 'nonpayable',
|
|
64
|
+
type: 'function',
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
67
|
functionName: 'setApprovalForAll',
|
|
68
68
|
args: [CONTRACT_ADDRESSES[chainId].Controller, true],
|
|
69
69
|
});
|
|
70
|
-
}
|
|
70
|
+
};
|
|
71
|
+
/**
|
|
72
|
+
* @dev This function relates with `viem` dependency
|
|
73
|
+
* Approves the specified amount of tokens for the given account on the specified chain.
|
|
74
|
+
*
|
|
75
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
76
|
+
* @param {WalletClient} walletClient The wallet client.
|
|
77
|
+
* @param {`0x${string}`} token The ERC20 token address.
|
|
78
|
+
* @param {string | undefined} amount The amount to approve. If not provided, the maximum amount is approved.
|
|
79
|
+
* @param options
|
|
80
|
+
* @param options.rpcUrl The RPC URL of the blockchain.
|
|
81
|
+
* @returns {Promise<`0x${string}` | undefined>} Promise resolving to the transaction hash. If the account is already approved, the promise resolves to `undefined`.
|
|
82
|
+
* @example
|
|
83
|
+
* import { approveERC20 } from '@clober/v2-sdk'
|
|
84
|
+
*
|
|
85
|
+
* const walletClient = createWalletClient({
|
|
86
|
+
* chain: arbitrumSepolia,
|
|
87
|
+
* account: mnemonicToAccount('legal ...'),
|
|
88
|
+
* transport: http(),
|
|
89
|
+
* })
|
|
90
|
+
*
|
|
91
|
+
* const hash = await approveERC20({
|
|
92
|
+
* chainId: 421614,
|
|
93
|
+
* walletClient
|
|
94
|
+
* token: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
95
|
+
* amount: '1000.123', // approve 1000.123 USDC
|
|
96
|
+
* })
|
|
97
|
+
*/
|
|
98
|
+
export const approveERC20 = async ({ chainId, walletClient, token, amount, options, }) => {
|
|
99
|
+
if (!walletClient.account) {
|
|
100
|
+
throw new Error('Account is not found');
|
|
101
|
+
}
|
|
102
|
+
const publicClient = createPublicClient({
|
|
103
|
+
chain: CHAIN_MAP[chainId],
|
|
104
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
105
|
+
});
|
|
106
|
+
const [currency, allowance] = await Promise.all([
|
|
107
|
+
fetchCurrency(publicClient, chainId, token),
|
|
108
|
+
fetchAllowance(publicClient, token, walletClient.account.address, CONTRACT_ADDRESSES[chainId].Controller),
|
|
109
|
+
]);
|
|
110
|
+
const value = amount ? parseUnits(amount, currency.decimals) : 2n ** 256n - 1n;
|
|
111
|
+
if (allowance >= value) {
|
|
112
|
+
return undefined;
|
|
113
|
+
}
|
|
114
|
+
return walletClient.writeContract({
|
|
115
|
+
account: walletClient.account,
|
|
116
|
+
chain: CHAIN_MAP[chainId],
|
|
117
|
+
address: token,
|
|
118
|
+
abi: [
|
|
119
|
+
{
|
|
120
|
+
inputs: [
|
|
121
|
+
{
|
|
122
|
+
internalType: 'address',
|
|
123
|
+
name: 'spender',
|
|
124
|
+
type: 'address',
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
internalType: 'uint256',
|
|
128
|
+
name: 'value',
|
|
129
|
+
type: 'uint256',
|
|
130
|
+
},
|
|
131
|
+
],
|
|
132
|
+
name: 'approve',
|
|
133
|
+
outputs: [
|
|
134
|
+
{
|
|
135
|
+
internalType: 'bool',
|
|
136
|
+
name: '',
|
|
137
|
+
type: 'bool',
|
|
138
|
+
},
|
|
139
|
+
],
|
|
140
|
+
stateMutability: 'nonpayable',
|
|
141
|
+
type: 'function',
|
|
142
|
+
},
|
|
143
|
+
],
|
|
144
|
+
functionName: 'approve',
|
|
145
|
+
args: [CONTRACT_ADDRESSES[chainId].Controller, value],
|
|
146
|
+
});
|
|
147
|
+
};
|
|
71
148
|
//# sourceMappingURL=approval.js.map
|
package/dist/esm/approval.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"approval.js","sourceRoot":"","sources":["../../src/approval.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"approval.js","sourceRoot":"","sources":["../../src/approval.ts"],"names":[],"mappings":"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"}
|