@clober/v2-sdk 0.0.127 → 1.0.0-beta.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/dist/cjs/calls/approval/open-order.js +49 -0
- package/dist/cjs/calls/approval/open-order.js.map +1 -0
- package/dist/cjs/calls/approval/token.js +60 -0
- package/dist/cjs/calls/approval/token.js.map +1 -0
- package/dist/cjs/calls/index.js +39 -0
- package/dist/cjs/calls/index.js.map +1 -0
- package/dist/cjs/calls/market/cancel.js +80 -0
- package/dist/cjs/calls/market/cancel.js.map +1 -0
- package/dist/cjs/calls/market/claim.js +79 -0
- package/dist/cjs/calls/market/claim.js.map +1 -0
- package/dist/cjs/calls/market/limit.js +182 -0
- package/dist/cjs/calls/market/limit.js.map +1 -0
- package/dist/cjs/calls/market/make.js +160 -0
- package/dist/cjs/calls/market/make.js.map +1 -0
- package/dist/cjs/calls/market/market.js +170 -0
- package/dist/cjs/calls/market/market.js.map +1 -0
- package/dist/cjs/calls/market/open.js +50 -0
- package/dist/cjs/calls/market/open.js.map +1 -0
- package/dist/cjs/calls/pool/burn.js +88 -0
- package/dist/cjs/calls/pool/burn.js.map +1 -0
- package/dist/cjs/calls/pool/market-making/adjust.js +69 -0
- package/dist/cjs/calls/pool/market-making/adjust.js.map +1 -0
- package/dist/cjs/calls/pool/market-making/pause.js +44 -0
- package/dist/cjs/calls/pool/market-making/pause.js.map +1 -0
- package/dist/cjs/calls/pool/market-making/refill.js +41 -0
- package/dist/cjs/calls/pool/market-making/refill.js.map +1 -0
- package/dist/cjs/calls/pool/market-making/resume.js +44 -0
- package/dist/cjs/calls/pool/market-making/resume.js.map +1 -0
- package/dist/cjs/calls/pool/mint.js +253 -0
- package/dist/cjs/calls/pool/mint.js.map +1 -0
- package/dist/cjs/calls/pool/open.js +50 -0
- package/dist/cjs/calls/pool/open.js.map +1 -0
- package/dist/cjs/calls/pool/wrap.js +97 -0
- package/dist/cjs/calls/pool/wrap.js.map +1 -0
- package/dist/cjs/{abis → constants/abis}/core/book-manager-abi.js +28 -0
- package/dist/cjs/constants/abis/core/book-manager-abi.js.map +1 -0
- package/dist/cjs/constants/abis/core/book-viewer-abi.js.map +1 -0
- package/dist/cjs/{abis → constants/abis}/core/controller-abi.js +24 -1
- package/dist/cjs/constants/abis/core/controller-abi.js.map +1 -0
- package/dist/cjs/constants/abis/core/params-abi.js +77 -0
- package/dist/cjs/constants/abis/core/params-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/minter-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/mock-swap-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/cjs/constants/abis/rebalancer/wrapped-6909-factory-abi.js +107 -0
- package/dist/cjs/constants/abis/rebalancer/wrapped-6909-factory-abi.js.map +1 -0
- package/dist/cjs/constants/chain-configs/addresses.js +78 -0
- package/dist/cjs/constants/chain-configs/addresses.js.map +1 -0
- package/dist/cjs/constants/{chain.js → chain-configs/chain.js} +8 -15
- package/dist/cjs/constants/chain-configs/chain.js.map +1 -0
- package/dist/cjs/constants/chain-configs/currency.js +221 -0
- package/dist/cjs/constants/chain-configs/currency.js.map +1 -0
- package/dist/cjs/constants/chain-configs/fee.js +24 -0
- package/dist/cjs/constants/chain-configs/fee.js.map +1 -0
- package/dist/cjs/constants/{subgraph.js → chain-configs/subgraph.js} +8 -9
- package/dist/cjs/constants/chain-configs/subgraph.js.map +1 -0
- package/dist/cjs/constants/networks/giwa-sepolia.js +41 -0
- package/dist/cjs/constants/networks/giwa-sepolia.js.map +1 -0
- package/dist/cjs/constants/networks/rise-sepolia.js.map +1 -0
- package/dist/cjs/constants/networks/test-chain.js +27 -0
- package/dist/cjs/constants/networks/test-chain.js.map +1 -0
- package/dist/cjs/constants/permit.js +2 -2
- package/dist/cjs/constants/permit.js.map +1 -1
- package/dist/cjs/constants/price.js.map +1 -1
- package/dist/cjs/entities/analytics/apis/index.js +179 -0
- package/dist/cjs/entities/analytics/apis/index.js.map +1 -0
- package/dist/cjs/{model/depth.js → entities/analytics/types.js} +1 -1
- package/dist/cjs/entities/analytics/types.js.map +1 -0
- package/dist/cjs/entities/book/apis/index.js +87 -0
- package/dist/cjs/entities/book/apis/index.js.map +1 -0
- package/dist/cjs/{model/book.js → entities/book/model.js} +11 -11
- package/dist/cjs/entities/book/model.js.map +1 -0
- package/dist/cjs/{model/currency.js → entities/book/types.js} +1 -1
- package/dist/cjs/entities/book/types.js.map +1 -0
- package/dist/cjs/{utils → entities/book/utils}/book-id.js +1 -1
- package/dist/cjs/entities/book/utils/book-id.js.map +1 -0
- package/dist/cjs/entities/currency/apis/allowance.js +38 -0
- package/dist/cjs/entities/currency/apis/allowance.js.map +1 -0
- package/dist/cjs/entities/currency/apis/approval.js +39 -0
- package/dist/cjs/entities/currency/apis/approval.js.map +1 -0
- package/dist/cjs/entities/currency/apis/index.js +128 -0
- package/dist/cjs/entities/currency/apis/index.js.map +1 -0
- package/dist/cjs/entities/currency/apis/price.js +36 -0
- package/dist/cjs/entities/currency/apis/price.js.map +1 -0
- package/dist/cjs/entities/currency/apis/total-supply.js +67 -0
- package/dist/cjs/entities/currency/apis/total-supply.js.map +1 -0
- package/dist/cjs/{model/chart-log.js → entities/currency/types.js} +1 -1
- package/dist/cjs/entities/currency/types.js.map +1 -0
- package/dist/cjs/{model/fee-policy.js → entities/fee-policy/model.js} +2 -2
- package/dist/cjs/entities/fee-policy/model.js.map +1 -0
- package/dist/cjs/{apis/chart-logs.js → entities/market/apis/chart-log.js} +15 -15
- package/dist/cjs/entities/market/apis/chart-log.js.map +1 -0
- package/dist/cjs/entities/market/apis/index.js +33 -0
- package/dist/cjs/entities/market/apis/index.js.map +1 -0
- package/dist/cjs/entities/market/apis/snapshot.js +374 -0
- package/dist/cjs/entities/market/apis/snapshot.js.map +1 -0
- package/dist/cjs/{model/market.js → entities/market/model.js} +14 -16
- package/dist/cjs/entities/market/model.js.map +1 -0
- package/dist/cjs/{model/open-order.js → entities/market/types.js} +1 -1
- package/dist/cjs/entities/market/types.js.map +1 -0
- package/dist/cjs/{utils/market.js → entities/market/utils/market-id.js} +18 -8
- package/dist/cjs/entities/market/utils/market-id.js.map +1 -0
- package/dist/cjs/entities/open-order/apis/index.js +198 -0
- package/dist/cjs/entities/open-order/apis/index.js.map +1 -0
- package/dist/cjs/entities/open-order/types.js +3 -0
- package/dist/cjs/entities/open-order/types.js.map +1 -0
- package/dist/cjs/entities/open-order/utils/order-id.js +18 -0
- package/dist/cjs/entities/open-order/utils/order-id.js.map +1 -0
- package/dist/cjs/entities/pool/apis/index.js +88 -0
- package/dist/cjs/entities/pool/apis/index.js.map +1 -0
- package/dist/cjs/entities/pool/apis/snapshot.js +93 -0
- package/dist/cjs/entities/pool/apis/snapshot.js.map +1 -0
- package/dist/cjs/{apis → entities/pool/apis}/strategy.js +4 -22
- package/dist/cjs/entities/pool/apis/strategy.js.map +1 -0
- package/dist/cjs/{model/pool.js → entities/pool/model.js} +33 -12
- package/dist/cjs/entities/pool/model.js.map +1 -0
- package/dist/cjs/entities/pool/types.js +3 -0
- package/dist/cjs/entities/pool/types.js.map +1 -0
- package/dist/cjs/{utils/pool.js → entities/pool/utils/mint.js} +14 -2
- package/dist/cjs/entities/pool/utils/mint.js.map +1 -0
- package/dist/cjs/{utils → entities/pool/utils}/pool-key.js +3 -6
- package/dist/cjs/entities/pool/utils/pool-key.js.map +1 -0
- package/dist/cjs/entities/swap/apis/index.js +48 -0
- package/dist/cjs/entities/swap/apis/index.js.map +1 -0
- package/dist/cjs/entities/swap/types.js +3 -0
- package/dist/cjs/entities/swap/types.js.map +1 -0
- package/dist/cjs/index.js +11 -4
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/default-options.js +3 -0
- package/dist/cjs/types/default-options.js.map +1 -0
- package/dist/cjs/{type.js → types/index.js} +2 -2
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/permit.js +3 -0
- package/dist/cjs/types/permit.js.map +1 -0
- package/dist/cjs/types/transaction.js +3 -0
- package/dist/cjs/types/transaction.js.map +1 -0
- package/dist/cjs/utils/bigint.js +4 -1
- package/dist/cjs/utils/bigint.js.map +1 -1
- package/dist/cjs/utils/{decimals.js → conversion.js} +1 -1
- package/dist/cjs/utils/conversion.js.map +1 -0
- package/dist/cjs/{utils.js → utils/index.js} +8 -8
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/prices.js +1 -2
- package/dist/cjs/utils/prices.js.map +1 -1
- package/dist/cjs/utils/time.js +7 -2
- package/dist/cjs/utils/time.js.map +1 -1
- package/dist/cjs/utils/unit-size.js +2 -2
- package/dist/cjs/utils/unit-size.js.map +1 -1
- package/dist/cjs/views/address.js +9 -0
- package/dist/cjs/views/address.js.map +1 -0
- package/dist/cjs/views/analytics.js +21 -0
- package/dist/cjs/views/analytics.js.map +1 -0
- package/dist/cjs/views/currency.js +35 -0
- package/dist/cjs/views/currency.js.map +1 -0
- package/dist/cjs/views/index.js +46 -0
- package/dist/cjs/views/index.js.map +1 -0
- package/dist/cjs/views/market/chart-log.js +13 -0
- package/dist/cjs/views/market/chart-log.js.map +1 -0
- package/dist/cjs/views/market/index.js +32 -0
- package/dist/cjs/views/market/index.js.map +1 -0
- package/dist/cjs/views/market/parse.js +22 -0
- package/dist/cjs/views/market/parse.js.map +1 -0
- package/dist/cjs/views/market/quote.js +97 -0
- package/dist/cjs/views/market/quote.js.map +1 -0
- package/dist/cjs/views/market/snapshot.js +28 -0
- package/dist/cjs/views/market/snapshot.js.map +1 -0
- package/dist/cjs/views/market/token.js +10 -0
- package/dist/cjs/views/market/token.js.map +1 -0
- package/dist/cjs/views/open-order.js +13 -0
- package/dist/cjs/views/open-order.js.map +1 -0
- package/dist/cjs/views/pool/index.js +43 -0
- package/dist/cjs/views/pool/index.js.map +1 -0
- package/dist/cjs/views/pool/market-making.js +23 -0
- package/dist/cjs/views/pool/market-making.js.map +1 -0
- package/dist/cjs/views/pool/snapshot.js +17 -0
- package/dist/cjs/views/pool/snapshot.js.map +1 -0
- package/dist/cjs/views/subgraph.js +24 -0
- package/dist/cjs/views/subgraph.js.map +1 -0
- package/dist/cjs/views/tick.js +80 -0
- package/dist/cjs/views/tick.js.map +1 -0
- package/dist/cjs/views/trade.js +15 -0
- package/dist/cjs/views/trade.js.map +1 -0
- package/dist/esm/calls/approval/open-order.js +69 -0
- package/dist/esm/calls/approval/open-order.js.map +1 -0
- package/dist/esm/{approval.js → calls/approval/token.js} +5 -70
- package/dist/esm/calls/approval/token.js.map +1 -0
- package/dist/esm/calls/index.js +17 -0
- package/dist/esm/calls/index.js.map +1 -0
- package/dist/esm/calls/market/cancel.js +123 -0
- package/dist/esm/calls/market/cancel.js.map +1 -0
- package/dist/esm/calls/market/claim.js +122 -0
- package/dist/esm/calls/market/claim.js.map +1 -0
- package/dist/esm/calls/market/limit.js +224 -0
- package/dist/esm/calls/market/limit.js.map +1 -0
- package/dist/esm/calls/market/make.js +156 -0
- package/dist/esm/calls/market/make.js.map +1 -0
- package/dist/esm/calls/market/market.js +201 -0
- package/dist/esm/calls/market/market.js.map +1 -0
- package/dist/esm/calls/market/open.js +65 -0
- package/dist/esm/calls/market/open.js.map +1 -0
- package/dist/esm/calls/pool/burn.js +85 -0
- package/dist/esm/calls/pool/burn.js.map +1 -0
- package/dist/esm/calls/pool/market-making/adjust.js +65 -0
- package/dist/esm/calls/pool/market-making/adjust.js.map +1 -0
- package/dist/esm/calls/pool/market-making/pause.js +40 -0
- package/dist/esm/calls/pool/market-making/pause.js.map +1 -0
- package/dist/esm/calls/pool/market-making/refill.js +37 -0
- package/dist/esm/calls/pool/market-making/refill.js.map +1 -0
- package/dist/esm/calls/pool/market-making/resume.js +40 -0
- package/dist/esm/calls/pool/market-making/resume.js.map +1 -0
- package/dist/esm/calls/pool/mint.js +250 -0
- package/dist/esm/calls/pool/mint.js.map +1 -0
- package/dist/esm/calls/pool/open.js +67 -0
- package/dist/esm/calls/pool/open.js.map +1 -0
- package/dist/esm/calls/pool/wrap.js +138 -0
- package/dist/esm/calls/pool/wrap.js.map +1 -0
- package/dist/esm/{abis → constants/abis}/core/book-manager-abi.js +28 -0
- package/dist/esm/constants/abis/core/book-manager-abi.js.map +1 -0
- package/dist/esm/constants/abis/core/book-viewer-abi.js.map +1 -0
- package/dist/esm/{abis → constants/abis}/core/controller-abi.js +24 -1
- package/dist/esm/constants/abis/core/controller-abi.js.map +1 -0
- package/dist/esm/constants/abis/core/params-abi.js +74 -0
- package/dist/esm/constants/abis/core/params-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/minter-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/mock-swap-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/operator-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/rebalancer-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/strategy-abi.js.map +1 -0
- package/dist/esm/constants/abis/rebalancer/wrapped-6909-factory-abi.js +104 -0
- package/dist/esm/constants/abis/rebalancer/wrapped-6909-factory-abi.js.map +1 -0
- package/dist/esm/constants/chain-configs/addresses.js +93 -0
- package/dist/esm/constants/chain-configs/addresses.js.map +1 -0
- package/dist/esm/constants/{chain.js → chain-configs/chain.js} +12 -14
- package/dist/esm/constants/chain-configs/chain.js.map +1 -0
- package/dist/esm/constants/chain-configs/currency.js +236 -0
- package/dist/esm/constants/chain-configs/currency.js.map +1 -0
- package/dist/esm/constants/{fee.js → chain-configs/fee.js} +9 -7
- package/dist/esm/constants/chain-configs/fee.js.map +1 -0
- package/dist/esm/constants/{subgraph.js → chain-configs/subgraph.js} +12 -9
- package/dist/esm/constants/chain-configs/subgraph.js.map +1 -0
- package/dist/esm/constants/networks/giwa-sepolia.js +38 -0
- package/dist/esm/constants/networks/giwa-sepolia.js.map +1 -0
- package/dist/esm/constants/networks/rise-sepolia.js.map +1 -0
- package/dist/esm/constants/networks/test-chain.js +24 -0
- package/dist/esm/constants/networks/test-chain.js.map +1 -0
- package/dist/esm/constants/permit.js +1 -1
- package/dist/esm/constants/permit.js.map +1 -1
- package/dist/esm/constants/price.js.map +1 -1
- package/dist/esm/entities/analytics/apis/index.js +172 -0
- package/dist/esm/entities/analytics/apis/index.js.map +1 -0
- package/dist/esm/entities/analytics/types.js +2 -0
- package/dist/esm/entities/analytics/types.js.map +1 -0
- package/dist/esm/entities/book/apis/index.js +83 -0
- package/dist/esm/entities/book/apis/index.js.map +1 -0
- package/dist/esm/{model/book.js → entities/book/model.js} +6 -6
- package/dist/esm/entities/book/model.js.map +1 -0
- package/dist/esm/entities/book/types.js +2 -0
- package/dist/esm/entities/book/types.js.map +1 -0
- package/dist/esm/{utils → entities/book/utils}/book-id.js +1 -1
- package/dist/esm/entities/book/utils/book-id.js.map +1 -0
- package/dist/esm/entities/currency/apis/allowance.js +34 -0
- package/dist/esm/entities/currency/apis/allowance.js.map +1 -0
- package/dist/esm/entities/currency/apis/approval.js +35 -0
- package/dist/esm/entities/currency/apis/approval.js.map +1 -0
- package/dist/esm/entities/currency/apis/index.js +123 -0
- package/dist/esm/entities/currency/apis/index.js.map +1 -0
- package/dist/esm/entities/currency/apis/price.js +30 -0
- package/dist/esm/entities/currency/apis/price.js.map +1 -0
- package/dist/esm/entities/currency/apis/total-supply.js +62 -0
- package/dist/esm/entities/currency/apis/total-supply.js.map +1 -0
- package/dist/esm/entities/currency/types.js +2 -0
- package/dist/esm/entities/currency/types.js.map +1 -0
- package/dist/esm/{model/fee-policy.js → entities/fee-policy/model.js} +2 -2
- package/dist/esm/entities/fee-policy/model.js.map +1 -0
- package/dist/esm/{apis/chart-logs.js → entities/market/apis/chart-log.js} +3 -3
- package/dist/esm/entities/market/apis/chart-log.js.map +1 -0
- package/dist/esm/entities/market/apis/index.js +29 -0
- package/dist/esm/entities/market/apis/index.js.map +1 -0
- package/dist/esm/entities/market/apis/snapshot.js +371 -0
- package/dist/esm/entities/market/apis/snapshot.js.map +1 -0
- package/dist/esm/{model/market.js → entities/market/model.js} +5 -7
- package/dist/esm/entities/market/model.js.map +1 -0
- package/dist/esm/entities/market/types.js +2 -0
- package/dist/esm/entities/market/types.js.map +1 -0
- package/dist/esm/{utils/market.js → entities/market/utils/market-id.js} +18 -8
- package/dist/esm/entities/market/utils/market-id.js.map +1 -0
- package/dist/esm/entities/open-order/apis/index.js +195 -0
- package/dist/esm/entities/open-order/apis/index.js.map +1 -0
- package/dist/esm/entities/open-order/types.js +2 -0
- package/dist/esm/entities/open-order/types.js.map +1 -0
- package/dist/esm/entities/open-order/utils/order-id.js +13 -0
- package/dist/esm/entities/open-order/utils/order-id.js.map +1 -0
- package/dist/esm/entities/pool/apis/index.js +84 -0
- package/dist/esm/entities/pool/apis/index.js.map +1 -0
- package/dist/esm/entities/pool/apis/snapshot.js +88 -0
- package/dist/esm/entities/pool/apis/snapshot.js.map +1 -0
- package/dist/esm/entities/pool/apis/strategy.js +30 -0
- package/dist/esm/entities/pool/apis/strategy.js.map +1 -0
- package/dist/esm/{model/pool.js → entities/pool/model.js} +31 -10
- package/dist/esm/entities/pool/model.js.map +1 -0
- package/dist/esm/entities/pool/types.js +2 -0
- package/dist/esm/entities/pool/types.js.map +1 -0
- package/dist/esm/{utils/pool.js → entities/pool/utils/mint.js} +11 -1
- package/dist/esm/entities/pool/utils/mint.js.map +1 -0
- package/dist/esm/{utils → entities/pool/utils}/pool-key.js +1 -3
- package/dist/esm/entities/pool/utils/pool-key.js.map +1 -0
- package/dist/esm/entities/swap/apis/index.js +44 -0
- package/dist/esm/entities/swap/apis/index.js.map +1 -0
- package/dist/esm/entities/swap/types.js +2 -0
- package/dist/esm/entities/swap/types.js.map +1 -0
- package/dist/esm/index.js +9 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types/default-options.js +2 -0
- package/dist/esm/types/default-options.js.map +1 -0
- package/dist/esm/{type.js → types/index.js} +2 -2
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/permit.js +2 -0
- package/dist/esm/types/permit.js.map +1 -0
- package/dist/esm/types/transaction.js +2 -0
- package/dist/esm/types/transaction.js.map +1 -0
- package/dist/esm/utils/bigint.js +2 -0
- package/dist/esm/utils/bigint.js.map +1 -1
- package/dist/esm/utils/{decimals.js → conversion.js} +1 -1
- package/dist/esm/utils/conversion.js.map +1 -0
- package/dist/esm/utils/index.js +5 -0
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/esm/utils/prices.js +1 -2
- package/dist/esm/utils/prices.js.map +1 -1
- package/dist/esm/utils/time.js +4 -1
- package/dist/esm/utils/time.js.map +1 -1
- package/dist/esm/utils/unit-size.js +2 -2
- package/dist/esm/utils/unit-size.js.map +1 -1
- package/dist/esm/views/address.js +17 -0
- package/dist/esm/views/address.js.map +1 -0
- package/dist/esm/views/analytics.js +14 -0
- package/dist/esm/views/analytics.js.map +1 -0
- package/dist/esm/views/currency.js +50 -0
- package/dist/esm/views/currency.js.map +1 -0
- package/dist/esm/views/index.js +10 -0
- package/dist/esm/views/index.js.map +1 -0
- package/dist/esm/views/market/chart-log.js +48 -0
- package/dist/esm/views/market/chart-log.js.map +1 -0
- package/dist/esm/views/market/index.js +37 -0
- package/dist/esm/views/market/index.js.map +1 -0
- package/dist/esm/views/market/parse.js +18 -0
- package/dist/esm/views/market/parse.js.map +1 -0
- package/dist/esm/views/market/quote.js +137 -0
- package/dist/esm/views/market/quote.js.map +1 -0
- package/dist/esm/views/market/snapshot.js +23 -0
- package/dist/esm/views/market/snapshot.js.map +1 -0
- package/dist/esm/views/market/token.js +23 -0
- package/dist/esm/views/market/token.js.map +1 -0
- package/dist/esm/views/open-order.js +38 -0
- package/dist/esm/views/open-order.js.map +1 -0
- package/dist/esm/views/pool/index.js +54 -0
- package/dist/esm/views/pool/index.js.map +1 -0
- package/dist/esm/views/pool/market-making.js +18 -0
- package/dist/esm/views/pool/market-making.js.map +1 -0
- package/dist/esm/views/pool/snapshot.js +12 -0
- package/dist/esm/views/pool/snapshot.js.map +1 -0
- package/dist/esm/views/subgraph.js +54 -0
- package/dist/esm/views/subgraph.js.map +1 -0
- package/dist/esm/views/tick.js +89 -0
- package/dist/esm/views/tick.js.map +1 -0
- package/dist/esm/views/trade.js +11 -0
- package/dist/esm/views/trade.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/calls/approval/open-order.d.ts +33 -0
- package/dist/types/calls/approval/open-order.d.ts.map +1 -0
- package/dist/types/{approval.d.ts → calls/approval/token.d.ts} +3 -32
- package/dist/types/calls/approval/token.d.ts.map +1 -0
- package/dist/types/calls/index.d.ts +17 -0
- package/dist/types/calls/index.d.ts.map +1 -0
- package/dist/types/calls/market/cancel.d.ts +73 -0
- package/dist/types/calls/market/cancel.d.ts.map +1 -0
- package/dist/types/calls/market/claim.d.ts +73 -0
- package/dist/types/calls/market/claim.d.ts.map +1 -0
- package/dist/types/calls/market/limit.d.ts +87 -0
- package/dist/types/calls/market/limit.d.ts.map +1 -0
- package/dist/types/calls/market/make.d.ts +36 -0
- package/dist/types/calls/market/make.d.ts.map +1 -0
- package/dist/types/calls/market/market.d.ts +67 -0
- package/dist/types/calls/market/market.d.ts.map +1 -0
- package/dist/types/calls/market/open.d.ts +31 -0
- package/dist/types/calls/market/open.d.ts.map +1 -0
- package/dist/types/calls/pool/burn.d.ts +22 -0
- package/dist/types/calls/pool/burn.d.ts.map +1 -0
- package/dist/types/calls/pool/market-making/adjust.d.ts +22 -0
- package/dist/types/calls/pool/market-making/adjust.d.ts.map +1 -0
- package/dist/types/calls/pool/market-making/pause.d.ts +14 -0
- package/dist/types/calls/pool/market-making/pause.d.ts.map +1 -0
- package/dist/types/calls/pool/market-making/refill.d.ts +14 -0
- package/dist/types/calls/pool/market-making/refill.d.ts.map +1 -0
- package/dist/types/calls/pool/market-making/resume.d.ts +14 -0
- package/dist/types/calls/pool/market-making/resume.d.ts.map +1 -0
- package/dist/types/calls/pool/mint.d.ts +45 -0
- package/dist/types/calls/pool/mint.d.ts.map +1 -0
- package/dist/types/calls/pool/open.d.ts +34 -0
- package/dist/types/calls/pool/open.d.ts.map +1 -0
- package/dist/types/calls/pool/wrap.d.ts +79 -0
- package/dist/types/calls/pool/wrap.d.ts.map +1 -0
- package/dist/types/{abis → constants/abis}/core/book-manager-abi.d.ts +35 -0
- package/dist/types/constants/abis/core/book-manager-abi.d.ts.map +1 -0
- package/dist/types/{abis → constants/abis}/core/book-viewer-abi.d.ts.map +1 -1
- package/dist/types/{abis → constants/abis}/core/controller-abi.d.ts +19 -1
- package/dist/types/{abis → constants/abis}/core/controller-abi.d.ts.map +1 -1
- package/dist/types/constants/abis/core/params-abi.d.ts +31 -0
- package/dist/types/constants/abis/core/params-abi.d.ts.map +1 -0
- package/dist/types/{abis → constants/abis}/rebalancer/minter-abi.d.ts.map +1 -1
- package/dist/types/constants/abis/rebalancer/mock-swap-abi.d.ts.map +1 -0
- package/dist/types/{abis → constants/abis}/rebalancer/operator-abi.d.ts.map +1 -1
- package/dist/types/{abis → constants/abis}/rebalancer/rebalancer-abi.d.ts.map +1 -1
- package/dist/types/{abis → constants/abis}/rebalancer/strategy-abi.d.ts.map +1 -1
- package/dist/types/constants/abis/rebalancer/wrapped-6909-factory-abi.d.ts +80 -0
- package/dist/types/constants/abis/rebalancer/wrapped-6909-factory-abi.d.ts.map +1 -0
- package/dist/types/constants/{addresses.d.ts → chain-configs/addresses.d.ts} +1 -0
- package/dist/types/constants/chain-configs/addresses.d.ts.map +1 -0
- package/dist/types/constants/{chain.d.ts → chain-configs/chain.d.ts} +3 -5
- package/dist/types/constants/chain-configs/chain.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/currency.d.ts +18 -0
- package/dist/types/constants/chain-configs/currency.d.ts.map +1 -0
- package/dist/types/constants/{fee.d.ts → chain-configs/fee.d.ts} +1 -1
- package/dist/types/constants/chain-configs/fee.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/subgraph.d.ts.map +1 -0
- package/dist/types/constants/networks/giwa-sepolia.d.ts +60 -0
- package/dist/types/constants/networks/giwa-sepolia.d.ts.map +1 -0
- package/dist/types/constants/{rise-sepolia.d.ts → networks/rise-sepolia.d.ts} +3 -0
- package/dist/types/constants/networks/rise-sepolia.d.ts.map +1 -0
- package/dist/types/constants/networks/test-chain.d.ts +3 -0
- package/dist/types/constants/networks/test-chain.d.ts.map +1 -0
- package/dist/types/constants/permit.d.ts +1 -1
- package/dist/types/constants/permit.d.ts.map +1 -1
- package/dist/types/constants/price.d.ts.map +1 -1
- package/dist/types/entities/analytics/apis/index.d.ts +7 -0
- package/dist/types/entities/analytics/apis/index.d.ts.map +1 -0
- package/dist/types/entities/analytics/types.d.ts +52 -0
- package/dist/types/entities/analytics/types.d.ts.map +1 -0
- package/dist/types/entities/book/apis/index.d.ts +6 -0
- package/dist/types/entities/book/apis/index.d.ts.map +1 -0
- package/dist/types/{model/book.d.ts → entities/book/model.d.ts} +11 -7
- package/dist/types/entities/book/model.d.ts.map +1 -0
- package/dist/types/entities/book/types.d.ts +14 -0
- package/dist/types/entities/book/types.d.ts.map +1 -0
- package/dist/types/{utils → entities/book/utils}/book-id.d.ts +1 -1
- package/dist/types/entities/book/utils/book-id.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/allowance.d.ts.map +1 -0
- package/dist/types/{utils → entities/currency/apis}/approval.d.ts +1 -1
- package/dist/types/entities/currency/apis/approval.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/index.d.ts +6 -0
- package/dist/types/entities/currency/apis/index.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/price.d.ts +10 -0
- package/dist/types/entities/currency/apis/price.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/total-supply.d.ts +6 -0
- package/dist/types/entities/currency/apis/total-supply.d.ts.map +1 -0
- package/dist/types/entities/currency/types.d.ts +32 -0
- package/dist/types/entities/currency/types.d.ts.map +1 -0
- package/dist/types/{model/fee-policy.d.ts → entities/fee-policy/model.d.ts} +1 -1
- package/dist/types/entities/fee-policy/model.d.ts.map +1 -0
- package/dist/types/{apis/chart-logs.d.ts → entities/market/apis/chart-log.d.ts} +4 -3
- package/dist/types/entities/market/apis/chart-log.d.ts.map +1 -0
- package/dist/types/entities/market/apis/index.d.ts +5 -0
- package/dist/types/entities/market/apis/index.d.ts.map +1 -0
- package/dist/types/entities/market/apis/snapshot.d.ts +6 -0
- package/dist/types/entities/market/apis/snapshot.d.ts.map +1 -0
- package/dist/types/{model/market.d.ts → entities/market/model.d.ts} +16 -11
- package/dist/types/entities/market/model.d.ts.map +1 -0
- package/dist/types/entities/market/types.d.ts +38 -0
- package/dist/types/entities/market/types.d.ts.map +1 -0
- package/dist/types/{utils/market.d.ts → entities/market/utils/market-id.d.ts} +2 -2
- package/dist/types/entities/market/utils/market-id.d.ts.map +1 -0
- package/dist/types/{apis/open-order.d.ts → entities/open-order/apis/index.d.ts} +6 -3
- package/dist/types/entities/open-order/apis/index.d.ts.map +1 -0
- package/dist/types/entities/open-order/types.d.ts +21 -0
- package/dist/types/entities/open-order/types.d.ts.map +1 -0
- package/dist/types/entities/open-order/utils/order-id.d.ts +7 -0
- package/dist/types/entities/open-order/utils/order-id.d.ts.map +1 -0
- package/dist/types/entities/pool/apis/index.d.ts +6 -0
- package/dist/types/entities/pool/apis/index.d.ts.map +1 -0
- package/dist/types/entities/pool/apis/snapshot.d.ts +5 -0
- package/dist/types/entities/pool/apis/snapshot.d.ts.map +1 -0
- package/dist/types/entities/pool/apis/strategy.d.ts +6 -0
- package/dist/types/entities/pool/apis/strategy.d.ts.map +1 -0
- package/dist/types/{model/pool.d.ts → entities/pool/model.d.ts} +10 -34
- package/dist/types/entities/pool/model.d.ts.map +1 -0
- package/dist/types/entities/pool/types.d.ts +75 -0
- package/dist/types/entities/pool/types.d.ts.map +1 -0
- package/dist/types/{utils/pool.d.ts → entities/pool/utils/mint.d.ts} +4 -2
- package/dist/types/entities/pool/utils/mint.d.ts.map +1 -0
- package/dist/types/entities/pool/utils/pool-key.d.ts +2 -0
- package/dist/types/entities/pool/utils/pool-key.d.ts.map +1 -0
- package/dist/types/entities/swap/apis/index.d.ts +5 -0
- package/dist/types/entities/swap/apis/index.d.ts.map +1 -0
- package/dist/types/entities/swap/types.d.ts +12 -0
- package/dist/types/entities/swap/types.d.ts.map +1 -0
- package/dist/types/index.d.ts +4 -4
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/types/default-options.d.ts +10 -0
- package/dist/types/types/default-options.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +26 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/permit.d.ts +12 -0
- package/dist/types/types/permit.d.ts.map +1 -0
- package/dist/types/types/transaction.d.ts +10 -0
- package/dist/types/types/transaction.d.ts.map +1 -0
- package/dist/types/utils/bigint.d.ts +1 -0
- package/dist/types/utils/bigint.d.ts.map +1 -1
- package/dist/types/utils/build-transaction.d.ts +1 -1
- package/dist/types/utils/build-transaction.d.ts.map +1 -1
- package/dist/types/utils/{decimals.d.ts → conversion.d.ts} +1 -1
- package/dist/types/utils/conversion.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +5 -0
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/types/utils/prices.d.ts +1 -1
- package/dist/types/utils/prices.d.ts.map +1 -1
- package/dist/types/utils/time.d.ts +2 -0
- package/dist/types/utils/time.d.ts.map +1 -1
- package/dist/types/utils/unit-size.d.ts +2 -2
- package/dist/types/utils/unit-size.d.ts.map +1 -1
- package/dist/types/views/address.d.ts +26 -0
- package/dist/types/views/address.d.ts.map +1 -0
- package/dist/types/views/analytics.d.ts +17 -0
- package/dist/types/views/analytics.d.ts.map +1 -0
- package/dist/types/views/currency.d.ts +50 -0
- package/dist/types/views/currency.d.ts.map +1 -0
- package/dist/types/views/index.d.ts +10 -0
- package/dist/types/views/index.d.ts.map +1 -0
- package/dist/types/views/market/chart-log.d.ts +56 -0
- package/dist/types/views/market/chart-log.d.ts.map +1 -0
- package/dist/types/views/market/index.d.ts +33 -0
- package/dist/types/views/market/index.d.ts.map +1 -0
- package/dist/types/views/market/parse.d.ts +10 -0
- package/dist/types/views/market/parse.d.ts.map +1 -0
- package/dist/types/views/market/quote.d.ts +90 -0
- package/dist/types/views/market/quote.d.ts.map +1 -0
- package/dist/types/views/market/snapshot.d.ts +17 -0
- package/dist/types/views/market/snapshot.d.ts.map +1 -0
- package/dist/types/views/market/token.d.ts +24 -0
- package/dist/types/views/market/token.d.ts.map +1 -0
- package/dist/types/views/open-order.d.ts +41 -0
- package/dist/types/views/open-order.d.ts.map +1 -0
- package/dist/types/views/pool/index.d.ts +43 -0
- package/dist/types/views/pool/index.d.ts.map +1 -0
- package/dist/types/views/pool/market-making.d.ts +13 -0
- package/dist/types/views/pool/market-making.d.ts.map +1 -0
- package/dist/types/views/pool/snapshot.d.ts +10 -0
- package/dist/types/views/pool/snapshot.d.ts.map +1 -0
- package/dist/types/views/subgraph.d.ts +52 -0
- package/dist/types/views/subgraph.d.ts.map +1 -0
- package/dist/types/views/tick.d.ts +77 -0
- package/dist/types/views/tick.d.ts.map +1 -0
- package/dist/types/views/trade.d.ts +10 -0
- package/dist/types/views/trade.d.ts.map +1 -0
- package/package.json +2 -2
- package/dist/cjs/abis/core/book-manager-abi.js.map +0 -1
- package/dist/cjs/abis/core/book-viewer-abi.js.map +0 -1
- package/dist/cjs/abis/core/controller-abi.js.map +0 -1
- package/dist/cjs/abis/rebalancer/minter-abi.js.map +0 -1
- package/dist/cjs/abis/rebalancer/mock-swap-abi.js.map +0 -1
- package/dist/cjs/abis/rebalancer/operator-abi.js.map +0 -1
- package/dist/cjs/abis/rebalancer/rebalancer-abi.js.map +0 -1
- package/dist/cjs/abis/rebalancer/strategy-abi.js.map +0 -1
- package/dist/cjs/apis/chart-logs.js.map +0 -1
- package/dist/cjs/apis/market.js +0 -89
- package/dist/cjs/apis/market.js.map +0 -1
- package/dist/cjs/apis/odos.js +0 -100
- package/dist/cjs/apis/odos.js.map +0 -1
- package/dist/cjs/apis/open-order.js +0 -131
- package/dist/cjs/apis/open-order.js.map +0 -1
- package/dist/cjs/apis/pool.js +0 -95
- package/dist/cjs/apis/pool.js.map +0 -1
- package/dist/cjs/apis/strategy.js.map +0 -1
- package/dist/cjs/approval.js +0 -102
- package/dist/cjs/approval.js.map +0 -1
- package/dist/cjs/call.js +0 -1057
- package/dist/cjs/call.js.map +0 -1
- package/dist/cjs/constants/action.js +0 -14
- package/dist/cjs/constants/action.js.map +0 -1
- package/dist/cjs/constants/addresses.js +0 -80
- package/dist/cjs/constants/addresses.js.map +0 -1
- package/dist/cjs/constants/chain.js.map +0 -1
- package/dist/cjs/constants/currency.js +0 -95
- package/dist/cjs/constants/currency.js.map +0 -1
- package/dist/cjs/constants/fee.js +0 -26
- package/dist/cjs/constants/fee.js.map +0 -1
- package/dist/cjs/constants/rise-sepolia.js.map +0 -1
- package/dist/cjs/constants/subgraph.js.map +0 -1
- package/dist/cjs/constants/test-chain.js +0 -50
- package/dist/cjs/constants/test-chain.js.map +0 -1
- package/dist/cjs/model/book.js.map +0 -1
- package/dist/cjs/model/chart-log.js.map +0 -1
- package/dist/cjs/model/currency.js.map +0 -1
- package/dist/cjs/model/depth.js.map +0 -1
- package/dist/cjs/model/fee-policy.js.map +0 -1
- package/dist/cjs/model/market.js.map +0 -1
- package/dist/cjs/model/open-order.js.map +0 -1
- package/dist/cjs/model/pool.js.map +0 -1
- package/dist/cjs/type.js.map +0 -1
- package/dist/cjs/utils/allowance.js +0 -39
- package/dist/cjs/utils/allowance.js.map +0 -1
- package/dist/cjs/utils/approval.js +0 -40
- package/dist/cjs/utils/approval.js.map +0 -1
- package/dist/cjs/utils/book-id.js.map +0 -1
- package/dist/cjs/utils/currency.js +0 -165
- package/dist/cjs/utils/currency.js.map +0 -1
- package/dist/cjs/utils/decimals.js.map +0 -1
- package/dist/cjs/utils/market.js.map +0 -1
- package/dist/cjs/utils/open.js +0 -46
- package/dist/cjs/utils/open.js.map +0 -1
- package/dist/cjs/utils/order.js +0 -97
- package/dist/cjs/utils/order.js.map +0 -1
- package/dist/cjs/utils/pool-key.js.map +0 -1
- package/dist/cjs/utils/pool.js.map +0 -1
- package/dist/cjs/utils/quotes.js +0 -16
- package/dist/cjs/utils/quotes.js.map +0 -1
- package/dist/cjs/utils/time-series.js +0 -31
- package/dist/cjs/utils/time-series.js.map +0 -1
- package/dist/cjs/utils.js.map +0 -1
- package/dist/cjs/view.js +0 -349
- package/dist/cjs/view.js.map +0 -1
- package/dist/esm/abis/core/book-manager-abi.js.map +0 -1
- package/dist/esm/abis/core/book-viewer-abi.js.map +0 -1
- package/dist/esm/abis/core/controller-abi.js.map +0 -1
- package/dist/esm/abis/rebalancer/minter-abi.js.map +0 -1
- package/dist/esm/abis/rebalancer/mock-swap-abi.js.map +0 -1
- package/dist/esm/abis/rebalancer/operator-abi.js.map +0 -1
- package/dist/esm/abis/rebalancer/rebalancer-abi.js.map +0 -1
- package/dist/esm/abis/rebalancer/strategy-abi.js.map +0 -1
- package/dist/esm/apis/chart-logs.js.map +0 -1
- package/dist/esm/apis/market.js +0 -85
- package/dist/esm/apis/market.js.map +0 -1
- package/dist/esm/apis/odos.js +0 -94
- package/dist/esm/apis/odos.js.map +0 -1
- package/dist/esm/apis/open-order.js +0 -129
- package/dist/esm/apis/open-order.js.map +0 -1
- package/dist/esm/apis/pool.js +0 -90
- package/dist/esm/apis/pool.js.map +0 -1
- package/dist/esm/apis/strategy.js +0 -48
- package/dist/esm/apis/strategy.js.map +0 -1
- package/dist/esm/approval.js.map +0 -1
- package/dist/esm/call.js +0 -1257
- package/dist/esm/call.js.map +0 -1
- package/dist/esm/constants/action.js +0 -11
- package/dist/esm/constants/action.js.map +0 -1
- package/dist/esm/constants/addresses.js +0 -77
- package/dist/esm/constants/addresses.js.map +0 -1
- package/dist/esm/constants/chain.js.map +0 -1
- package/dist/esm/constants/currency.js +0 -94
- package/dist/esm/constants/currency.js.map +0 -1
- package/dist/esm/constants/fee.js.map +0 -1
- package/dist/esm/constants/rise-sepolia.js.map +0 -1
- package/dist/esm/constants/subgraph.js.map +0 -1
- package/dist/esm/constants/test-chain.js +0 -47
- package/dist/esm/constants/test-chain.js.map +0 -1
- package/dist/esm/model/book.js.map +0 -1
- package/dist/esm/model/chart-log.js +0 -2
- package/dist/esm/model/chart-log.js.map +0 -1
- package/dist/esm/model/currency.js +0 -2
- package/dist/esm/model/currency.js.map +0 -1
- package/dist/esm/model/depth.js +0 -2
- package/dist/esm/model/depth.js.map +0 -1
- package/dist/esm/model/fee-policy.js.map +0 -1
- package/dist/esm/model/market.js.map +0 -1
- package/dist/esm/model/open-order.js +0 -2
- package/dist/esm/model/open-order.js.map +0 -1
- package/dist/esm/model/pool.js.map +0 -1
- package/dist/esm/type.js.map +0 -1
- package/dist/esm/utils/allowance.js +0 -35
- package/dist/esm/utils/allowance.js.map +0 -1
- package/dist/esm/utils/approval.js +0 -36
- package/dist/esm/utils/approval.js.map +0 -1
- package/dist/esm/utils/book-id.js.map +0 -1
- package/dist/esm/utils/currency.js +0 -160
- package/dist/esm/utils/currency.js.map +0 -1
- package/dist/esm/utils/decimals.js.map +0 -1
- package/dist/esm/utils/market.js.map +0 -1
- package/dist/esm/utils/open.js +0 -42
- package/dist/esm/utils/open.js.map +0 -1
- package/dist/esm/utils/order.js +0 -92
- package/dist/esm/utils/order.js.map +0 -1
- package/dist/esm/utils/pool-key.js.map +0 -1
- package/dist/esm/utils/pool.js.map +0 -1
- package/dist/esm/utils/quotes.js +0 -12
- package/dist/esm/utils/quotes.js.map +0 -1
- package/dist/esm/utils/time-series.js +0 -27
- package/dist/esm/utils/time-series.js.map +0 -1
- package/dist/esm/utils.js +0 -5
- package/dist/esm/utils.js.map +0 -1
- package/dist/esm/view.js +0 -549
- package/dist/esm/view.js.map +0 -1
- package/dist/types/abis/core/book-manager-abi.d.ts.map +0 -1
- package/dist/types/abis/rebalancer/mock-swap-abi.d.ts.map +0 -1
- package/dist/types/apis/chart-logs.d.ts.map +0 -1
- package/dist/types/apis/market.d.ts +0 -5
- package/dist/types/apis/market.d.ts.map +0 -1
- package/dist/types/apis/odos.d.ts +0 -28
- package/dist/types/apis/odos.d.ts.map +0 -1
- package/dist/types/apis/open-order.d.ts.map +0 -1
- package/dist/types/apis/pool.d.ts +0 -11
- package/dist/types/apis/pool.d.ts.map +0 -1
- package/dist/types/apis/strategy.d.ts +0 -6
- package/dist/types/apis/strategy.d.ts.map +0 -1
- package/dist/types/approval.d.ts.map +0 -1
- package/dist/types/call.d.ts +0 -465
- package/dist/types/call.d.ts.map +0 -1
- package/dist/types/constants/action.d.ts +0 -10
- package/dist/types/constants/action.d.ts.map +0 -1
- package/dist/types/constants/addresses.d.ts.map +0 -1
- package/dist/types/constants/chain.d.ts.map +0 -1
- package/dist/types/constants/currency.d.ts +0 -16
- package/dist/types/constants/currency.d.ts.map +0 -1
- package/dist/types/constants/fee.d.ts.map +0 -1
- package/dist/types/constants/rise-sepolia.d.ts.map +0 -1
- package/dist/types/constants/subgraph.d.ts.map +0 -1
- package/dist/types/constants/test-chain.d.ts +0 -4
- package/dist/types/constants/test-chain.d.ts.map +0 -1
- package/dist/types/model/book.d.ts.map +0 -1
- package/dist/types/model/chart-log.d.ts +0 -9
- package/dist/types/model/chart-log.d.ts.map +0 -1
- package/dist/types/model/currency.d.ts +0 -14
- package/dist/types/model/currency.d.ts.map +0 -1
- package/dist/types/model/depth.d.ts +0 -10
- package/dist/types/model/depth.d.ts.map +0 -1
- package/dist/types/model/fee-policy.d.ts.map +0 -1
- package/dist/types/model/market.d.ts.map +0 -1
- package/dist/types/model/open-order.d.ts +0 -50
- package/dist/types/model/open-order.d.ts.map +0 -1
- package/dist/types/model/pool.d.ts.map +0 -1
- package/dist/types/type.d.ts +0 -159
- package/dist/types/type.d.ts.map +0 -1
- package/dist/types/utils/allowance.d.ts.map +0 -1
- package/dist/types/utils/approval.d.ts.map +0 -1
- package/dist/types/utils/book-id.d.ts.map +0 -1
- package/dist/types/utils/currency.d.ts +0 -8
- package/dist/types/utils/currency.d.ts.map +0 -1
- package/dist/types/utils/decimals.d.ts.map +0 -1
- package/dist/types/utils/market.d.ts.map +0 -1
- package/dist/types/utils/open.d.ts +0 -4
- package/dist/types/utils/open.d.ts.map +0 -1
- package/dist/types/utils/order.d.ts +0 -10
- package/dist/types/utils/order.d.ts.map +0 -1
- package/dist/types/utils/pool-key.d.ts +0 -3
- package/dist/types/utils/pool-key.d.ts.map +0 -1
- package/dist/types/utils/pool.d.ts.map +0 -1
- package/dist/types/utils/quotes.d.ts +0 -2
- package/dist/types/utils/quotes.d.ts.map +0 -1
- package/dist/types/utils/time-series.d.ts +0 -4
- package/dist/types/utils/time-series.d.ts.map +0 -1
- package/dist/types/utils.d.ts +0 -5
- package/dist/types/utils.d.ts.map +0 -1
- package/dist/types/view.d.ts +0 -423
- package/dist/types/view.d.ts.map +0 -1
- /package/dist/cjs/{abis → constants/abis}/core/book-viewer-abi.js +0 -0
- /package/dist/cjs/{abis → constants/abis}/rebalancer/minter-abi.js +0 -0
- /package/dist/cjs/{abis → constants/abis}/rebalancer/mock-swap-abi.js +0 -0
- /package/dist/cjs/{abis → constants/abis}/rebalancer/operator-abi.js +0 -0
- /package/dist/cjs/{abis → constants/abis}/rebalancer/rebalancer-abi.js +0 -0
- /package/dist/cjs/{abis → constants/abis}/rebalancer/strategy-abi.js +0 -0
- /package/dist/cjs/constants/{rise-sepolia.js → networks/rise-sepolia.js} +0 -0
- /package/dist/esm/{abis → constants/abis}/core/book-viewer-abi.js +0 -0
- /package/dist/esm/{abis → constants/abis}/rebalancer/minter-abi.js +0 -0
- /package/dist/esm/{abis → constants/abis}/rebalancer/mock-swap-abi.js +0 -0
- /package/dist/esm/{abis → constants/abis}/rebalancer/operator-abi.js +0 -0
- /package/dist/esm/{abis → constants/abis}/rebalancer/rebalancer-abi.js +0 -0
- /package/dist/esm/{abis → constants/abis}/rebalancer/strategy-abi.js +0 -0
- /package/dist/esm/constants/{rise-sepolia.js → networks/rise-sepolia.js} +0 -0
- /package/dist/types/{abis → constants/abis}/core/book-viewer-abi.d.ts +0 -0
- /package/dist/types/{abis → constants/abis}/rebalancer/minter-abi.d.ts +0 -0
- /package/dist/types/{abis → constants/abis}/rebalancer/mock-swap-abi.d.ts +0 -0
- /package/dist/types/{abis → constants/abis}/rebalancer/operator-abi.d.ts +0 -0
- /package/dist/types/{abis → constants/abis}/rebalancer/rebalancer-abi.d.ts +0 -0
- /package/dist/types/{abis → constants/abis}/rebalancer/strategy-abi.d.ts +0 -0
- /package/dist/types/constants/{subgraph.d.ts → chain-configs/subgraph.d.ts} +0 -0
- /package/dist/types/{utils → entities/currency/apis}/allowance.d.ts +0 -0
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { createPublicClient, http, isAddressEqual, zeroAddress, zeroHash, } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchIsApprovedForAll } from '../../entities/currency/apis/approval';
|
|
4
|
+
import { fetchOnChainOrders, fetchOpenOrdersByOrderIdsFromSubgraph, } from '../../entities/open-order/apis';
|
|
5
|
+
import { buildTransaction } from '../../utils/build-transaction';
|
|
6
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
7
|
+
import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
|
|
8
|
+
import { getDeadlineTimestampInSeconds } from '../../utils/time';
|
|
9
|
+
/**
|
|
10
|
+
* Cancels specified open order if the order is not fully filled.
|
|
11
|
+
* [IMPORTANT] Set ApprovalForAll before calling this function.
|
|
12
|
+
*
|
|
13
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
14
|
+
* @param {`0x${string}`} userAddress The Ethereum address of the user.
|
|
15
|
+
* @param {string} id An ID representing the open order to be canceled
|
|
16
|
+
* @param options {@link DefaultWriteContractOptions} options.
|
|
17
|
+
* @returns {Promise<{ transaction: Transaction, result: CurrencyFlow }>}
|
|
18
|
+
* Promise resolving to the transaction object representing the cancel action with the result of the order.
|
|
19
|
+
* @throws {Error} Throws an error if no open orders are found for the specified user.
|
|
20
|
+
* @example
|
|
21
|
+
* import { getOpenOrders, cancelOrders } from '@clober/v2-sdk'
|
|
22
|
+
*
|
|
23
|
+
* const openOrders = await getOpenOrders({
|
|
24
|
+
* chainId: 421614,
|
|
25
|
+
* userAddress:'0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
|
|
26
|
+
* })
|
|
27
|
+
* const transaction = await cancelOrders({
|
|
28
|
+
* chainId: 421614,
|
|
29
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
30
|
+
* id: openOrders.map((order) => order.id)
|
|
31
|
+
* })
|
|
32
|
+
*/
|
|
33
|
+
export const cancelOrder = async ({ chainId, userAddress, id, options, }) => {
|
|
34
|
+
const { transaction, result } = await cancelOrders({
|
|
35
|
+
chainId,
|
|
36
|
+
userAddress,
|
|
37
|
+
ids: [id],
|
|
38
|
+
options: { ...options },
|
|
39
|
+
});
|
|
40
|
+
return {
|
|
41
|
+
transaction,
|
|
42
|
+
result: result[0],
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* Cancels specified open orders if orders are not fully filled.
|
|
47
|
+
* [IMPORTANT] Set ApprovalForAll before calling this function.
|
|
48
|
+
*
|
|
49
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
50
|
+
* @param {`0x${string}`} userAddress The Ethereum address of the user.
|
|
51
|
+
* @param {string[]} ids An array of IDs representing the open orders to be canceled.
|
|
52
|
+
* @param options {@link DefaultWriteContractOptions} options.
|
|
53
|
+
* @returns {Promise<{ transaction: Transaction, result: CurrencyFlow[] }>
|
|
54
|
+
* Promise resolving to the transaction object representing the cancel action with the result of the orders.
|
|
55
|
+
* @throws {Error} Throws an error if no open orders are found for the specified user.
|
|
56
|
+
* @example
|
|
57
|
+
* import { getOpenOrders, cancelOrders } from '@clober/v2-sdk'
|
|
58
|
+
*
|
|
59
|
+
* const openOrders = await getOpenOrders({
|
|
60
|
+
* chainId: 421614,
|
|
61
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
|
|
62
|
+
* })
|
|
63
|
+
* const transaction = await cancelOrders({
|
|
64
|
+
* chainId: 421614,
|
|
65
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
66
|
+
* ids: openOrders.map((order) => order.id)
|
|
67
|
+
* })
|
|
68
|
+
*/
|
|
69
|
+
export const cancelOrders = async ({ chainId, userAddress, ids, options, }) => {
|
|
70
|
+
const publicClient = createPublicClient({
|
|
71
|
+
chain: CHAIN_MAP[chainId],
|
|
72
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
73
|
+
});
|
|
74
|
+
const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, userAddress);
|
|
75
|
+
if (!isApprovedForAll) {
|
|
76
|
+
throw new Error(`
|
|
77
|
+
Set ApprovalForAll before calling this function.
|
|
78
|
+
import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
|
|
79
|
+
|
|
80
|
+
const hash = await setApprovalOfOpenOrdersForAll({
|
|
81
|
+
chainId: ${chainId},
|
|
82
|
+
walletClient, // use viem
|
|
83
|
+
})
|
|
84
|
+
`);
|
|
85
|
+
}
|
|
86
|
+
const useSubgraph = !!(options && options.useSubgraph);
|
|
87
|
+
const orders = (useSubgraph
|
|
88
|
+
? await fetchOpenOrdersByOrderIdsFromSubgraph(chainId, ids)
|
|
89
|
+
: await fetchOnChainOrders(publicClient, chainId, ids.map((id) => BigInt(id)))).filter((order) => isAddressEqual(order.user, userAddress) && order.cancelable.value !== '0');
|
|
90
|
+
const tokensToSettle = orders
|
|
91
|
+
.map((order) => [order.inputCurrency.address, order.outputCurrency.address])
|
|
92
|
+
.flat()
|
|
93
|
+
.filter((address, index, self) => self.findIndex((c) => isAddressEqual(c, address)) === index)
|
|
94
|
+
.filter((address) => !isAddressEqual(address, zeroAddress));
|
|
95
|
+
return {
|
|
96
|
+
transaction: await buildTransaction(publicClient, {
|
|
97
|
+
chain: CHAIN_MAP[chainId],
|
|
98
|
+
account: userAddress,
|
|
99
|
+
address: CONTRACT_ADDRESSES[chainId].Controller,
|
|
100
|
+
abi: CONTROLLER_ABI,
|
|
101
|
+
functionName: 'cancel',
|
|
102
|
+
args: [
|
|
103
|
+
orders.map(({ id }) => ({
|
|
104
|
+
id,
|
|
105
|
+
leftQuoteAmount: 0n,
|
|
106
|
+
hookData: zeroHash,
|
|
107
|
+
})),
|
|
108
|
+
tokensToSettle,
|
|
109
|
+
[],
|
|
110
|
+
getDeadlineTimestampInSeconds(),
|
|
111
|
+
],
|
|
112
|
+
}, options?.gasLimit),
|
|
113
|
+
result: orders.reduce((acc, { cancelable: { currency, value } }) => {
|
|
114
|
+
const index = acc.findIndex((c) => isAddressEqual(c.currency.address, currency.address));
|
|
115
|
+
if (index === -1) {
|
|
116
|
+
return [...acc, { currency, amount: value, direction: 'out' }];
|
|
117
|
+
}
|
|
118
|
+
acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
|
|
119
|
+
return acc;
|
|
120
|
+
}, []),
|
|
121
|
+
};
|
|
122
|
+
};
|
|
123
|
+
//# sourceMappingURL=cancel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cancel.js","sourceRoot":"","sources":["../../../../src/calls/market/cancel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { createPublicClient, http, isAddressEqual, zeroAddress, zeroHash, } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchIsApprovedForAll } from '../../entities/currency/apis/approval';
|
|
4
|
+
import { fetchOnChainOrders, fetchOpenOrdersByOrderIdsFromSubgraph, } from '../../entities/open-order/apis';
|
|
5
|
+
import { buildTransaction } from '../../utils/build-transaction';
|
|
6
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
7
|
+
import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
|
|
8
|
+
import { getDeadlineTimestampInSeconds } from '../../utils/time';
|
|
9
|
+
/**
|
|
10
|
+
* Claims specified open order for settlement.
|
|
11
|
+
* [IMPORTANT] Set ApprovalForAll before calling this function.
|
|
12
|
+
*
|
|
13
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
14
|
+
* @param {`0x${string}`} userAddress The Ethereum address of the user.
|
|
15
|
+
* @param {string} id An ID representing the open order to be claimed.
|
|
16
|
+
* @param options {@link DefaultWriteContractOptions} options.
|
|
17
|
+
* @returns {Promise<{ transaction: Transaction, result: CurrencyFlow }>}
|
|
18
|
+
* Promise resolving to the transaction object representing the claim action with the result of the order.
|
|
19
|
+
* @throws {Error} Throws an error if no open orders are found for the specified user.
|
|
20
|
+
* @example
|
|
21
|
+
* import { getOpenOrders, claimOrders } from '@clober/v2-sdk'
|
|
22
|
+
*
|
|
23
|
+
* const openOrders = await getOpenOrders({
|
|
24
|
+
* chainId: 421614,
|
|
25
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
|
|
26
|
+
* })
|
|
27
|
+
* const transaction = await claimOrders({
|
|
28
|
+
* chainId: 421614,
|
|
29
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
30
|
+
* id: openOrders.map((order) => order.id)
|
|
31
|
+
* })
|
|
32
|
+
*/
|
|
33
|
+
export const claimOrder = async ({ chainId, userAddress, id, options, }) => {
|
|
34
|
+
const { transaction, result } = await claimOrders({
|
|
35
|
+
chainId,
|
|
36
|
+
userAddress,
|
|
37
|
+
ids: [id],
|
|
38
|
+
options: { ...options },
|
|
39
|
+
});
|
|
40
|
+
return {
|
|
41
|
+
transaction,
|
|
42
|
+
result: result[0],
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* Claims specified open orders for settlement.
|
|
47
|
+
* [IMPORTANT] Set ApprovalForAll before calling this function.
|
|
48
|
+
*
|
|
49
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
50
|
+
* @param {`0x${string}`} userAddress The Ethereum address of the user.
|
|
51
|
+
* @param {string[]} ids An array of IDs representing the open orders to be claimed.
|
|
52
|
+
* @param options {@link DefaultWriteContractOptions} options.
|
|
53
|
+
* @returns {Promise<{ transaction: Transaction, result: CurrencyFlow[] }>}
|
|
54
|
+
* Promise resolving to the transaction object representing the claim action with the result of the orders.
|
|
55
|
+
* @throws {Error} Throws an error if no open orders are found for the specified user.
|
|
56
|
+
* @example
|
|
57
|
+
* import { getOpenOrders, claimOrders } from '@clober/v2-sdk'
|
|
58
|
+
*
|
|
59
|
+
* const openOrders = await getOpenOrders({
|
|
60
|
+
* chainId: 421614,
|
|
61
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
|
|
62
|
+
* })
|
|
63
|
+
* const transaction = await claimOrders(
|
|
64
|
+
* chainId: 421614,
|
|
65
|
+
* userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
66
|
+
* ids: openOrders.map((order) => order.id)
|
|
67
|
+
* )
|
|
68
|
+
*/
|
|
69
|
+
export const claimOrders = async ({ chainId, userAddress, ids, options, }) => {
|
|
70
|
+
const publicClient = createPublicClient({
|
|
71
|
+
chain: CHAIN_MAP[chainId],
|
|
72
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
73
|
+
});
|
|
74
|
+
const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, userAddress);
|
|
75
|
+
if (!isApprovedForAll) {
|
|
76
|
+
throw new Error(`
|
|
77
|
+
Set ApprovalForAll before calling this function.
|
|
78
|
+
import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
|
|
79
|
+
|
|
80
|
+
const hash = await setApprovalOfOpenOrdersForAll({
|
|
81
|
+
chainId: ${chainId},
|
|
82
|
+
walletClient, // use viem
|
|
83
|
+
})
|
|
84
|
+
`);
|
|
85
|
+
}
|
|
86
|
+
const useSubgraph = !!(options && options.useSubgraph);
|
|
87
|
+
const orders = (useSubgraph
|
|
88
|
+
? await fetchOpenOrdersByOrderIdsFromSubgraph(chainId, ids)
|
|
89
|
+
: await fetchOnChainOrders(publicClient, chainId, ids.map((id) => BigInt(id)))).filter((order) => isAddressEqual(order.user, userAddress) && order.claimable.value !== '0');
|
|
90
|
+
const tokensToSettle = orders
|
|
91
|
+
.map((order) => [order.inputCurrency.address, order.outputCurrency.address])
|
|
92
|
+
.flat()
|
|
93
|
+
.filter((address, index, self) => self.findIndex((c) => isAddressEqual(c, address)) === index)
|
|
94
|
+
.filter((address) => !isAddressEqual(address, zeroAddress));
|
|
95
|
+
return {
|
|
96
|
+
transaction: await buildTransaction(publicClient, {
|
|
97
|
+
chain: CHAIN_MAP[chainId],
|
|
98
|
+
account: userAddress,
|
|
99
|
+
address: CONTRACT_ADDRESSES[chainId].Controller,
|
|
100
|
+
abi: CONTROLLER_ABI,
|
|
101
|
+
functionName: 'claim',
|
|
102
|
+
args: [
|
|
103
|
+
orders.map(({ id }) => ({
|
|
104
|
+
id,
|
|
105
|
+
hookData: zeroHash,
|
|
106
|
+
})),
|
|
107
|
+
tokensToSettle,
|
|
108
|
+
[],
|
|
109
|
+
getDeadlineTimestampInSeconds(),
|
|
110
|
+
],
|
|
111
|
+
}, options?.gasLimit),
|
|
112
|
+
result: orders.reduce((acc, { claimable: { currency, value } }) => {
|
|
113
|
+
const index = acc.findIndex((c) => isAddressEqual(c.currency.address, currency.address));
|
|
114
|
+
if (index === -1) {
|
|
115
|
+
return [...acc, { currency, amount: value, direction: 'out' }];
|
|
116
|
+
}
|
|
117
|
+
acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
|
|
118
|
+
return acc;
|
|
119
|
+
}, []),
|
|
120
|
+
};
|
|
121
|
+
};
|
|
122
|
+
//# sourceMappingURL=claim.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claim.js","sourceRoot":"","sources":["../../../../src/calls/market/claim.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { createPublicClient, formatUnits, getAddress, http, isAddress, isAddressEqual, parseUnits, zeroAddress, zeroHash, } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchMarket } from '../../entities/market/apis';
|
|
4
|
+
import { formatPrice, parsePrice, invertTick, toPrice } from '../../utils';
|
|
5
|
+
import { calculateUnitSize } from '../../utils/unit-size';
|
|
6
|
+
import { getExpectedOutput } from '../../views';
|
|
7
|
+
import { toBookId } from '../../entities/book/utils/book-id';
|
|
8
|
+
import { buildTransaction } from '../../utils/build-transaction';
|
|
9
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
10
|
+
import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
|
|
11
|
+
import { getDeadlineTimestampInSeconds } from '../../utils/time';
|
|
12
|
+
/**
|
|
13
|
+
* Places a limit order on the specified chain for trading tokens.
|
|
14
|
+
*
|
|
15
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
16
|
+
* @param {`0x${string}`} userAddress The Ethereum address of the user placing the order.
|
|
17
|
+
* @param {`0x${string}`} inputToken The address of the token to be used as input.
|
|
18
|
+
* @param {`0x${string}`} outputToken The address of the token to be received as output.
|
|
19
|
+
* @param {string} amount The amount of input tokens for the order.
|
|
20
|
+
* @param {string} price The price at which the order should be executed.
|
|
21
|
+
* @param options {@link DefaultWriteContractOptions} options.
|
|
22
|
+
* @param {erc20PermitParam} [options.erc20PermitParam] The permit signature for token approval.
|
|
23
|
+
* @param {boolean} [options.postOnly] A boolean indicating whether the order is only to be made not taken.
|
|
24
|
+
* @param {bigint} [options.makeTick] The tick for the make order.
|
|
25
|
+
* @param {bigint} [options.takeLimitTick] The tick for the take order.
|
|
26
|
+
* @param {boolean} [options.roundingUpMakeBid] A boolean indicating whether to round up the make bid.
|
|
27
|
+
* @param {boolean} [options.roundingDownMakeAsk] A boolean indicating whether to round down the make ask.
|
|
28
|
+
* @param {boolean} [options.roundingDownTakenBid] A boolean indicating whether to round down the taken bid.
|
|
29
|
+
* @param {boolean} [options.roundingUpTakenAsk] A boolean indicating whether to round up the taken ask.
|
|
30
|
+
* @returns {Promise<{ transaction: Transaction, result: { make: CurrencyFlow, take: CurrencyFlow, spent: CurrencyFlow }>}
|
|
31
|
+
* Promise resolving to the transaction object representing the limit order with the result of the order.
|
|
32
|
+
* @example
|
|
33
|
+
* import { limitOrder } from '@clober/v2-sdk'
|
|
34
|
+
* import { privateKeyToAccount } from 'viem/accounts'
|
|
35
|
+
*
|
|
36
|
+
* const { transaction } = await limitOrder({
|
|
37
|
+
* chainId: 421614,
|
|
38
|
+
* userAddress: '0xF8c1869Ecd4df136693C45EcE1b67f85B6bDaE69
|
|
39
|
+
* inputToken: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
40
|
+
* outputToken: '0x0000000000000000000000000000000000000000',
|
|
41
|
+
* amount: '100.123', // 100.123 USDC
|
|
42
|
+
* price: '4000.01', // price at 4000.01 (ETH/USDC)
|
|
43
|
+
* })
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* import { limitOrder } from '@clober/v2-sdk'
|
|
47
|
+
*
|
|
48
|
+
* const { transaction } = await limitOrder({
|
|
49
|
+
* chainId: 421614,
|
|
50
|
+
* userAddress: '0xF8c1869Ecd4df136693C45EcE1b67f85B6bDaE69
|
|
51
|
+
* inputToken: '0x0000000000000000000000000000000000000000',
|
|
52
|
+
* outputToken: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
53
|
+
* amount: '0.13', // 0.13 ETH
|
|
54
|
+
* price: '4000.01', // price at 4000.01 (ETH/USDC)
|
|
55
|
+
* })
|
|
56
|
+
*/
|
|
57
|
+
export const limitOrder = async ({ chainId, userAddress, inputToken, outputToken, amount, price, options, }) => {
|
|
58
|
+
const [roundingUpMakeBid, roundingDownMakeAsk, roundingDownTakenBid, roundingUpTakenAsk,] = [
|
|
59
|
+
options?.roundingUpMakeBid ? options.roundingUpMakeBid : false,
|
|
60
|
+
options?.roundingDownMakeAsk ? options.roundingDownMakeAsk : false,
|
|
61
|
+
options?.roundingDownTakenBid ? options.roundingDownTakenBid : false,
|
|
62
|
+
options?.roundingUpTakenAsk ? options.roundingUpTakenAsk : false,
|
|
63
|
+
];
|
|
64
|
+
const publicClient = createPublicClient({
|
|
65
|
+
chain: CHAIN_MAP[chainId],
|
|
66
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
67
|
+
});
|
|
68
|
+
const market = await fetchMarket(publicClient, chainId, [inputToken, outputToken], !!(options && options.useSubgraph));
|
|
69
|
+
const isBid = isAddressEqual(market.quote.address, inputToken);
|
|
70
|
+
const [inputCurrency, outputCurrency] = isBid
|
|
71
|
+
? [market.quote, market.base]
|
|
72
|
+
: [market.base, market.quote];
|
|
73
|
+
if ((isBid && !market.bidBook.isOpened) ||
|
|
74
|
+
(!isBid && !market.askBook.isOpened)) {
|
|
75
|
+
throw new Error(`
|
|
76
|
+
Open the market before placing a limit order.
|
|
77
|
+
import { openMarket } from '@clober/v2-sdk'
|
|
78
|
+
|
|
79
|
+
const transaction = await openMarket({
|
|
80
|
+
chainId: ${chainId},
|
|
81
|
+
inputToken: '${inputToken}',
|
|
82
|
+
outputToken: '${outputToken}',
|
|
83
|
+
})
|
|
84
|
+
`);
|
|
85
|
+
}
|
|
86
|
+
const provider = options && options.provider && isAddress(options.provider)
|
|
87
|
+
? getAddress(options.provider)
|
|
88
|
+
: zeroAddress;
|
|
89
|
+
const { roundingDownTick, roundingUpTick } = parsePrice(Number(price), market.quote.decimals, market.base.decimals);
|
|
90
|
+
const tokensToSettle = [inputToken, outputToken].filter((address) => !isAddressEqual(address, zeroAddress));
|
|
91
|
+
const quoteAmount = parseUnits(amount, inputCurrency.decimals);
|
|
92
|
+
const unitSize = calculateUnitSize(chainId, inputCurrency);
|
|
93
|
+
const { takenAmount, spentAmount, bookId, events } = await getExpectedOutput({
|
|
94
|
+
chainId,
|
|
95
|
+
inputToken,
|
|
96
|
+
outputToken,
|
|
97
|
+
amountIn: amount,
|
|
98
|
+
options: {
|
|
99
|
+
...options,
|
|
100
|
+
limitPrice: price,
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
const isETH = isAddressEqual(inputToken, zeroAddress);
|
|
104
|
+
const makeParam = {
|
|
105
|
+
id: toBookId(chainId, inputToken, outputToken, unitSize),
|
|
106
|
+
tick: options?.makeTick
|
|
107
|
+
? Number(options.makeTick)
|
|
108
|
+
: Number(isBid
|
|
109
|
+
? roundingUpMakeBid
|
|
110
|
+
? roundingUpTick
|
|
111
|
+
: roundingDownTick
|
|
112
|
+
: invertTick(roundingDownMakeAsk ? roundingDownTick : roundingUpTick)),
|
|
113
|
+
quoteAmount,
|
|
114
|
+
provider,
|
|
115
|
+
hookData: zeroHash,
|
|
116
|
+
};
|
|
117
|
+
if (options?.postOnly === true || spentAmount === '0') {
|
|
118
|
+
return {
|
|
119
|
+
transaction: await buildTransaction(publicClient, {
|
|
120
|
+
chain: CHAIN_MAP[chainId],
|
|
121
|
+
account: userAddress,
|
|
122
|
+
address: CONTRACT_ADDRESSES[chainId].Controller,
|
|
123
|
+
abi: CONTROLLER_ABI,
|
|
124
|
+
functionName: 'make',
|
|
125
|
+
args: [
|
|
126
|
+
[makeParam],
|
|
127
|
+
tokensToSettle,
|
|
128
|
+
options?.erc20PermitParam ? [options.erc20PermitParam] : [],
|
|
129
|
+
getDeadlineTimestampInSeconds(),
|
|
130
|
+
],
|
|
131
|
+
value: isETH ? quoteAmount : 0n,
|
|
132
|
+
}, options?.gasLimit),
|
|
133
|
+
result: {
|
|
134
|
+
make: {
|
|
135
|
+
amount: formatUnits(quoteAmount, inputCurrency.decimals),
|
|
136
|
+
currency: inputCurrency,
|
|
137
|
+
direction: 'in',
|
|
138
|
+
price: formatPrice(isBid
|
|
139
|
+
? toPrice(BigInt(makeParam.tick))
|
|
140
|
+
: toPrice(invertTick(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
|
|
141
|
+
},
|
|
142
|
+
spent: {
|
|
143
|
+
amount: '0',
|
|
144
|
+
currency: inputCurrency,
|
|
145
|
+
direction: 'in',
|
|
146
|
+
events: [],
|
|
147
|
+
},
|
|
148
|
+
taken: {
|
|
149
|
+
amount: '0',
|
|
150
|
+
currency: outputCurrency,
|
|
151
|
+
direction: 'out',
|
|
152
|
+
events: [],
|
|
153
|
+
},
|
|
154
|
+
},
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
// take and make
|
|
159
|
+
return {
|
|
160
|
+
transaction: await buildTransaction(publicClient, {
|
|
161
|
+
chain: CHAIN_MAP[chainId],
|
|
162
|
+
account: userAddress,
|
|
163
|
+
address: CONTRACT_ADDRESSES[chainId].Controller,
|
|
164
|
+
abi: CONTROLLER_ABI,
|
|
165
|
+
functionName: 'limit',
|
|
166
|
+
args: [
|
|
167
|
+
[
|
|
168
|
+
{
|
|
169
|
+
takeBookId: bookId,
|
|
170
|
+
makeBookId: makeParam.id,
|
|
171
|
+
limitPrice: options?.takeLimitTick
|
|
172
|
+
? toPrice(options.takeLimitTick)
|
|
173
|
+
: toPrice(isBid
|
|
174
|
+
? invertTick(roundingUpTakenAsk
|
|
175
|
+
? roundingUpTick
|
|
176
|
+
: roundingDownTick)
|
|
177
|
+
: roundingDownTakenBid
|
|
178
|
+
? roundingDownTick
|
|
179
|
+
: roundingUpTick),
|
|
180
|
+
tick: makeParam.tick,
|
|
181
|
+
quoteAmount,
|
|
182
|
+
provider,
|
|
183
|
+
takeHookData: zeroHash,
|
|
184
|
+
makeHookData: makeParam.hookData,
|
|
185
|
+
},
|
|
186
|
+
],
|
|
187
|
+
tokensToSettle,
|
|
188
|
+
options?.erc20PermitParam ? [options.erc20PermitParam] : [],
|
|
189
|
+
getDeadlineTimestampInSeconds(),
|
|
190
|
+
],
|
|
191
|
+
value: isETH ? quoteAmount : 0n,
|
|
192
|
+
}, options?.gasLimit),
|
|
193
|
+
result: {
|
|
194
|
+
make: {
|
|
195
|
+
amount: formatUnits(quoteAmount - parseUnits(spentAmount, inputCurrency.decimals), inputCurrency.decimals),
|
|
196
|
+
currency: inputCurrency,
|
|
197
|
+
direction: 'in',
|
|
198
|
+
price: formatPrice(isBid
|
|
199
|
+
? toPrice(BigInt(makeParam.tick))
|
|
200
|
+
: toPrice(invertTick(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
|
|
201
|
+
},
|
|
202
|
+
spent: {
|
|
203
|
+
amount: spentAmount,
|
|
204
|
+
currency: inputCurrency,
|
|
205
|
+
direction: 'in',
|
|
206
|
+
events: events.map(({ price, spentAmount }) => ({
|
|
207
|
+
price,
|
|
208
|
+
amount: spentAmount,
|
|
209
|
+
})),
|
|
210
|
+
},
|
|
211
|
+
taken: {
|
|
212
|
+
amount: takenAmount,
|
|
213
|
+
currency: outputCurrency,
|
|
214
|
+
direction: 'out',
|
|
215
|
+
events: events.map(({ price, takenAmount }) => ({
|
|
216
|
+
price,
|
|
217
|
+
amount: takenAmount,
|
|
218
|
+
})),
|
|
219
|
+
},
|
|
220
|
+
},
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
//# sourceMappingURL=limit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"limit.js","sourceRoot":"","sources":["../../../../src/calls/market/limit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { createPublicClient, encodeAbiParameters, getAddress, http, isAddress, isAddressEqual, parseUnits, zeroAddress, zeroHash, } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchMarket } from '../../entities/market/apis';
|
|
4
|
+
import { getContractAddresses, getOpenOrders, getPriceNeighborhood, getQuoteToken, } from '../../views';
|
|
5
|
+
import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
|
|
6
|
+
import { CANCEL_ORDER_PARAMS_ABI, CLAIM_ORDER_PARAMS_ABI, MAKE_ORDER_PARAMS_ABI, } from '../../constants/abis/core/params-abi';
|
|
7
|
+
import { buildTransaction } from '../../utils/build-transaction';
|
|
8
|
+
import { getDeadlineTimestampInSeconds } from '../../utils/time';
|
|
9
|
+
export var Action;
|
|
10
|
+
(function (Action) {
|
|
11
|
+
Action[Action["OPEN"] = 0] = "OPEN";
|
|
12
|
+
Action[Action["MAKE"] = 1] = "MAKE";
|
|
13
|
+
Action[Action["LIMIT"] = 2] = "LIMIT";
|
|
14
|
+
Action[Action["TAKE"] = 3] = "TAKE";
|
|
15
|
+
Action[Action["SPEND"] = 4] = "SPEND";
|
|
16
|
+
Action[Action["CLAIM"] = 5] = "CLAIM";
|
|
17
|
+
Action[Action["CANCEL"] = 6] = "CANCEL";
|
|
18
|
+
})(Action || (Action = {}));
|
|
19
|
+
export const placeMarketMakingQuotes = async ({ chainId, userAddress, bidQuotes, askQuotes, baseToken, quoteToken, clearOpenOrders, options, }) => {
|
|
20
|
+
let orderIdsToClaim = options?.orderIdsToClaim || [];
|
|
21
|
+
let orderIdsToCancel = options?.orderIdsToCancel || [];
|
|
22
|
+
if (clearOpenOrders) {
|
|
23
|
+
const openOrders = await getOpenOrders({
|
|
24
|
+
chainId,
|
|
25
|
+
userAddress,
|
|
26
|
+
});
|
|
27
|
+
orderIdsToClaim = openOrders
|
|
28
|
+
.filter(({ claimable }) => Number(claimable.value) > 0)
|
|
29
|
+
.map((order) => order.id);
|
|
30
|
+
orderIdsToCancel = openOrders
|
|
31
|
+
.filter(({ cancelable }) => Number(cancelable.value) > 0)
|
|
32
|
+
.map((order) => order.id);
|
|
33
|
+
}
|
|
34
|
+
const [roundingUpMakeBid, roundingDownMakeAsk] = [
|
|
35
|
+
options?.roundingUpMakeBid ? options.roundingUpMakeBid : false,
|
|
36
|
+
options?.roundingDownMakeAsk ? options.roundingDownMakeAsk : false,
|
|
37
|
+
];
|
|
38
|
+
const publicClient = createPublicClient({
|
|
39
|
+
chain: CHAIN_MAP[chainId],
|
|
40
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
41
|
+
});
|
|
42
|
+
const market = options?.market
|
|
43
|
+
? options.market
|
|
44
|
+
: (await fetchMarket(publicClient, chainId, [baseToken, quoteToken], !!(options && options.useSubgraph))).toJson();
|
|
45
|
+
if (!isAddressEqual(quoteToken, getQuoteToken({ chainId, token0: baseToken, token1: quoteToken }))) {
|
|
46
|
+
throw new Error(`Invalid market: The quote token ${quoteToken} does not match the base token ${baseToken}. Please check the market configuration.`);
|
|
47
|
+
}
|
|
48
|
+
if (!market.bidBook.isOpened && bidQuotes.length > 0) {
|
|
49
|
+
throw new Error(`
|
|
50
|
+
Open the market before placing a limit order.
|
|
51
|
+
import { openMarket } from '@clober/v2-sdk'
|
|
52
|
+
|
|
53
|
+
const transaction = await openMarket({
|
|
54
|
+
chainId: ${chainId},
|
|
55
|
+
inputToken: '${market.quote.address}',
|
|
56
|
+
outputToken: '${market.base.address}',
|
|
57
|
+
})
|
|
58
|
+
`);
|
|
59
|
+
}
|
|
60
|
+
if (!market.askBook.isOpened && askQuotes.length > 0) {
|
|
61
|
+
throw new Error(`
|
|
62
|
+
Open the market before placing a limit order.
|
|
63
|
+
import { openMarket } from '@clober/v2-sdk'
|
|
64
|
+
|
|
65
|
+
const transaction = await openMarket({
|
|
66
|
+
chainId: ${chainId},
|
|
67
|
+
inputToken: '${market.base.address}',
|
|
68
|
+
outputToken: '${market.quote.address}',
|
|
69
|
+
})
|
|
70
|
+
`);
|
|
71
|
+
}
|
|
72
|
+
const provider = options && options.provider && isAddress(options.provider)
|
|
73
|
+
? getAddress(options.provider)
|
|
74
|
+
: zeroAddress;
|
|
75
|
+
const bidMakeParams = bidQuotes.map((quote) => {
|
|
76
|
+
const { normal: { now: { tick: bidTick }, }, } = getPriceNeighborhood({
|
|
77
|
+
chainId,
|
|
78
|
+
price: quote.price,
|
|
79
|
+
currency0: market.quote,
|
|
80
|
+
currency1: market.base,
|
|
81
|
+
});
|
|
82
|
+
return {
|
|
83
|
+
id: BigInt(market.bidBook.id),
|
|
84
|
+
tick: roundingUpMakeBid ? Number(bidTick + 1n) : Number(bidTick),
|
|
85
|
+
quoteAmount: parseUnits(quote.amount, market.quote.decimals),
|
|
86
|
+
provider,
|
|
87
|
+
hookData: zeroHash,
|
|
88
|
+
isNative: isAddressEqual(market.quote.address, zeroAddress),
|
|
89
|
+
};
|
|
90
|
+
});
|
|
91
|
+
const askMakeParams = askQuotes.map((quote) => {
|
|
92
|
+
const { inverted: { now: { tick: askTick }, }, } = getPriceNeighborhood({
|
|
93
|
+
chainId,
|
|
94
|
+
price: quote.price,
|
|
95
|
+
currency0: market.quote,
|
|
96
|
+
currency1: market.base,
|
|
97
|
+
});
|
|
98
|
+
return {
|
|
99
|
+
id: BigInt(market.askBook.id),
|
|
100
|
+
tick: roundingDownMakeAsk ? Number(askTick - 1n) : Number(askTick),
|
|
101
|
+
quoteAmount: parseUnits(quote.amount, market.base.decimals),
|
|
102
|
+
provider,
|
|
103
|
+
hookData: zeroHash,
|
|
104
|
+
isNative: isAddressEqual(market.base.address, zeroAddress),
|
|
105
|
+
};
|
|
106
|
+
});
|
|
107
|
+
const args = {
|
|
108
|
+
address: getContractAddresses({ chainId }).Controller,
|
|
109
|
+
abi: CONTROLLER_ABI,
|
|
110
|
+
account: userAddress,
|
|
111
|
+
functionName: 'execute',
|
|
112
|
+
args: [
|
|
113
|
+
[
|
|
114
|
+
...orderIdsToClaim.map(() => Action.CLAIM),
|
|
115
|
+
...orderIdsToCancel.map(() => Action.CANCEL),
|
|
116
|
+
...[...bidMakeParams].map(() => Action.MAKE),
|
|
117
|
+
...[...askMakeParams].map(() => Action.MAKE),
|
|
118
|
+
],
|
|
119
|
+
[
|
|
120
|
+
...orderIdsToClaim.map((id) => encodeAbiParameters(CLAIM_ORDER_PARAMS_ABI, [
|
|
121
|
+
{ id, hookData: zeroHash },
|
|
122
|
+
])),
|
|
123
|
+
...orderIdsToCancel.map((id) => encodeAbiParameters(CANCEL_ORDER_PARAMS_ABI, [
|
|
124
|
+
{ id, leftQuoteAmount: 0n, hookData: zeroHash },
|
|
125
|
+
])),
|
|
126
|
+
...[...bidMakeParams].map((param) => encodeAbiParameters(MAKE_ORDER_PARAMS_ABI, [
|
|
127
|
+
{
|
|
128
|
+
id: param.id,
|
|
129
|
+
tick: param.tick,
|
|
130
|
+
quoteAmount: param.quoteAmount,
|
|
131
|
+
provider: param.provider,
|
|
132
|
+
hookData: param.hookData,
|
|
133
|
+
},
|
|
134
|
+
])),
|
|
135
|
+
...[...askMakeParams].map((param) => encodeAbiParameters(MAKE_ORDER_PARAMS_ABI, [
|
|
136
|
+
{
|
|
137
|
+
id: param.id,
|
|
138
|
+
tick: param.tick,
|
|
139
|
+
quoteAmount: param.quoteAmount,
|
|
140
|
+
provider: param.provider,
|
|
141
|
+
hookData: param.hookData,
|
|
142
|
+
},
|
|
143
|
+
])),
|
|
144
|
+
],
|
|
145
|
+
[market.base.address, market.quote.address].filter((address) => !isAddressEqual(address, zeroAddress)),
|
|
146
|
+
[],
|
|
147
|
+
[],
|
|
148
|
+
getDeadlineTimestampInSeconds(),
|
|
149
|
+
],
|
|
150
|
+
value: [...bidMakeParams, ...askMakeParams]
|
|
151
|
+
.filter((p) => p.isNative)
|
|
152
|
+
.reduce((acc, p) => acc + BigInt(p.quoteAmount), 0n),
|
|
153
|
+
};
|
|
154
|
+
return buildTransaction(publicClient, args, options?.gasLimit);
|
|
155
|
+
};
|
|
156
|
+
//# sourceMappingURL=make.js.map
|