@clober/v2-sdk 0.0.11 → 0.0.12-8.dev.0
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 +1 -6
- package/dist/cjs/abis/core/controller-abi.js.map +1 -1
- package/dist/cjs/abis/rebalancer/minter-abi.js +262 -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 +401 -0
- package/dist/cjs/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/rebalancer-abi.js +1326 -0
- package/dist/cjs/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/cjs/abis/rebalancer/strategy-abi.js +895 -0
- package/dist/cjs/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/cjs/apis/chart-logs.js +30 -13
- package/dist/cjs/apis/chart-logs.js.map +1 -1
- package/dist/cjs/apis/market.js +45 -22
- 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 +75 -44
- package/dist/cjs/apis/open-order.js.map +1 -1
- package/dist/cjs/apis/pool.js +95 -0
- package/dist/cjs/apis/pool.js.map +1 -0
- package/dist/cjs/apis/strategy.js +53 -0
- package/dist/cjs/apis/strategy.js.map +1 -0
- package/dist/cjs/approval.js +83 -26
- package/dist/cjs/approval.js.map +1 -1
- package/dist/cjs/call.js +739 -107
- package/dist/cjs/call.js.map +1 -1
- package/dist/cjs/constants/addresses.js +68 -1
- package/dist/cjs/constants/addresses.js.map +1 -1
- package/dist/cjs/constants/chain.js +23 -2
- package/dist/cjs/constants/chain.js.map +1 -1
- package/dist/cjs/constants/currency.js +86 -3
- package/dist/cjs/constants/currency.js.map +1 -1
- package/dist/cjs/constants/fee.js +21 -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/rise-sepolia.js +29 -0
- package/dist/cjs/constants/rise-sepolia.js.map +1 -0
- package/dist/cjs/constants/subgraph.js +37 -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/market.js +61 -26
- package/dist/cjs/model/market.js.map +1 -1
- package/dist/cjs/model/pool.js +239 -0
- package/dist/cjs/model/pool.js.map +1 -0
- 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 +5 -1
- package/dist/cjs/utils/bigint.js.map +1 -1
- 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 +3 -4
- package/dist/cjs/utils/build-transaction.js.map +1 -1
- package/dist/cjs/utils/currency.js +61 -27
- 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 +50 -126
- package/dist/cjs/utils/order.js.map +1 -1
- 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/quotes.js +16 -0
- package/dist/cjs/utils/quotes.js.map +1 -0
- package/dist/cjs/utils/tick.js +12 -1
- package/dist/cjs/utils/tick.js.map +1 -1
- package/dist/cjs/utils/time-series.js +31 -0
- package/dist/cjs/utils/time-series.js.map +1 -0
- package/dist/cjs/utils/unit-size.js +14 -0
- package/dist/cjs/utils/unit-size.js.map +1 -0
- package/dist/cjs/utils.js +18 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/cjs/view.js +308 -44
- 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 +1 -6
- package/dist/esm/abis/core/controller-abi.js.map +1 -1
- package/dist/esm/abis/rebalancer/minter-abi.js +259 -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 +398 -0
- package/dist/esm/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/rebalancer-abi.js +1323 -0
- package/dist/esm/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/esm/abis/rebalancer/strategy-abi.js +892 -0
- package/dist/esm/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/esm/apis/chart-logs.js +29 -12
- package/dist/esm/apis/chart-logs.js.map +1 -1
- package/dist/esm/apis/market.js +47 -24
- 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 +78 -44
- package/dist/esm/apis/open-order.js.map +1 -1
- package/dist/esm/apis/pool.js +96 -0
- package/dist/esm/apis/pool.js.map +1 -0
- package/dist/esm/apis/strategy.js +48 -0
- package/dist/esm/apis/strategy.js.map +1 -0
- package/dist/esm/approval.js +107 -25
- package/dist/esm/approval.js.map +1 -1
- package/dist/esm/call.js +772 -145
- package/dist/esm/call.js.map +1 -1
- package/dist/esm/constants/addresses.js +69 -2
- package/dist/esm/constants/addresses.js.map +1 -1
- package/dist/esm/constants/chain.js +23 -2
- package/dist/esm/constants/chain.js.map +1 -1
- package/dist/esm/constants/currency.js +87 -2
- package/dist/esm/constants/currency.js.map +1 -1
- package/dist/esm/constants/fee.js +21 -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/rise-sepolia.js +26 -0
- package/dist/esm/constants/rise-sepolia.js.map +1 -0
- package/dist/esm/constants/subgraph.js +33 -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/market.js +63 -28
- package/dist/esm/model/market.js.map +1 -1
- package/dist/esm/model/pool.js +236 -0
- package/dist/esm/model/pool.js.map +1 -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 +2 -0
- package/dist/esm/utils/bigint.js.map +1 -1
- 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 +3 -4
- package/dist/esm/utils/build-transaction.js.map +1 -1
- package/dist/esm/utils/currency.js +59 -25
- 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 +49 -125
- package/dist/esm/utils/order.js.map +1 -1
- 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/quotes.js +12 -0
- package/dist/esm/utils/quotes.js.map +1 -0
- package/dist/esm/utils/tick.js +11 -1
- package/dist/esm/utils/tick.js.map +1 -1
- package/dist/esm/utils/time-series.js +27 -0
- package/dist/esm/utils/time-series.js.map +1 -0
- package/dist/esm/utils/unit-size.js +10 -0
- package/dist/esm/utils/unit-size.js.map +1 -0
- package/dist/esm/utils.js +5 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/esm/view.js +379 -61
- 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 +1 -5
- package/dist/types/abis/core/controller-abi.d.ts.map +1 -1
- package/dist/types/abis/rebalancer/minter-abi.d.ts +198 -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 +308 -0
- package/dist/types/abis/rebalancer/operator-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/rebalancer-abi.d.ts +1023 -0
- package/dist/types/abis/rebalancer/rebalancer-abi.d.ts.map +1 -0
- package/dist/types/abis/rebalancer/strategy-abi.d.ts +690 -0
- package/dist/types/abis/rebalancer/strategy-abi.d.ts.map +1 -0
- package/dist/types/apis/chart-logs.d.ts +3 -0
- package/dist/types/apis/chart-logs.d.ts.map +1 -1
- 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 +3 -2
- package/dist/types/apis/open-order.d.ts.map +1 -1
- package/dist/types/apis/pool.d.ts +11 -0
- package/dist/types/apis/pool.d.ts.map +1 -0
- package/dist/types/apis/strategy.d.ts +6 -0
- package/dist/types/apis/strategy.d.ts.map +1 -0
- package/dist/types/approval.d.ts +37 -3
- package/dist/types/approval.d.ts.map +1 -1
- package/dist/types/call.d.ts +233 -54
- 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/chain.d.ts +9 -2
- package/dist/types/constants/chain.d.ts.map +1 -1
- package/dist/types/constants/currency.d.ts +8 -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/rise-sepolia.d.ts +32 -0
- package/dist/types/constants/rise-sepolia.d.ts.map +1 -0
- package/dist/types/constants/subgraph.d.ts +8 -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/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 +76 -0
- package/dist/types/model/pool.d.ts.map +1 -0
- package/dist/types/type.d.ts +95 -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 +2 -0
- package/dist/types/utils/bigint.d.ts.map +1 -1
- 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 +3 -2
- 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 +4 -11
- package/dist/types/utils/order.d.ts.map +1 -1
- 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/quotes.d.ts +2 -0
- package/dist/types/utils/quotes.d.ts.map +1 -0
- package/dist/types/utils/tick.d.ts +1 -0
- package/dist/types/utils/tick.d.ts.map +1 -1
- package/dist/types/utils/time-series.d.ts +4 -0
- package/dist/types/utils/time-series.d.ts.map +1 -0
- package/dist/types/utils/unit-size.d.ts +4 -0
- package/dist/types/utils/unit-size.d.ts.map +1 -0
- package/dist/types/utils.d.ts +5 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/dist/types/view.d.ts +236 -30
- package/dist/types/view.d.ts.map +1 -1
- package/package.json +4 -3
- 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 -145
- 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 -169
- 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 -38
- 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,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fetchPool = exports.fetchPoolPerformance = void 0;
|
|
4
|
+
const pool_1 = require("../model/pool");
|
|
5
|
+
const addresses_1 = require("../constants/addresses");
|
|
6
|
+
const pool_key_1 = require("../utils/pool-key");
|
|
7
|
+
const rebalancer_abi_1 = require("../abis/rebalancer/rebalancer-abi");
|
|
8
|
+
const subgraph_1 = require("../constants/subgraph");
|
|
9
|
+
const strategy_abi_1 = require("../abis/rebalancer/strategy-abi");
|
|
10
|
+
const market_1 = require("./market");
|
|
11
|
+
const fetchPoolPerformance = async (chainId, poolKey, volumeFromTimestamp, snapshotFromTimestamp, snapshotIntervalType, spreadProfitFromTimestamp) => {
|
|
12
|
+
const result = await subgraph_1.Subgraph.get(chainId, 'getPoolPerformanceData', 'query getPoolPerformanceData($poolKey: String!, $volumeFrom: BigInt!, $snapshotFrom: BigInt!, $snapshotIntervalType: String!, $spreadProfitFrom: BigInt!) { poolVolumes( first: 1000 skip: 0 orderBy: timestamp orderDirection: asc where: {poolKey: $poolKey, intervalType: "4h", timestamp_gte: $volumeFrom} ) { id poolKey intervalType timestamp currencyAVolume currencyBVolume bookACurrencyAVolume bookACurrencyBVolume bookBCurrencyAVolume bookBCurrencyBVolume } poolSnapshots( first: 1000 skip: 0 orderBy: timestamp orderDirection: asc where: {poolKey: $poolKey, intervalType: $snapshotIntervalType, timestamp_gte: $snapshotFrom} ) { id poolKey intervalType timestamp price liquidityA liquidityB totalSupply } poolSnapshotBefore: poolSnapshots( first: 1 skip: 0 orderBy: timestamp orderDirection: desc where: {poolKey: $poolKey, intervalType: $snapshotIntervalType, timestamp_lt: $snapshotFrom} ) { id poolKey intervalType timestamp price liquidityA liquidityB totalSupply } poolSnapshots2: poolSnapshots( first: 1000 skip: 1000 orderBy: timestamp orderDirection: asc where: {poolKey: $poolKey, intervalType: $snapshotIntervalType, timestamp_gte: $snapshotFrom} ) { id poolKey intervalType timestamp price liquidityA liquidityB totalSupply } poolSnapshots3: poolSnapshots( first: 1000 skip: 2000 orderBy: timestamp orderDirection: asc where: {poolKey: $poolKey, intervalType: $snapshotIntervalType, timestamp_gte: $snapshotFrom} ) { id poolKey intervalType timestamp price liquidityA liquidityB totalSupply } poolSpreadProfits( first: 1000 skip: 0 orderBy: timestamp orderDirection: asc where: {intervalType: "5m", timestamp_gte: $spreadProfitFrom} ) { id intervalType timestamp accumulatedProfitInUsd } }', {
|
|
13
|
+
poolKey,
|
|
14
|
+
volumeFrom: 0,
|
|
15
|
+
snapshotFrom: 0,
|
|
16
|
+
snapshotIntervalType: snapshotIntervalType.valueOf(),
|
|
17
|
+
spreadProfitFrom: 0,
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
poolVolumes: result.data.poolVolumes,
|
|
21
|
+
poolSnapshots: result.data.poolSnapshotBefore
|
|
22
|
+
.concat(result.data.poolSnapshots)
|
|
23
|
+
.concat(result.data.poolSnapshots2)
|
|
24
|
+
.concat(result.data.poolSnapshots3),
|
|
25
|
+
poolSpreadProfits: result.data.poolSpreadProfits,
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
exports.fetchPoolPerformance = fetchPoolPerformance;
|
|
29
|
+
async function fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
30
|
+
if (tokenAddresses.length !== 2) {
|
|
31
|
+
throw new Error('Invalid token pair');
|
|
32
|
+
}
|
|
33
|
+
if (!market) {
|
|
34
|
+
market = (await (0, market_1.fetchMarket)(publicClient, chainId, tokenAddresses, useSubgraph)).toJson();
|
|
35
|
+
}
|
|
36
|
+
const poolKey = (0, pool_key_1.toPoolKey)(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
37
|
+
const [{ bookIdA, bookIdB, reserveA, reserveB, orderListA, orderListB }, totalSupply, [totalLiquidityA, totalLiquidityB], paused,] = await publicClient.multicall({
|
|
38
|
+
allowFailure: false,
|
|
39
|
+
contracts: [
|
|
40
|
+
{
|
|
41
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
42
|
+
abi: rebalancer_abi_1.REBALANCER_ABI,
|
|
43
|
+
functionName: 'getPool',
|
|
44
|
+
args: [poolKey],
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
48
|
+
abi: rebalancer_abi_1.REBALANCER_ABI,
|
|
49
|
+
functionName: 'totalSupply',
|
|
50
|
+
args: [BigInt(poolKey)],
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
54
|
+
abi: rebalancer_abi_1.REBALANCER_ABI,
|
|
55
|
+
functionName: 'getLiquidity',
|
|
56
|
+
args: [poolKey],
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Strategy,
|
|
60
|
+
abi: strategy_abi_1.STRATEGY_ABI,
|
|
61
|
+
functionName: 'isPaused',
|
|
62
|
+
args: [poolKey],
|
|
63
|
+
},
|
|
64
|
+
],
|
|
65
|
+
});
|
|
66
|
+
const liquidityA = totalLiquidityA.reserve +
|
|
67
|
+
totalLiquidityA.cancelable +
|
|
68
|
+
totalLiquidityA.claimable;
|
|
69
|
+
const liquidityB = totalLiquidityB.reserve +
|
|
70
|
+
totalLiquidityB.cancelable +
|
|
71
|
+
totalLiquidityB.claimable;
|
|
72
|
+
return new pool_1.Pool({
|
|
73
|
+
chainId,
|
|
74
|
+
market,
|
|
75
|
+
isOpened: bookIdA > 0 && bookIdB > 0,
|
|
76
|
+
bookIdA,
|
|
77
|
+
bookIdB,
|
|
78
|
+
poolKey,
|
|
79
|
+
totalSupply: BigInt(totalSupply),
|
|
80
|
+
decimals: 18,
|
|
81
|
+
liquidityA: BigInt(liquidityA),
|
|
82
|
+
liquidityB: BigInt(liquidityB),
|
|
83
|
+
cancelableA: BigInt(totalLiquidityA.cancelable),
|
|
84
|
+
cancelableB: BigInt(totalLiquidityB.cancelable),
|
|
85
|
+
claimableA: BigInt(totalLiquidityA.claimable),
|
|
86
|
+
claimableB: BigInt(totalLiquidityB.claimable),
|
|
87
|
+
reserveA: BigInt(reserveA),
|
|
88
|
+
reserveB: BigInt(reserveB),
|
|
89
|
+
orderListA: orderListA.map((id) => BigInt(id)),
|
|
90
|
+
orderListB: orderListB.map((id) => BigInt(id)),
|
|
91
|
+
paused,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
exports.fetchPool = fetchPool;
|
|
95
|
+
//# sourceMappingURL=pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../../src/apis/pool.ts"],"names":[],"mappings":";;;AAGA,wCAKsB;AACtB,sDAA2D;AAC3D,gDAA6C;AAC7C,sEAAkE;AAElE,oDAAgD;AAChD,kEAA8D;AAE9D,qCAAsC;AAE/B,MAAM,oBAAoB,GAAG,KAAK,EACvC,OAAkB,EAClB,OAAsB,EAEtB,mBAA2B,EAE3B,qBAA6B,EAC7B,oBAAyC,EAEzC,yBAAiC,EACjC,EAAE;IACF,MAAM,MAAM,GAAG,MAAM,mBAAQ,CAAC,GAAG,CAU/B,OAAO,EACP,wBAAwB,EACxB,wqDAAwqD,EACxqD;QACE,OAAO;QACP,UAAU,EAAE,CAAC;QACb,YAAY,EAAE,CAAC;QACf,oBAAoB,EAAE,oBAAoB,CAAC,OAAO,EAAE;QACpD,gBAAgB,EAAE,CAAC;KACpB,CACF,CAAA;IACD,OAAO;QACL,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW;QACpC,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,kBAAkB;aAC1C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC;aACjC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;aAClC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;QACrC,iBAAiB,EAAE,MAAM,CAAC,IAAI,CAAC,iBAAiB;KACjD,CAAA;AACH,CAAC,CAAA;AAxCY,QAAA,oBAAoB,wBAwChC;AAEM,KAAK,UAAU,SAAS,CAC7B,YAA0B,EAC1B,OAAkB,EAClB,cAA+B,EAC/B,IAAmB,EACnB,WAAoB,EACpB,MAAe;IAEf,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;IACvC,CAAC;IACD,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,GAAG,CACP,MAAM,IAAA,oBAAW,EAAC,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,CAAC,CACtE,CAAC,MAAM,EAAE,CAAA;IACZ,CAAC;IACD,MAAM,OAAO,GAAG,IAAA,oBAAS,EACvB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EACzB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EACzB,IAAI,CACL,CAAA;IACD,MAAM,CACJ,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,EAChE,WAAW,EACX,CAAC,eAAe,EAAE,eAAe,CAAC,EAClC,MAAM,EACP,GAAG,MAAM,YAAY,CAAC,SAAS,CAAC;QAC/B,YAAY,EAAE,KAAK;QACnB,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;gBAChD,GAAG,EAAE,+BAAc;gBACnB,YAAY,EAAE,SAAS;gBACvB,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB;YACD;gBACE,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;gBAChD,GAAG,EAAE,+BAAc;gBACnB,YAAY,EAAE,aAAa;gBAC3B,IAAI,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;aACxB;YACD;gBACE,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;gBAChD,GAAG,EAAE,+BAAc;gBACnB,YAAY,EAAE,cAAc;gBAC5B,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB;YACD;gBACE,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,QAAQ;gBAC9C,GAAG,EAAE,2BAAY;gBACjB,YAAY,EAAE,UAAU;gBACxB,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB;SACF;KACF,CAAC,CAAA;IACF,MAAM,UAAU,GACd,eAAe,CAAC,OAAO;QACvB,eAAe,CAAC,UAAU;QAC1B,eAAe,CAAC,SAAS,CAAA;IAC3B,MAAM,UAAU,GACd,eAAe,CAAC,OAAO;QACvB,eAAe,CAAC,UAAU;QAC1B,eAAe,CAAC,SAAS,CAAA;IAC3B,OAAO,IAAI,WAAI,CAAC;QACd,OAAO;QACP,MAAM;QACN,QAAQ,EAAE,OAAO,GAAG,CAAC,IAAI,OAAO,GAAG,CAAC;QACpC,OAAO;QACP,OAAO;QACP,OAAO;QACP,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;QAChC,QAAQ,EAAE,EAAE;QACZ,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC;QAC9B,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC;QAC9B,WAAW,EAAE,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC;QAC/C,WAAW,EAAE,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC;QAC/C,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC;QAC7C,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC;QAC7C,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC;QAC1B,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC;QAC1B,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,EAAU,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACtD,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,EAAU,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACtD,MAAM;KACP,CAAC,CAAA;AACJ,CAAC;AApFD,8BAoFC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fetchLastAmounts = exports.fetchStrategyPosition = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const addresses_1 = require("../constants/addresses");
|
|
6
|
+
const strategy_abi_1 = require("../abis/rebalancer/strategy-abi");
|
|
7
|
+
const pool_key_1 = require("../utils/pool-key");
|
|
8
|
+
const pool_1 = require("./pool");
|
|
9
|
+
async function fetchStrategyPosition(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
10
|
+
let poolKey = undefined;
|
|
11
|
+
if (market) {
|
|
12
|
+
poolKey = (0, pool_key_1.toPoolKey)(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const pool = await (0, pool_1.fetchPool)(publicClient, chainId, tokenAddresses, salt, useSubgraph);
|
|
16
|
+
poolKey = pool.key;
|
|
17
|
+
}
|
|
18
|
+
const getPriceResult = await publicClient.readContract({
|
|
19
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Strategy,
|
|
20
|
+
abi: strategy_abi_1.STRATEGY_ABI,
|
|
21
|
+
functionName: 'getPosition',
|
|
22
|
+
args: [poolKey],
|
|
23
|
+
});
|
|
24
|
+
return {
|
|
25
|
+
oraclePrice: BigInt(getPriceResult.oraclePrice),
|
|
26
|
+
rate: (0, viem_1.formatUnits)(BigInt(getPriceResult.rate), 6),
|
|
27
|
+
bidTick: BigInt(getPriceResult.tickA),
|
|
28
|
+
askTick: BigInt(getPriceResult.tickB),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
exports.fetchStrategyPosition = fetchStrategyPosition;
|
|
32
|
+
async function fetchLastAmounts(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
33
|
+
let poolKey = undefined;
|
|
34
|
+
if (market) {
|
|
35
|
+
poolKey = (0, pool_key_1.toPoolKey)(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
const pool = await (0, pool_1.fetchPool)(publicClient, chainId, tokenAddresses, salt, useSubgraph);
|
|
39
|
+
poolKey = pool.key;
|
|
40
|
+
}
|
|
41
|
+
const getLastAmount = await publicClient.readContract({
|
|
42
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].Strategy,
|
|
43
|
+
abi: strategy_abi_1.STRATEGY_ABI,
|
|
44
|
+
functionName: 'getLastAmount',
|
|
45
|
+
args: [poolKey],
|
|
46
|
+
});
|
|
47
|
+
return {
|
|
48
|
+
lastAmountA: BigInt(getLastAmount[0]),
|
|
49
|
+
lastAmountB: BigInt(getLastAmount[1]),
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
exports.fetchLastAmounts = fetchLastAmounts;
|
|
53
|
+
//# sourceMappingURL=strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.js","sourceRoot":"","sources":["../../../src/apis/strategy.ts"],"names":[],"mappings":";;;AAAA,+BAAgD;AAGhD,sDAA2D;AAE3D,kEAA8D;AAC9D,gDAA6C;AAE7C,iCAAkC;AAE3B,KAAK,UAAU,qBAAqB,CACzC,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,IAAA,oBAAS,EACjB,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,IAAA,gBAAS,EAC1B,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,8BAAkB,CAAC,OAAO,CAAE,CAAC,QAAQ;QAC9C,GAAG,EAAE,2BAAY;QACjB,YAAY,EAAE,aAAa;QAC3B,IAAI,EAAE,CAAC,OAAO,CAAC;KAChB,CAAC,CAAA;IACF,OAAO;QACL,WAAW,EAAE,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC;QAC/C,IAAI,EAAE,IAAA,kBAAW,EAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjD,OAAO,EAAE,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;QACrC,OAAO,EAAE,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;KACtC,CAAA;AACH,CAAC;AArCD,sDAqCC;AAEM,KAAK,UAAU,gBAAgB,CACpC,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,IAAA,oBAAS,EACjB,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,IAAA,gBAAS,EAC1B,YAAY,EACZ,OAAO,EACP,cAAc,EACd,IAAI,EACJ,WAAW,CACZ,CAAA;QACD,OAAO,GAAG,IAAI,CAAC,GAAG,CAAA;IACpB,CAAC;IACD,MAAM,aAAa,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC;QACpD,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,QAAQ;QAC9C,GAAG,EAAE,2BAAY;QACjB,YAAY,EAAE,eAAe;QAC7B,IAAI,EAAE,CAAC,OAAO,CAAC;KAChB,CAAC,CAAA;IACF,OAAO;QACL,WAAW,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACrC,WAAW,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;KACtC,CAAA;AACH,CAAC;AAnCD,4CAmCC"}
|
package/dist/cjs/approval.js
CHANGED
|
@@ -1,35 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.setApprovalOfOpenOrdersForAll = void 0;
|
|
3
|
+
exports.approveERC20 = exports.setApprovalOfOpenOrdersForAll = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
4
5
|
const chain_1 = require("./constants/chain");
|
|
5
6
|
const addresses_1 = require("./constants/addresses");
|
|
6
7
|
const approval_1 = require("./utils/approval");
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
inputs: [
|
|
11
|
-
{
|
|
12
|
-
internalType: 'address',
|
|
13
|
-
name: 'operator',
|
|
14
|
-
type: 'address',
|
|
15
|
-
},
|
|
16
|
-
{
|
|
17
|
-
internalType: 'bool',
|
|
18
|
-
name: 'approved',
|
|
19
|
-
type: 'bool',
|
|
20
|
-
},
|
|
21
|
-
],
|
|
22
|
-
name: 'setApprovalForAll',
|
|
23
|
-
outputs: [],
|
|
24
|
-
stateMutability: 'nonpayable',
|
|
25
|
-
type: 'function',
|
|
26
|
-
},
|
|
27
|
-
];
|
|
28
|
-
exports.setApprovalOfOpenOrdersForAll = (0, decorator_1.decorator)(async ({ chainId, walletClient, }) => {
|
|
8
|
+
const allowance_1 = require("./utils/allowance");
|
|
9
|
+
const currency_1 = require("./utils/currency");
|
|
10
|
+
const setApprovalOfOpenOrdersForAll = async ({ chainId, walletClient, options, }) => {
|
|
29
11
|
if (!walletClient.account) {
|
|
30
12
|
throw new Error('Account is not found');
|
|
31
13
|
}
|
|
32
|
-
const
|
|
14
|
+
const publicClient = (0, viem_1.createPublicClient)({
|
|
15
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
16
|
+
transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
|
|
17
|
+
});
|
|
18
|
+
const isApprovedForAll = await (0, approval_1.fetchIsApprovedForAll)(publicClient, chainId, walletClient.account.address);
|
|
33
19
|
if (isApprovedForAll) {
|
|
34
20
|
return undefined;
|
|
35
21
|
}
|
|
@@ -37,9 +23,80 @@ exports.setApprovalOfOpenOrdersForAll = (0, decorator_1.decorator)(async ({ chai
|
|
|
37
23
|
account: walletClient.account,
|
|
38
24
|
chain: chain_1.CHAIN_MAP[chainId],
|
|
39
25
|
address: addresses_1.CONTRACT_ADDRESSES[chainId].BookManager,
|
|
40
|
-
abi:
|
|
26
|
+
abi: [
|
|
27
|
+
{
|
|
28
|
+
inputs: [
|
|
29
|
+
{
|
|
30
|
+
internalType: 'address',
|
|
31
|
+
name: 'operator',
|
|
32
|
+
type: 'address',
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
internalType: 'bool',
|
|
36
|
+
name: 'approved',
|
|
37
|
+
type: 'bool',
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
name: 'setApprovalForAll',
|
|
41
|
+
outputs: [],
|
|
42
|
+
stateMutability: 'nonpayable',
|
|
43
|
+
type: 'function',
|
|
44
|
+
},
|
|
45
|
+
],
|
|
41
46
|
functionName: 'setApprovalForAll',
|
|
42
47
|
args: [addresses_1.CONTRACT_ADDRESSES[chainId].Controller, true],
|
|
43
48
|
});
|
|
44
|
-
}
|
|
49
|
+
};
|
|
50
|
+
exports.setApprovalOfOpenOrdersForAll = setApprovalOfOpenOrdersForAll;
|
|
51
|
+
const approveERC20 = async ({ chainId, walletClient, token, amount, options, }) => {
|
|
52
|
+
if (!walletClient.account) {
|
|
53
|
+
throw new Error('Account is not found');
|
|
54
|
+
}
|
|
55
|
+
const publicClient = (0, viem_1.createPublicClient)({
|
|
56
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
57
|
+
transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
|
|
58
|
+
});
|
|
59
|
+
const [currency, allowance] = await Promise.all([
|
|
60
|
+
(0, currency_1.fetchCurrency)(publicClient, chainId, token),
|
|
61
|
+
(0, allowance_1.fetchAllowance)(publicClient, token, walletClient.account.address, addresses_1.CONTRACT_ADDRESSES[chainId].Controller),
|
|
62
|
+
]);
|
|
63
|
+
const value = amount ? (0, viem_1.parseUnits)(amount, currency.decimals) : 2n ** 256n - 1n;
|
|
64
|
+
if (allowance >= value) {
|
|
65
|
+
return undefined;
|
|
66
|
+
}
|
|
67
|
+
return walletClient.writeContract({
|
|
68
|
+
account: walletClient.account,
|
|
69
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
70
|
+
address: token,
|
|
71
|
+
abi: [
|
|
72
|
+
{
|
|
73
|
+
inputs: [
|
|
74
|
+
{
|
|
75
|
+
internalType: 'address',
|
|
76
|
+
name: 'spender',
|
|
77
|
+
type: 'address',
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
internalType: 'uint256',
|
|
81
|
+
name: 'value',
|
|
82
|
+
type: 'uint256',
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
name: 'approve',
|
|
86
|
+
outputs: [
|
|
87
|
+
{
|
|
88
|
+
internalType: 'bool',
|
|
89
|
+
name: '',
|
|
90
|
+
type: 'bool',
|
|
91
|
+
},
|
|
92
|
+
],
|
|
93
|
+
stateMutability: 'nonpayable',
|
|
94
|
+
type: 'function',
|
|
95
|
+
},
|
|
96
|
+
],
|
|
97
|
+
functionName: 'approve',
|
|
98
|
+
args: [addresses_1.CONTRACT_ADDRESSES[chainId].Controller, value],
|
|
99
|
+
});
|
|
100
|
+
};
|
|
101
|
+
exports.approveERC20 = approveERC20;
|
|
45
102
|
//# sourceMappingURL=approval.js.map
|
package/dist/cjs/approval.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"approval.js","sourceRoot":"","sources":["../../src/approval.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"approval.js","sourceRoot":"","sources":["../../src/approval.ts"],"names":[],"mappings":"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"}
|