@clober/v2-sdk 0.0.10 → 0.0.11-1.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 +1 -6
- package/dist/cjs/abis/core/controller-abi.js.map +1 -1
- package/dist/cjs/abis/governance/election-governor-abi.js +838 -0
- package/dist/cjs/abis/governance/election-governor-abi.js.map +1 -0
- package/dist/cjs/abis/governance/keepers-registry-abi.js +546 -0
- package/dist/cjs/abis/governance/keepers-registry-abi.js.map +1 -0
- package/dist/cjs/abis/governance/vclob-abi.js +743 -0
- package/dist/cjs/abis/governance/vclob-abi.js.map +1 -0
- 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 +76 -39
- package/dist/cjs/apis/open-order.js.map +1 -1
- package/dist/cjs/apis/pool.js +96 -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/apis/vclob.js +47 -0
- package/dist/cjs/apis/vclob.js.map +1 -0
- package/dist/cjs/approval.js +83 -26
- package/dist/cjs/approval.js.map +1 -1
- package/dist/cjs/call.js +787 -125
- package/dist/cjs/call.js.map +1 -1
- package/dist/cjs/constants/addresses.js +104 -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 +29 -2
- package/dist/cjs/constants/chain.js.map +1 -1
- package/dist/cjs/constants/currency.js +99 -3
- package/dist/cjs/constants/currency.js.map +1 -1
- package/dist/cjs/constants/fee.js +23 -2
- package/dist/cjs/constants/fee.js.map +1 -1
- package/dist/cjs/constants/mitosis-testnet-chain.js +30 -0
- package/dist/cjs/constants/mitosis-testnet-chain.js.map +1 -0
- package/dist/cjs/constants/monad-testnet-chain.js +40 -0
- package/dist/cjs/constants/monad-testnet-chain.js.map +1 -0
- 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/sonic-mainnet-chain.js +30 -0
- package/dist/cjs/constants/sonic-mainnet-chain.js.map +1 -0
- package/dist/cjs/constants/subgraph.js +38 -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 +240 -0
- package/dist/cjs/model/pool.js.map +1 -0
- package/dist/cjs/model/vclob.js +3 -0
- package/dist/cjs/model/vclob.js.map +1 -0
- package/dist/cjs/type.js +8 -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 +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 +68 -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/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 +48 -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 +459 -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/governance/election-governor-abi.js +835 -0
- package/dist/esm/abis/governance/election-governor-abi.js.map +1 -0
- package/dist/esm/abis/governance/keepers-registry-abi.js +543 -0
- package/dist/esm/abis/governance/keepers-registry-abi.js.map +1 -0
- package/dist/esm/abis/governance/vclob-abi.js +740 -0
- package/dist/esm/abis/governance/vclob-abi.js.map +1 -0
- 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 -40
- package/dist/esm/apis/open-order.js.map +1 -1
- package/dist/esm/apis/pool.js +91 -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/apis/vclob.js +43 -0
- package/dist/esm/apis/vclob.js.map +1 -0
- package/dist/esm/approval.js +107 -25
- package/dist/esm/approval.js.map +1 -1
- package/dist/esm/call.js +818 -166
- package/dist/esm/call.js.map +1 -1
- package/dist/esm/constants/addresses.js +105 -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 +28 -2
- package/dist/esm/constants/chain.js.map +1 -1
- package/dist/esm/constants/currency.js +100 -2
- package/dist/esm/constants/currency.js.map +1 -1
- package/dist/esm/constants/fee.js +23 -2
- package/dist/esm/constants/fee.js.map +1 -1
- package/dist/esm/constants/mitosis-testnet-chain.js +27 -0
- package/dist/esm/constants/mitosis-testnet-chain.js.map +1 -0
- package/dist/esm/constants/monad-testnet-chain.js +37 -0
- package/dist/esm/constants/monad-testnet-chain.js.map +1 -0
- 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/sonic-mainnet-chain.js +27 -0
- package/dist/esm/constants/sonic-mainnet-chain.js.map +1 -0
- package/dist/esm/constants/subgraph.js +34 -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 +237 -0
- package/dist/esm/model/pool.js.map +1 -0
- package/dist/esm/model/vclob.js +2 -0
- package/dist/esm/model/vclob.js.map +1 -0
- package/dist/esm/type.js +7 -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 +67 -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/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 +44 -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 +516 -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/governance/election-governor-abi.d.ts +648 -0
- package/dist/types/abis/governance/election-governor-abi.d.ts.map +1 -0
- package/dist/types/abis/governance/keepers-registry-abi.d.ts +417 -0
- package/dist/types/abis/governance/keepers-registry-abi.d.ts.map +1 -0
- package/dist/types/abis/governance/vclob-abi.d.ts +568 -0
- package/dist/types/abis/governance/vclob-abi.d.ts.map +1 -0
- 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 +4 -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/apis/vclob.d.ts +5 -0
- package/dist/types/apis/vclob.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 +275 -59
- package/dist/types/call.d.ts.map +1 -1
- package/dist/types/constants/addresses.d.ts +7 -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 +10 -2
- package/dist/types/constants/chain.d.ts.map +1 -1
- package/dist/types/constants/currency.d.ts +9 -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/mitosis-testnet-chain.d.ts +33 -0
- package/dist/types/constants/mitosis-testnet-chain.d.ts.map +1 -0
- package/dist/types/constants/monad-testnet-chain.d.ts +37 -0
- package/dist/types/constants/monad-testnet-chain.d.ts.map +1 -0
- 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/sonic-mainnet-chain.d.ts +33 -0
- package/dist/types/constants/sonic-mainnet-chain.d.ts.map +1 -0
- 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/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 +77 -0
- package/dist/types/model/pool.d.ts.map +1 -0
- package/dist/types/model/vclob.d.ts +7 -0
- package/dist/types/model/vclob.d.ts.map +1 -0
- package/dist/types/type.d.ts +141 -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/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 +5 -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 +247 -30
- 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 -146
- 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 -170
- 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,91 @@
|
|
|
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 { STRATEGY_ABI } from '../abis/rebalancer/strategy-abi';
|
|
7
|
+
import { fetchMarket } from './market';
|
|
8
|
+
export const fetchPoolPerformance = async (chainId, poolKey, volumeFromTimestamp, snapshotFromTimestamp, snapshotIntervalType, spreadProfitFromTimestamp) => {
|
|
9
|
+
const result = await 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: "5m", 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 } }', {
|
|
10
|
+
poolKey,
|
|
11
|
+
volumeFrom: volumeFromTimestamp,
|
|
12
|
+
snapshotFrom: snapshotFromTimestamp,
|
|
13
|
+
snapshotIntervalType: snapshotIntervalType.valueOf(),
|
|
14
|
+
spreadProfitFrom: spreadProfitFromTimestamp,
|
|
15
|
+
});
|
|
16
|
+
return {
|
|
17
|
+
poolVolumes: result.data.poolVolumes,
|
|
18
|
+
poolSnapshots: result.data.poolSnapshotBefore
|
|
19
|
+
.concat(result.data.poolSnapshots)
|
|
20
|
+
.concat(result.data.poolSnapshots2)
|
|
21
|
+
.concat(result.data.poolSnapshots3),
|
|
22
|
+
poolSpreadProfits: result.data.poolSpreadProfits,
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export async function fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
26
|
+
if (tokenAddresses.length !== 2) {
|
|
27
|
+
throw new Error('Invalid token pair');
|
|
28
|
+
}
|
|
29
|
+
if (!market) {
|
|
30
|
+
market = (await fetchMarket(publicClient, chainId, tokenAddresses, useSubgraph)).toJson();
|
|
31
|
+
}
|
|
32
|
+
const poolKey = toPoolKey(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
33
|
+
const [{ bookIdA, bookIdB, reserveA, reserveB, orderListA, orderListB }, totalSupply, [totalLiquidityA, totalLiquidityB], paused,] = await publicClient.multicall({
|
|
34
|
+
allowFailure: false,
|
|
35
|
+
contracts: [
|
|
36
|
+
{
|
|
37
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
38
|
+
abi: REBALANCER_ABI,
|
|
39
|
+
functionName: 'getPool',
|
|
40
|
+
args: [poolKey],
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
44
|
+
abi: REBALANCER_ABI,
|
|
45
|
+
functionName: 'totalSupply',
|
|
46
|
+
args: [BigInt(poolKey)],
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
address: CONTRACT_ADDRESSES[chainId].Rebalancer,
|
|
50
|
+
abi: REBALANCER_ABI,
|
|
51
|
+
functionName: 'getLiquidity',
|
|
52
|
+
args: [poolKey],
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
address: CONTRACT_ADDRESSES[chainId].Strategy,
|
|
56
|
+
abi: STRATEGY_ABI,
|
|
57
|
+
functionName: 'isPaused',
|
|
58
|
+
args: [poolKey],
|
|
59
|
+
},
|
|
60
|
+
],
|
|
61
|
+
});
|
|
62
|
+
const liquidityA = totalLiquidityA.reserve +
|
|
63
|
+
totalLiquidityA.cancelable +
|
|
64
|
+
totalLiquidityA.claimable;
|
|
65
|
+
const liquidityB = totalLiquidityB.reserve +
|
|
66
|
+
totalLiquidityB.cancelable +
|
|
67
|
+
totalLiquidityB.claimable;
|
|
68
|
+
return new Pool({
|
|
69
|
+
chainId,
|
|
70
|
+
market,
|
|
71
|
+
isOpened: bookIdA > 0 && bookIdB > 0,
|
|
72
|
+
bookIdA,
|
|
73
|
+
bookIdB,
|
|
74
|
+
salt,
|
|
75
|
+
poolKey,
|
|
76
|
+
totalSupply: BigInt(totalSupply),
|
|
77
|
+
decimals: 18,
|
|
78
|
+
liquidityA: BigInt(liquidityA),
|
|
79
|
+
liquidityB: BigInt(liquidityB),
|
|
80
|
+
cancelableA: BigInt(totalLiquidityA.cancelable),
|
|
81
|
+
cancelableB: BigInt(totalLiquidityB.cancelable),
|
|
82
|
+
claimableA: BigInt(totalLiquidityA.claimable),
|
|
83
|
+
claimableB: BigInt(totalLiquidityB.claimable),
|
|
84
|
+
reserveA: BigInt(reserveA),
|
|
85
|
+
reserveB: BigInt(reserveB),
|
|
86
|
+
orderListA: orderListA.map((id) => BigInt(id)),
|
|
87
|
+
orderListB: orderListB.map((id) => BigInt(id)),
|
|
88
|
+
paused,
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
//# 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,48 @@
|
|
|
1
|
+
import { formatUnits } from 'viem';
|
|
2
|
+
import { CONTRACT_ADDRESSES } from '../constants/addresses';
|
|
3
|
+
import { STRATEGY_ABI } from '../abis/rebalancer/strategy-abi';
|
|
4
|
+
import { toPoolKey } from '../utils/pool-key';
|
|
5
|
+
import { fetchPool } from './pool';
|
|
6
|
+
export async function fetchStrategyPosition(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
7
|
+
let poolKey = undefined;
|
|
8
|
+
if (market) {
|
|
9
|
+
poolKey = toPoolKey(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
const pool = await fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph);
|
|
13
|
+
poolKey = pool.key;
|
|
14
|
+
}
|
|
15
|
+
const getPriceResult = await publicClient.readContract({
|
|
16
|
+
address: CONTRACT_ADDRESSES[chainId].Strategy,
|
|
17
|
+
abi: STRATEGY_ABI,
|
|
18
|
+
functionName: 'getPosition',
|
|
19
|
+
args: [poolKey],
|
|
20
|
+
});
|
|
21
|
+
return {
|
|
22
|
+
oraclePrice: BigInt(getPriceResult.oraclePrice),
|
|
23
|
+
rate: formatUnits(BigInt(getPriceResult.rate), 6),
|
|
24
|
+
bidTick: BigInt(getPriceResult.tickA),
|
|
25
|
+
askTick: BigInt(getPriceResult.tickB),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
export async function fetchLastAmounts(publicClient, chainId, tokenAddresses, salt, useSubgraph, market) {
|
|
29
|
+
let poolKey = undefined;
|
|
30
|
+
if (market) {
|
|
31
|
+
poolKey = toPoolKey(BigInt(market.bidBook.id), BigInt(market.askBook.id), salt);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
const pool = await fetchPool(publicClient, chainId, tokenAddresses, salt, useSubgraph);
|
|
35
|
+
poolKey = pool.key;
|
|
36
|
+
}
|
|
37
|
+
const getLastAmount = await publicClient.readContract({
|
|
38
|
+
address: CONTRACT_ADDRESSES[chainId].Strategy,
|
|
39
|
+
abi: STRATEGY_ABI,
|
|
40
|
+
functionName: 'getLastAmount',
|
|
41
|
+
args: [poolKey],
|
|
42
|
+
});
|
|
43
|
+
return {
|
|
44
|
+
lastAmountA: BigInt(getLastAmount[0]),
|
|
45
|
+
lastAmountB: BigInt(getLastAmount[1]),
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.js","sourceRoot":"","sources":["../../../src/apis/strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAgB,MAAM,MAAM,CAAA;AAGhD,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,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,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,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,WAAW,CAAC,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;AAED,MAAM,CAAC,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,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,aAAa,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC;QACpD,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,QAAQ;QAC9C,GAAG,EAAE,YAAY;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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Subgraph } from '../constants/subgraph';
|
|
2
|
+
import { CONTRACT_ADDRESSES } from '../constants/addresses';
|
|
3
|
+
import { VCLOB_ABI } from '../abis/governance/vclob-abi';
|
|
4
|
+
const fetchVCLOBListFromSubgraph = async (chainId, userAddress) => {
|
|
5
|
+
const result = await Subgraph.get(chainId, 'getVCLOBList', 'query getVCLOBList($owner: String!) { vclobs( where: { owner: $owner } ) { id owner amount lockedTimepoint } }', {
|
|
6
|
+
owner: userAddress,
|
|
7
|
+
});
|
|
8
|
+
return result.data.vclobs;
|
|
9
|
+
};
|
|
10
|
+
export const fetchVCLOBList = async (publicClient, chainId, userAddress, useSubgraph) => {
|
|
11
|
+
if (!useSubgraph) {
|
|
12
|
+
return [];
|
|
13
|
+
}
|
|
14
|
+
const [depositDuration, withdrawDuration] = await publicClient.multicall({
|
|
15
|
+
contracts: [
|
|
16
|
+
{
|
|
17
|
+
address: CONTRACT_ADDRESSES[chainId].VoteLockedCloberToken,
|
|
18
|
+
abi: VCLOB_ABI,
|
|
19
|
+
functionName: 'depositDuration',
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
address: CONTRACT_ADDRESSES[chainId].VoteLockedCloberToken,
|
|
23
|
+
abi: VCLOB_ABI,
|
|
24
|
+
functionName: 'withdrawDuration',
|
|
25
|
+
},
|
|
26
|
+
],
|
|
27
|
+
allowFailure: false,
|
|
28
|
+
});
|
|
29
|
+
const currentTimepoint = BigInt(Math.floor(Date.now() / 1000));
|
|
30
|
+
const vclobs = await fetchVCLOBListFromSubgraph(chainId, userAddress);
|
|
31
|
+
return vclobs.map((vclob) => {
|
|
32
|
+
const phaseDuration = depositDuration + withdrawDuration;
|
|
33
|
+
const phase = (currentTimepoint - vclob.lockedTimepoint) / phaseDuration;
|
|
34
|
+
const withdrawalStartTimepoint = vclob.lockedTimepoint + phase * phaseDuration + depositDuration;
|
|
35
|
+
const withdrawalEndTimepoint = withdrawalStartTimepoint + withdrawDuration;
|
|
36
|
+
return {
|
|
37
|
+
...vclob,
|
|
38
|
+
withdrawalStartTimepoint,
|
|
39
|
+
withdrawalEndTimepoint,
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=vclob.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vclob.js","sourceRoot":"","sources":["../../../src/apis/vclob.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAEhD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAA;AAGxD,MAAM,0BAA0B,GAAG,KAAK,EACtC,OAAkB,EAClB,WAA0B,EAC1B,EAAE;IACF,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,GAAG,CAK/B,OAAO,EACP,cAAc,EACd,gHAAgH,EAChH;QACE,KAAK,EAAE,WAAW;KACnB,CACF,CAAA;IACD,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAA;AAC3B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EACjC,YAA0B,EAC1B,OAAkB,EAClB,WAA0B,EAC1B,WAAoB,EACF,EAAE;IACpB,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,OAAO,EAAE,CAAA;IACX,CAAC;IACD,MAAM,CAAC,eAAe,EAAE,gBAAgB,CAAC,GAAG,MAAM,YAAY,CAAC,SAAS,CAAC;QACvE,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,qBAAqB;gBAC3D,GAAG,EAAE,SAAS;gBACd,YAAY,EAAE,iBAAiB;aAChC;YACD;gBACE,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,qBAAqB;gBAC3D,GAAG,EAAE,SAAS;gBACd,YAAY,EAAE,kBAAkB;aACjC;SACF;QACD,YAAY,EAAE,KAAK;KACpB,CAAC,CAAA;IACF,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,CAAA;IAC9D,MAAM,MAAM,GAAG,MAAM,0BAA0B,CAAC,OAAO,EAAE,WAAW,CAAC,CAAA;IACrE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1B,MAAM,aAAa,GAAG,eAAe,GAAG,gBAAgB,CAAA;QACxD,MAAM,KAAK,GAAG,CAAC,gBAAgB,GAAG,KAAK,CAAC,eAAe,CAAC,GAAG,aAAa,CAAA;QACxE,MAAM,wBAAwB,GAC5B,KAAK,CAAC,eAAe,GAAG,KAAK,GAAG,aAAa,GAAG,eAAe,CAAA;QACjE,MAAM,sBAAsB,GAAG,wBAAwB,GAAG,gBAAgB,CAAA;QAC1E,OAAO;YACL,GAAG,KAAK;YACR,wBAAwB;YACxB,sBAAsB;SACvB,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
package/dist/esm/approval.js
CHANGED
|
@@ -1,27 +1,9 @@
|
|
|
1
|
+
import { createPublicClient, http, parseUnits } from 'viem';
|
|
1
2
|
import { CHAIN_MAP } from './constants/chain';
|
|
2
3
|
import { CONTRACT_ADDRESSES } from './constants/addresses';
|
|
3
4
|
import { fetchIsApprovedForAll } from './utils/approval';
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
{
|
|
7
|
-
inputs: [
|
|
8
|
-
{
|
|
9
|
-
internalType: 'address',
|
|
10
|
-
name: 'operator',
|
|
11
|
-
type: 'address',
|
|
12
|
-
},
|
|
13
|
-
{
|
|
14
|
-
internalType: 'bool',
|
|
15
|
-
name: 'approved',
|
|
16
|
-
type: 'bool',
|
|
17
|
-
},
|
|
18
|
-
],
|
|
19
|
-
name: 'setApprovalForAll',
|
|
20
|
-
outputs: [],
|
|
21
|
-
stateMutability: 'nonpayable',
|
|
22
|
-
type: 'function',
|
|
23
|
-
},
|
|
24
|
-
];
|
|
5
|
+
import { fetchAllowance } from './utils/allowance';
|
|
6
|
+
import { fetchCurrency } from './utils/currency';
|
|
25
7
|
/**
|
|
26
8
|
* @dev This function relates with `viem` dependency
|
|
27
9
|
* Sets approval of all open orders for the specified account on the given chain.
|
|
@@ -46,11 +28,15 @@ const _abi = [
|
|
|
46
28
|
* walletClient
|
|
47
29
|
* })
|
|
48
30
|
*/
|
|
49
|
-
export const setApprovalOfOpenOrdersForAll =
|
|
31
|
+
export const setApprovalOfOpenOrdersForAll = async ({ chainId, walletClient, options, }) => {
|
|
50
32
|
if (!walletClient.account) {
|
|
51
33
|
throw new Error('Account is not found');
|
|
52
34
|
}
|
|
53
|
-
const
|
|
35
|
+
const publicClient = createPublicClient({
|
|
36
|
+
chain: CHAIN_MAP[chainId],
|
|
37
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
38
|
+
});
|
|
39
|
+
const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, walletClient.account.address);
|
|
54
40
|
if (isApprovedForAll) {
|
|
55
41
|
return undefined;
|
|
56
42
|
}
|
|
@@ -58,9 +44,105 @@ export const setApprovalOfOpenOrdersForAll = decorator(async ({ chainId, walletC
|
|
|
58
44
|
account: walletClient.account,
|
|
59
45
|
chain: CHAIN_MAP[chainId],
|
|
60
46
|
address: CONTRACT_ADDRESSES[chainId].BookManager,
|
|
61
|
-
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
|
+
],
|
|
62
67
|
functionName: 'setApprovalForAll',
|
|
63
68
|
args: [CONTRACT_ADDRESSES[chainId].Controller, true],
|
|
64
69
|
});
|
|
65
|
-
}
|
|
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
|
+
};
|
|
66
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":"
|
|
1
|
+
{"version":3,"file":"approval.js","sourceRoot":"","sources":["../../src/approval.ts"],"names":[],"mappings":"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"}
|