@1stdex/first-sdk 1.0.0-rc.1
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 +11 -0
- package/dist/cjs/calls/approval/market.js +136 -0
- package/dist/cjs/calls/approval/market.js.map +1 -0
- package/dist/cjs/calls/approval/open-order.js +50 -0
- package/dist/cjs/calls/approval/open-order.js.map +1 -0
- package/dist/cjs/calls/approval/order.js +45 -0
- package/dist/cjs/calls/approval/order.js.map +1 -0
- package/dist/cjs/calls/approval/token.js +167 -0
- package/dist/cjs/calls/approval/token.js.map +1 -0
- package/dist/cjs/calls/index.js +31 -0
- package/dist/cjs/calls/index.js.map +1 -0
- package/dist/cjs/calls/market/cancel.js +65 -0
- package/dist/cjs/calls/market/cancel.js.map +1 -0
- package/dist/cjs/calls/market/claim.js +64 -0
- package/dist/cjs/calls/market/claim.js.map +1 -0
- package/dist/cjs/calls/market/limit.js +187 -0
- package/dist/cjs/calls/market/limit.js.map +1 -0
- package/dist/cjs/calls/market/make.js +164 -0
- package/dist/cjs/calls/market/make.js.map +1 -0
- package/dist/cjs/calls/market/market.js +171 -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/vault/deposit-to-vault.js +24 -0
- package/dist/cjs/calls/vault/deposit-to-vault.js.map +1 -0
- package/dist/cjs/calls/vault/index.js +12 -0
- package/dist/cjs/calls/vault/index.js.map +1 -0
- package/dist/cjs/calls/vault/remove-vault.js +24 -0
- package/dist/cjs/calls/vault/remove-vault.js.map +1 -0
- package/dist/cjs/calls/vault/set-vault.js +24 -0
- package/dist/cjs/calls/vault/set-vault.js.map +1 -0
- package/dist/cjs/calls/vault/withdraw-from-vault.js +24 -0
- package/dist/cjs/calls/vault/withdraw-from-vault.js.map +1 -0
- package/dist/cjs/constants/abis/core/book-manager-abi.js +1211 -0
- package/dist/cjs/constants/abis/core/book-manager-abi.js.map +1 -0
- package/dist/cjs/constants/abis/core/book-viewer-abi.js +321 -0
- package/dist/cjs/constants/abis/core/book-viewer-abi.js.map +1 -0
- package/dist/cjs/constants/abis/core/controller-abi.js +613 -0
- package/dist/cjs/constants/abis/core/controller-abi.js.map +1 -0
- package/dist/cjs/constants/abis/core/params-abi.js +64 -0
- package/dist/cjs/constants/abis/core/params-abi.js.map +1 -0
- package/dist/cjs/constants/chain-configs/addresses.js +18 -0
- package/dist/cjs/constants/chain-configs/addresses.js.map +1 -0
- package/dist/cjs/constants/chain-configs/chain.js +23 -0
- package/dist/cjs/constants/chain-configs/chain.js.map +1 -0
- package/dist/cjs/constants/chain-configs/currency.js +24 -0
- package/dist/cjs/constants/chain-configs/currency.js.map +1 -0
- package/dist/cjs/constants/chain-configs/fee.js +14 -0
- package/dist/cjs/constants/chain-configs/fee.js.map +1 -0
- package/dist/cjs/constants/chain-configs/subgraph.js +27 -0
- package/dist/cjs/constants/chain-configs/subgraph.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 +7 -0
- package/dist/cjs/constants/price.js.map +1 -0
- package/dist/cjs/constants/tick.js +6 -0
- package/dist/cjs/constants/tick.js.map +1 -0
- package/dist/cjs/entities/analytics/apis/index.js +209 -0
- package/dist/cjs/entities/analytics/apis/index.js.map +1 -0
- package/dist/cjs/entities/analytics/types.js +3 -0
- 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/entities/book/model.js +197 -0
- package/dist/cjs/entities/book/model.js.map +1 -0
- package/dist/cjs/entities/book/types.js +3 -0
- package/dist/cjs/entities/book/types.js.map +1 -0
- package/dist/cjs/entities/book/utils/book-id.js +23 -0
- 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 +123 -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 +62 -0
- package/dist/cjs/entities/currency/apis/total-supply.js.map +1 -0
- package/dist/cjs/entities/currency/types.js +3 -0
- package/dist/cjs/entities/currency/types.js.map +1 -0
- package/dist/cjs/entities/fee-policy/model.js +92 -0
- package/dist/cjs/entities/fee-policy/model.js.map +1 -0
- package/dist/cjs/entities/market/apis/chart-log.js +171 -0
- package/dist/cjs/entities/market/apis/chart-log.js.map +1 -0
- package/dist/cjs/entities/market/apis/index.js +35 -0
- package/dist/cjs/entities/market/apis/index.js.map +1 -0
- package/dist/cjs/entities/market/apis/price.js +65 -0
- package/dist/cjs/entities/market/apis/price.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/entities/market/model.js +185 -0
- package/dist/cjs/entities/market/model.js.map +1 -0
- package/dist/cjs/entities/market/types.js +3 -0
- package/dist/cjs/entities/market/types.js.map +1 -0
- package/dist/cjs/entities/market/utils/market-id.js +30 -0
- package/dist/cjs/entities/market/utils/market-id.js.map +1 -0
- package/dist/cjs/entities/open-order/apis/index.js +195 -0
- package/dist/cjs/entities/open-order/apis/index.js.map +1 -0
- package/dist/cjs/entities/open-order/apis/operator.js +15 -0
- package/dist/cjs/entities/open-order/apis/operator.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/vault/types.js +3 -0
- package/dist/cjs/entities/vault/types.js.map +1 -0
- package/dist/cjs/index.js +27 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/types/default-options.js +3 -0
- package/dist/cjs/types/default-options.js.map +1 -0
- package/dist/cjs/types/index.js +21 -0
- 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 +16 -0
- package/dist/cjs/utils/bigint.js.map +1 -0
- package/dist/cjs/utils/build-transaction.js +27 -0
- package/dist/cjs/utils/build-transaction.js.map +1 -0
- package/dist/cjs/utils/conversion.js +17 -0
- package/dist/cjs/utils/conversion.js.map +1 -0
- package/dist/cjs/utils/index.js +18 -0
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/math.js +58 -0
- package/dist/cjs/utils/math.js.map +1 -0
- package/dist/cjs/utils/prices.js +56 -0
- package/dist/cjs/utils/prices.js.map +1 -0
- package/dist/cjs/utils/tick.js +117 -0
- package/dist/cjs/utils/tick.js.map +1 -0
- package/dist/cjs/utils/time.js +14 -0
- package/dist/cjs/utils/time.js.map +1 -0
- package/dist/cjs/utils/unit-size.js +8 -0
- package/dist/cjs/utils/unit-size.js.map +1 -0
- package/dist/cjs/views/address.js +9 -0
- package/dist/cjs/views/address.js.map +1 -0
- package/dist/cjs/views/analytics.js +25 -0
- package/dist/cjs/views/analytics.js.map +1 -0
- package/dist/cjs/views/currency.js +22 -0
- package/dist/cjs/views/currency.js.map +1 -0
- package/dist/cjs/views/index.js +39 -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 +40 -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/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/vault.js +24 -0
- package/dist/cjs/views/vault.js.map +1 -0
- package/dist/esm/calls/approval/market.js +186 -0
- package/dist/esm/calls/approval/market.js.map +1 -0
- package/dist/esm/calls/approval/open-order.js +71 -0
- package/dist/esm/calls/approval/open-order.js.map +1 -0
- package/dist/esm/calls/approval/order.js +70 -0
- package/dist/esm/calls/approval/order.js.map +1 -0
- package/dist/esm/calls/approval/token.js +212 -0
- package/dist/esm/calls/approval/token.js.map +1 -0
- package/dist/esm/calls/index.js +12 -0
- package/dist/esm/calls/index.js.map +1 -0
- package/dist/esm/calls/market/cancel.js +108 -0
- package/dist/esm/calls/market/cancel.js.map +1 -0
- package/dist/esm/calls/market/claim.js +107 -0
- package/dist/esm/calls/market/claim.js.map +1 -0
- package/dist/esm/calls/market/limit.js +229 -0
- package/dist/esm/calls/market/limit.js.map +1 -0
- package/dist/esm/calls/market/make.js +160 -0
- package/dist/esm/calls/market/make.js.map +1 -0
- package/dist/esm/calls/market/market.js +202 -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/vault/deposit-to-vault.js +39 -0
- package/dist/esm/calls/vault/deposit-to-vault.js.map +1 -0
- package/dist/esm/calls/vault/index.js +5 -0
- package/dist/esm/calls/vault/index.js.map +1 -0
- package/dist/esm/calls/vault/remove-vault.js +37 -0
- package/dist/esm/calls/vault/remove-vault.js.map +1 -0
- package/dist/esm/calls/vault/set-vault.js +39 -0
- package/dist/esm/calls/vault/set-vault.js.map +1 -0
- package/dist/esm/calls/vault/withdraw-from-vault.js +39 -0
- package/dist/esm/calls/vault/withdraw-from-vault.js.map +1 -0
- package/dist/esm/constants/abis/core/book-manager-abi.js +1208 -0
- package/dist/esm/constants/abis/core/book-manager-abi.js.map +1 -0
- package/dist/esm/constants/abis/core/book-viewer-abi.js +318 -0
- package/dist/esm/constants/abis/core/book-viewer-abi.js.map +1 -0
- package/dist/esm/constants/abis/core/controller-abi.js +610 -0
- package/dist/esm/constants/abis/core/controller-abi.js.map +1 -0
- package/dist/esm/constants/abis/core/params-abi.js +61 -0
- package/dist/esm/constants/abis/core/params-abi.js.map +1 -0
- package/dist/esm/constants/chain-configs/addresses.js +15 -0
- package/dist/esm/constants/chain-configs/addresses.js.map +1 -0
- package/dist/esm/constants/chain-configs/chain.js +22 -0
- package/dist/esm/constants/chain-configs/chain.js.map +1 -0
- package/dist/esm/constants/chain-configs/currency.js +23 -0
- package/dist/esm/constants/chain-configs/currency.js.map +1 -0
- package/dist/esm/constants/chain-configs/fee.js +11 -0
- package/dist/esm/constants/chain-configs/fee.js.map +1 -0
- package/dist/esm/constants/chain-configs/subgraph.js +23 -0
- package/dist/esm/constants/chain-configs/subgraph.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 +4 -0
- package/dist/esm/constants/price.js.map +1 -0
- package/dist/esm/constants/tick.js +3 -0
- package/dist/esm/constants/tick.js.map +1 -0
- package/dist/esm/entities/analytics/apis/index.js +206 -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/entities/book/model.js +195 -0
- 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/entities/book/utils/book-id.js +19 -0
- 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 +118 -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 +57 -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/entities/fee-policy/model.js +88 -0
- package/dist/esm/entities/fee-policy/model.js.map +1 -0
- package/dist/esm/entities/market/apis/chart-log.js +167 -0
- package/dist/esm/entities/market/apis/chart-log.js.map +1 -0
- package/dist/esm/entities/market/apis/index.js +30 -0
- package/dist/esm/entities/market/apis/index.js.map +1 -0
- package/dist/esm/entities/market/apis/price.js +86 -0
- package/dist/esm/entities/market/apis/price.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/entities/market/model.js +183 -0
- 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/entities/market/utils/market-id.js +28 -0
- package/dist/esm/entities/market/utils/market-id.js.map +1 -0
- package/dist/esm/entities/open-order/apis/index.js +192 -0
- package/dist/esm/entities/open-order/apis/index.js.map +1 -0
- package/dist/esm/entities/open-order/apis/operator.js +11 -0
- package/dist/esm/entities/open-order/apis/operator.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/vault/types.js +2 -0
- package/dist/esm/entities/vault/types.js.map +1 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/types/default-options.js +2 -0
- package/dist/esm/types/default-options.js.map +1 -0
- package/dist/esm/types/index.js +17 -0
- 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 +9 -0
- package/dist/esm/utils/bigint.js.map +1 -0
- package/dist/esm/utils/build-transaction.js +23 -0
- package/dist/esm/utils/build-transaction.js.map +1 -0
- package/dist/esm/utils/conversion.js +12 -0
- 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/math.js +79 -0
- package/dist/esm/utils/math.js.map +1 -0
- package/dist/esm/utils/prices.js +50 -0
- package/dist/esm/utils/prices.js.map +1 -0
- package/dist/esm/utils/tick.js +110 -0
- package/dist/esm/utils/tick.js.map +1 -0
- package/dist/esm/utils/time.js +8 -0
- package/dist/esm/utils/time.js.map +1 -0
- package/dist/esm/utils/unit-size.js +4 -0
- package/dist/esm/utils/unit-size.js.map +1 -0
- package/dist/esm/views/address.js +17 -0
- package/dist/esm/views/address.js.map +1 -0
- package/dist/esm/views/analytics.js +17 -0
- package/dist/esm/views/analytics.js.map +1 -0
- package/dist/esm/views/currency.js +15 -0
- package/dist/esm/views/currency.js.map +1 -0
- package/dist/esm/views/index.js +9 -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 +62 -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/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/vault.js +35 -0
- package/dist/esm/views/vault.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/types/calls/approval/market.d.ts +43 -0
- package/dist/types/calls/approval/market.d.ts.map +1 -0
- 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/calls/approval/order.d.ts +39 -0
- package/dist/types/calls/approval/order.d.ts.map +1 -0
- package/dist/types/calls/approval/token.d.ts +41 -0
- package/dist/types/calls/approval/token.d.ts.map +1 -0
- package/dist/types/calls/index.d.ts +12 -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 +90 -0
- package/dist/types/calls/market/limit.d.ts.map +1 -0
- package/dist/types/calls/market/make.d.ts +37 -0
- package/dist/types/calls/market/make.d.ts.map +1 -0
- package/dist/types/calls/market/market.d.ts +69 -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/vault/deposit-to-vault.d.ts +29 -0
- package/dist/types/calls/vault/deposit-to-vault.d.ts.map +1 -0
- package/dist/types/calls/vault/index.d.ts +5 -0
- package/dist/types/calls/vault/index.d.ts.map +1 -0
- package/dist/types/calls/vault/remove-vault.d.ts +26 -0
- package/dist/types/calls/vault/remove-vault.d.ts.map +1 -0
- package/dist/types/calls/vault/set-vault.d.ts +29 -0
- package/dist/types/calls/vault/set-vault.d.ts.map +1 -0
- package/dist/types/calls/vault/withdraw-from-vault.d.ts +29 -0
- package/dist/types/calls/vault/withdraw-from-vault.d.ts.map +1 -0
- package/dist/types/constants/abis/core/book-manager-abi.d.ts +1633 -0
- package/dist/types/constants/abis/core/book-manager-abi.d.ts.map +1 -0
- package/dist/types/constants/abis/core/book-viewer-abi.d.ts +243 -0
- package/dist/types/constants/abis/core/book-viewer-abi.d.ts.map +1 -0
- package/dist/types/constants/abis/core/controller-abi.d.ts +970 -0
- package/dist/types/constants/abis/core/controller-abi.d.ts.map +1 -0
- 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/constants/chain-configs/addresses.d.ts +9 -0
- package/dist/types/constants/chain-configs/addresses.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/chain.d.ts +10 -0
- package/dist/types/constants/chain-configs/chain.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/currency.d.ts +6 -0
- package/dist/types/constants/chain-configs/currency.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/fee.d.ts +9 -0
- package/dist/types/constants/chain-configs/fee.d.ts.map +1 -0
- package/dist/types/constants/chain-configs/subgraph.d.ts +8 -0
- package/dist/types/constants/chain-configs/subgraph.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 +4 -0
- package/dist/types/constants/price.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/entities/analytics/apis/index.d.ts +12 -0
- package/dist/types/entities/analytics/apis/index.d.ts.map +1 -0
- package/dist/types/entities/analytics/types.d.ts +57 -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/entities/book/model.d.ts +50 -0
- 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/entities/book/utils/book-id.d.ts +3 -0
- package/dist/types/entities/book/utils/book-id.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/allowance.d.ts +3 -0
- package/dist/types/entities/currency/apis/allowance.d.ts.map +1 -0
- package/dist/types/entities/currency/apis/approval.d.ts +4 -0
- 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/entities/fee-policy/model.d.ts +15 -0
- package/dist/types/entities/fee-policy/model.d.ts.map +1 -0
- package/dist/types/entities/market/apis/chart-log.d.ts +9 -0
- package/dist/types/entities/market/apis/chart-log.d.ts.map +1 -0
- package/dist/types/entities/market/apis/index.d.ts +7 -0
- package/dist/types/entities/market/apis/index.d.ts.map +1 -0
- package/dist/types/entities/market/apis/price.d.ts +32 -0
- package/dist/types/entities/market/apis/price.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/entities/market/model.d.ts +58 -0
- 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/entities/market/utils/market-id.d.ts +7 -0
- package/dist/types/entities/market/utils/market-id.d.ts.map +1 -0
- package/dist/types/entities/open-order/apis/index.d.ts +9 -0
- package/dist/types/entities/open-order/apis/index.d.ts.map +1 -0
- package/dist/types/entities/open-order/apis/operator.d.ts +4 -0
- package/dist/types/entities/open-order/apis/operator.d.ts.map +1 -0
- package/dist/types/entities/open-order/types.d.ts +22 -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/vault/types.d.ts +4 -0
- package/dist/types/entities/vault/types.d.ts.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.d.ts.map +1 -0
- 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 +5 -0
- package/dist/types/utils/bigint.d.ts.map +1 -0
- package/dist/types/utils/build-transaction.d.ts +4 -0
- package/dist/types/utils/build-transaction.d.ts.map +1 -0
- package/dist/types/utils/conversion.d.ts +3 -0
- 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/math.d.ts +4 -0
- package/dist/types/utils/math.d.ts.map +1 -0
- package/dist/types/utils/prices.d.ts +14 -0
- package/dist/types/utils/prices.d.ts.map +1 -0
- package/dist/types/utils/tick.d.ts +5 -0
- package/dist/types/utils/tick.d.ts.map +1 -0
- package/dist/types/utils/time.d.ts +4 -0
- package/dist/types/utils/time.d.ts.map +1 -0
- package/dist/types/utils/unit-size.d.ts +4 -0
- package/dist/types/utils/unit-size.d.ts.map +1 -0
- package/dist/types/views/address.d.ts +21 -0
- package/dist/types/views/address.d.ts.map +1 -0
- package/dist/types/views/analytics.d.ts +21 -0
- package/dist/types/views/analytics.d.ts.map +1 -0
- package/dist/types/views/currency.d.ts +20 -0
- package/dist/types/views/currency.d.ts.map +1 -0
- package/dist/types/views/index.d.ts +9 -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 +57 -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/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/vault.d.ts +25 -0
- package/dist/types/views/vault.d.ts.map +1 -0
- package/package.json +52 -0
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getPriceNeighborhood = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
const index_1 = require("./index");
|
|
7
|
+
const getPriceNeighborhood = ({ chainId, price, currency0, currency1, }) => {
|
|
8
|
+
const quoteTokenAddress = (0, index_1.getQuoteToken)({
|
|
9
|
+
chainId,
|
|
10
|
+
token0: currency0.address,
|
|
11
|
+
token1: currency1.address,
|
|
12
|
+
});
|
|
13
|
+
const quoteCurrency = (0, viem_1.isAddressEqual)(quoteTokenAddress, currency0.address)
|
|
14
|
+
? currency0
|
|
15
|
+
: currency1;
|
|
16
|
+
const baseCurrency = (0, viem_1.isAddressEqual)(quoteTokenAddress, currency0.address)
|
|
17
|
+
? currency1
|
|
18
|
+
: currency0;
|
|
19
|
+
const { roundingDownTick, roundingUpTick } = (0, utils_1.parsePrice)(Number(price), quoteCurrency.decimals, baseCurrency.decimals);
|
|
20
|
+
const bidBookTick = roundingDownTick;
|
|
21
|
+
const askBookTick = (0, utils_1.invertTick)(roundingUpTick);
|
|
22
|
+
return {
|
|
23
|
+
normal: {
|
|
24
|
+
nextUp: {
|
|
25
|
+
tick: bidBookTick + 2n,
|
|
26
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick + 2n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
27
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick + 2n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
28
|
+
},
|
|
29
|
+
up: {
|
|
30
|
+
tick: bidBookTick + 1n,
|
|
31
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick + 1n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
32
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick + 1n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
33
|
+
},
|
|
34
|
+
now: {
|
|
35
|
+
tick: bidBookTick,
|
|
36
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick), quoteCurrency.decimals, baseCurrency.decimals),
|
|
37
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick), quoteCurrency.decimals, baseCurrency.decimals),
|
|
38
|
+
},
|
|
39
|
+
down: {
|
|
40
|
+
tick: bidBookTick - 1n,
|
|
41
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick - 1n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
42
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick - 1n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
43
|
+
},
|
|
44
|
+
nextDown: {
|
|
45
|
+
tick: bidBookTick - 2n,
|
|
46
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick - 2n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
47
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)(bidBookTick - 2n), quoteCurrency.decimals, baseCurrency.decimals),
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
inverted: {
|
|
51
|
+
nextUp: {
|
|
52
|
+
tick: askBookTick + 2n,
|
|
53
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(askBookTick + 2n), baseCurrency.decimals, quoteCurrency.decimals),
|
|
54
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(askBookTick + 2n)), quoteCurrency.decimals, baseCurrency.decimals),
|
|
55
|
+
},
|
|
56
|
+
up: {
|
|
57
|
+
tick: askBookTick + 1n,
|
|
58
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(askBookTick + 1n), baseCurrency.decimals, quoteCurrency.decimals),
|
|
59
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(askBookTick + 1n)), quoteCurrency.decimals, baseCurrency.decimals),
|
|
60
|
+
},
|
|
61
|
+
now: {
|
|
62
|
+
tick: askBookTick,
|
|
63
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(askBookTick), baseCurrency.decimals, quoteCurrency.decimals),
|
|
64
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(askBookTick)), quoteCurrency.decimals, baseCurrency.decimals),
|
|
65
|
+
},
|
|
66
|
+
down: {
|
|
67
|
+
tick: askBookTick - 1n,
|
|
68
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(askBookTick - 1n), baseCurrency.decimals, quoteCurrency.decimals),
|
|
69
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(askBookTick - 1n)), quoteCurrency.decimals, baseCurrency.decimals),
|
|
70
|
+
},
|
|
71
|
+
nextDown: {
|
|
72
|
+
tick: askBookTick - 2n,
|
|
73
|
+
price: (0, utils_1.formatPrice)((0, utils_1.toPrice)(askBookTick - 2n), baseCurrency.decimals, quoteCurrency.decimals),
|
|
74
|
+
marketPrice: (0, utils_1.formatPrice)((0, utils_1.toPrice)((0, utils_1.invertTick)(askBookTick - 2n)), quoteCurrency.decimals, baseCurrency.decimals),
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
exports.getPriceNeighborhood = getPriceNeighborhood;
|
|
80
|
+
//# sourceMappingURL=tick.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tick.js","sourceRoot":"","sources":["../../../src/views/tick.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getVault = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const chain_1 = require("../constants/chain-configs/chain");
|
|
6
|
+
const addresses_1 = require("../constants/chain-configs/addresses");
|
|
7
|
+
const book_manager_abi_1 = require("../constants/abis/core/book-manager-abi");
|
|
8
|
+
const getVault = async ({ chainId, tokenAddress, options, }) => {
|
|
9
|
+
const publicClient = (0, viem_1.createPublicClient)({
|
|
10
|
+
chain: chain_1.CHAIN_MAP[chainId],
|
|
11
|
+
transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
|
|
12
|
+
});
|
|
13
|
+
const vaultAddress = await publicClient.readContract({
|
|
14
|
+
address: addresses_1.CONTRACT_ADDRESSES[chainId].BookManager,
|
|
15
|
+
abi: book_manager_abi_1.BOOK_MANAGER_ABI,
|
|
16
|
+
functionName: 'getVault',
|
|
17
|
+
args: [tokenAddress],
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
address: vaultAddress,
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
exports.getVault = getVault;
|
|
24
|
+
//# sourceMappingURL=vault.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vault.js","sourceRoot":"","sources":["../../../src/views/vault.ts"],"names":[],"mappings":";;;AAAA,+BAAgD;AAEhD,4DAAwE;AACxE,oEAA0E;AAC1E,8EAA2E;AAkBpE,MAAM,QAAQ,GAAG,KAAK,EAAE,EAC7B,OAAO,EACP,YAAY,EACZ,OAAO,GAOR,EAAkB,EAAE;IACnB,MAAM,YAAY,GAAG,IAAA,yBAAkB,EAAC;QACtC,KAAK,EAAE,iBAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,WAAI,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAA,WAAI,GAAE;KAC3D,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC;QACnD,OAAO,EAAE,8BAAkB,CAAC,OAAO,CAAE,CAAC,WAAW;QACjD,GAAG,EAAE,mCAAgB;QACrB,YAAY,EAAE,UAAU;QACxB,IAAI,EAAE,CAAC,YAAY,CAAC;KACrB,CAAC,CAAC;IAEH,OAAO;QACL,OAAO,EAAE,YAAY;KACtB,CAAC;AACJ,CAAC,CAAC;AA1BW,QAAA,QAAQ,YA0BnB"}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { createPublicClient, http } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchCurrency } from '../../entities/currency/apis';
|
|
4
|
+
import { fetchAllowance } from '../../entities/currency/apis/allowance';
|
|
5
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
6
|
+
import { getMarketId } from '../../entities/market/utils/market-id';
|
|
7
|
+
import { getVault } from '../../views/vault';
|
|
8
|
+
/**
|
|
9
|
+
* @dev This function relates with `viem` dependency
|
|
10
|
+
* Approves maximum allowance for all tokens in a market for both controller and book manager.
|
|
11
|
+
* This includes:
|
|
12
|
+
* - Max allowance for both market tokens (base and quote) to controller
|
|
13
|
+
* - Max allowance for both market token vaults to book manager
|
|
14
|
+
*
|
|
15
|
+
* Only adds allowance if current allowance is below threshold (max - 1 million tokens).
|
|
16
|
+
*
|
|
17
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
18
|
+
* @param {WalletClient} walletClient The wallet client.
|
|
19
|
+
* @param {`0x${string}`} token0 The first token address in the market.
|
|
20
|
+
* @param {`0x${string}`} token1 The second token address in the market.
|
|
21
|
+
* @param options
|
|
22
|
+
* @param options.rpcUrl The RPC URL of the blockchain.
|
|
23
|
+
* @returns {Promise<`0x${string}`[]>} Promise resolving to array of transaction hashes. Empty array if no approvals needed.
|
|
24
|
+
* @example
|
|
25
|
+
* import { approveAllForMarket } from '@clober/v2-sdk'
|
|
26
|
+
*
|
|
27
|
+
* const walletClient = createWalletClient({
|
|
28
|
+
* chain: arbitrumSepolia,
|
|
29
|
+
* account: mnemonicToAccount('legal ...'),
|
|
30
|
+
* transport: http(),
|
|
31
|
+
* })
|
|
32
|
+
*
|
|
33
|
+
* const hashes = await approveAllForMarket({
|
|
34
|
+
* chainId: 421614,
|
|
35
|
+
* walletClient,
|
|
36
|
+
* token0: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
|
|
37
|
+
* token1: '0x0000000000000000000000000000000000000000',
|
|
38
|
+
* })
|
|
39
|
+
*/
|
|
40
|
+
export const approveAllForMarket = async ({ chainId, walletClient, token0, token1, options, }) => {
|
|
41
|
+
if (!walletClient.account) {
|
|
42
|
+
throw new Error('Account is not found');
|
|
43
|
+
}
|
|
44
|
+
const publicClient = createPublicClient({
|
|
45
|
+
chain: CHAIN_MAP[chainId],
|
|
46
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
47
|
+
});
|
|
48
|
+
// Get market tokens (base and quote)
|
|
49
|
+
const { baseTokenAddress, quoteTokenAddress } = getMarketId(chainId, [
|
|
50
|
+
token0,
|
|
51
|
+
token1,
|
|
52
|
+
]);
|
|
53
|
+
// Get contract addresses
|
|
54
|
+
const controllerAddress = CONTRACT_ADDRESSES[chainId].Controller;
|
|
55
|
+
const bookManagerAddress = CONTRACT_ADDRESSES[chainId].BookManager;
|
|
56
|
+
// Fetch currencies and vaults
|
|
57
|
+
const [baseCurrency, quoteCurrency, baseVault, quoteVault] = await Promise.all([
|
|
58
|
+
fetchCurrency(publicClient, chainId, baseTokenAddress),
|
|
59
|
+
fetchCurrency(publicClient, chainId, quoteTokenAddress),
|
|
60
|
+
getVault({
|
|
61
|
+
chainId,
|
|
62
|
+
tokenAddress: baseTokenAddress,
|
|
63
|
+
...(options?.rpcUrl && { options: { rpcUrl: options.rpcUrl } }),
|
|
64
|
+
}),
|
|
65
|
+
getVault({
|
|
66
|
+
chainId,
|
|
67
|
+
tokenAddress: quoteTokenAddress,
|
|
68
|
+
...(options?.rpcUrl && { options: { rpcUrl: options.rpcUrl } }),
|
|
69
|
+
}),
|
|
70
|
+
]);
|
|
71
|
+
// Calculate max value and threshold (max - 1 million tokens)
|
|
72
|
+
const maxValue = 2n ** 256n - 1n;
|
|
73
|
+
const oneMillionBase = 10n ** BigInt(baseCurrency.decimals) * 1000000n;
|
|
74
|
+
const oneMillionQuote = 10n ** BigInt(quoteCurrency.decimals) * 1000000n;
|
|
75
|
+
const baseThreshold = maxValue - oneMillionBase;
|
|
76
|
+
const quoteThreshold = maxValue - oneMillionQuote;
|
|
77
|
+
// Check current allowances
|
|
78
|
+
const [baseToControllerAllowance, quoteToControllerAllowance, baseVaultToBookManagerAllowance, quoteVaultToBookManagerAllowance,] = await Promise.all([
|
|
79
|
+
fetchAllowance(publicClient, baseTokenAddress, walletClient.account.address, controllerAddress),
|
|
80
|
+
fetchAllowance(publicClient, quoteTokenAddress, walletClient.account.address, controllerAddress),
|
|
81
|
+
fetchAllowance(publicClient, baseVault.address, walletClient.account.address, bookManagerAddress),
|
|
82
|
+
fetchAllowance(publicClient, quoteVault.address, walletClient.account.address, bookManagerAddress),
|
|
83
|
+
]);
|
|
84
|
+
const approvalAbi = [
|
|
85
|
+
{
|
|
86
|
+
inputs: [
|
|
87
|
+
{
|
|
88
|
+
internalType: 'address',
|
|
89
|
+
name: 'spender',
|
|
90
|
+
type: 'address',
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
internalType: 'uint256',
|
|
94
|
+
name: 'value',
|
|
95
|
+
type: 'uint256',
|
|
96
|
+
},
|
|
97
|
+
],
|
|
98
|
+
name: 'approve',
|
|
99
|
+
outputs: [
|
|
100
|
+
{
|
|
101
|
+
internalType: 'bool',
|
|
102
|
+
name: '',
|
|
103
|
+
type: 'bool',
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
stateMutability: 'nonpayable',
|
|
107
|
+
type: 'function',
|
|
108
|
+
},
|
|
109
|
+
];
|
|
110
|
+
const transactionHashes = [];
|
|
111
|
+
// Approve base token to controller if needed
|
|
112
|
+
if (baseToControllerAllowance < baseThreshold) {
|
|
113
|
+
// Simulate the contract call first to validate it will succeed
|
|
114
|
+
const { request } = await publicClient.simulateContract({
|
|
115
|
+
account: walletClient.account,
|
|
116
|
+
chain: CHAIN_MAP[chainId],
|
|
117
|
+
address: baseTokenAddress,
|
|
118
|
+
abi: approvalAbi,
|
|
119
|
+
functionName: 'approve',
|
|
120
|
+
args: [controllerAddress, maxValue],
|
|
121
|
+
});
|
|
122
|
+
const hash = await walletClient.writeContract(request);
|
|
123
|
+
transactionHashes.push(hash);
|
|
124
|
+
// Wait for transaction confirmation to ensure nonce is updated
|
|
125
|
+
await publicClient.waitForTransactionReceipt({ hash });
|
|
126
|
+
// Wait 1 second before proceeding (to avoid nonce issues)
|
|
127
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
128
|
+
}
|
|
129
|
+
// Approve quote token to controller if needed
|
|
130
|
+
if (quoteToControllerAllowance < quoteThreshold) {
|
|
131
|
+
// Simulate the contract call first to validate it will succeed
|
|
132
|
+
const { request } = await publicClient.simulateContract({
|
|
133
|
+
account: walletClient.account,
|
|
134
|
+
chain: CHAIN_MAP[chainId],
|
|
135
|
+
address: quoteTokenAddress,
|
|
136
|
+
abi: approvalAbi,
|
|
137
|
+
functionName: 'approve',
|
|
138
|
+
args: [controllerAddress, maxValue],
|
|
139
|
+
});
|
|
140
|
+
const hash = await walletClient.writeContract(request);
|
|
141
|
+
transactionHashes.push(hash);
|
|
142
|
+
// Wait for transaction confirmation to ensure nonce is updated
|
|
143
|
+
await publicClient.waitForTransactionReceipt({ hash });
|
|
144
|
+
// Wait 1 second before proceeding (to avoid nonce issues)
|
|
145
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
146
|
+
}
|
|
147
|
+
// Approve base vault to book manager if needed
|
|
148
|
+
if (baseVaultToBookManagerAllowance < baseThreshold) {
|
|
149
|
+
// Simulate the contract call first to validate it will succeed
|
|
150
|
+
const { request } = await publicClient.simulateContract({
|
|
151
|
+
account: walletClient.account,
|
|
152
|
+
chain: CHAIN_MAP[chainId],
|
|
153
|
+
address: baseVault.address,
|
|
154
|
+
abi: approvalAbi,
|
|
155
|
+
functionName: 'approve',
|
|
156
|
+
args: [bookManagerAddress, maxValue],
|
|
157
|
+
});
|
|
158
|
+
const hash = await walletClient.writeContract(request);
|
|
159
|
+
transactionHashes.push(hash);
|
|
160
|
+
// Wait for transaction confirmation to ensure nonce is updated
|
|
161
|
+
await publicClient.waitForTransactionReceipt({ hash });
|
|
162
|
+
// Wait 1 second before proceeding (to avoid nonce issues)
|
|
163
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
164
|
+
}
|
|
165
|
+
// Approve quote vault to book manager if needed
|
|
166
|
+
if (quoteVaultToBookManagerAllowance < quoteThreshold) {
|
|
167
|
+
// Simulate the contract call first to validate it will succeed
|
|
168
|
+
const { request } = await publicClient.simulateContract({
|
|
169
|
+
account: walletClient.account,
|
|
170
|
+
chain: CHAIN_MAP[chainId],
|
|
171
|
+
address: quoteVault.address,
|
|
172
|
+
abi: approvalAbi,
|
|
173
|
+
functionName: 'approve',
|
|
174
|
+
args: [bookManagerAddress, maxValue],
|
|
175
|
+
});
|
|
176
|
+
const hash = await walletClient.writeContract(request);
|
|
177
|
+
transactionHashes.push(hash);
|
|
178
|
+
// Wait for transaction confirmation to ensure nonce is updated
|
|
179
|
+
await publicClient.waitForTransactionReceipt({ hash });
|
|
180
|
+
// Wait 1 second before proceeding (to avoid nonce issues)
|
|
181
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
182
|
+
}
|
|
183
|
+
// Return all transaction hashes (executed sequentially with proper nonce management)
|
|
184
|
+
return transactionHashes;
|
|
185
|
+
};
|
|
186
|
+
//# sourceMappingURL=market.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"market.js","sourceRoot":"","sources":["../../../../src/calls/approval/market.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { createPublicClient, http } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { fetchIsApprovedForAll } from '../../entities/currency/apis/approval';
|
|
4
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
5
|
+
/**
|
|
6
|
+
* @dev This function relates with `viem` dependency
|
|
7
|
+
* Sets approval of all open orders for the specified account on the given chain.
|
|
8
|
+
*
|
|
9
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
10
|
+
* @param {WalletClient} walletClient The wallet client.
|
|
11
|
+
* @param {Object} [options] Optional parameters for setting approval.
|
|
12
|
+
* @param {string} options.rpcUrl The RPC URL to use for executing the transaction.
|
|
13
|
+
* @returns {Promise<`0x${string}` | undefined>} Promise resolving to the transaction hash. If the account is already approved for all, the promise resolves to `undefined`.
|
|
14
|
+
* @example
|
|
15
|
+
* import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
|
|
16
|
+
* import { mnemonicToAccount } from 'viem/accounts'
|
|
17
|
+
*
|
|
18
|
+
* const walletClient = createWalletClient({
|
|
19
|
+
* chain: arbitrumSepolia,
|
|
20
|
+
* account: mnemonicToAccount('legal ...'),
|
|
21
|
+
* transport: http(),
|
|
22
|
+
* })
|
|
23
|
+
*
|
|
24
|
+
* const hash = await setApprovalOfOpenOrdersForAll({
|
|
25
|
+
* chainId: 421614,
|
|
26
|
+
* walletClient
|
|
27
|
+
* })
|
|
28
|
+
*/
|
|
29
|
+
export const setApprovalOfOpenOrdersForAll = async ({ chainId, walletClient, options, }) => {
|
|
30
|
+
if (!walletClient.account) {
|
|
31
|
+
throw new Error('Account is not found');
|
|
32
|
+
}
|
|
33
|
+
const publicClient = createPublicClient({
|
|
34
|
+
chain: CHAIN_MAP[chainId],
|
|
35
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
36
|
+
});
|
|
37
|
+
const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, walletClient.account.address);
|
|
38
|
+
if (isApprovedForAll) {
|
|
39
|
+
return undefined;
|
|
40
|
+
}
|
|
41
|
+
// Simulate the contract call first to validate it will succeed
|
|
42
|
+
const { request } = await publicClient.simulateContract({
|
|
43
|
+
account: walletClient.account,
|
|
44
|
+
chain: CHAIN_MAP[chainId],
|
|
45
|
+
address: CONTRACT_ADDRESSES[chainId].BookManager,
|
|
46
|
+
abi: [
|
|
47
|
+
{
|
|
48
|
+
inputs: [
|
|
49
|
+
{
|
|
50
|
+
internalType: 'address',
|
|
51
|
+
name: 'operator',
|
|
52
|
+
type: 'address',
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
internalType: 'bool',
|
|
56
|
+
name: 'approved',
|
|
57
|
+
type: 'bool',
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
name: 'setApprovalForAll',
|
|
61
|
+
outputs: [],
|
|
62
|
+
stateMutability: 'nonpayable',
|
|
63
|
+
type: 'function',
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
functionName: 'setApprovalForAll',
|
|
67
|
+
args: [CONTRACT_ADDRESSES[chainId].Controller, true],
|
|
68
|
+
});
|
|
69
|
+
return walletClient.writeContract(request);
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=open-order.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"open-order.js","sourceRoot":"","sources":["../../../../src/calls/approval/open-order.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAgB,MAAM,MAAM,CAAC;AAE9D,OAAO,EAAa,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAE3E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAE7E;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,CAAC,MAAM,6BAA6B,GAAG,KAAK,EAAE,EAClD,OAAO,EACP,YAAY,EACZ,OAAO,GAKR,EAAsC,EAAE;IACvC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;IAC1C,CAAC;IACD,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;KAC3D,CAAC,CAAC;IACH,MAAM,gBAAgB,GAAG,MAAM,qBAAqB,CAClD,YAAY,EACZ,OAAO,EACP,YAAY,CAAC,OAAO,CAAC,OAAO,CAC7B,CAAC;IACF,IAAI,gBAAgB,EAAE,CAAC;QACrB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,+DAA+D;IAC/D,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,YAAY,CAAC,gBAAgB,CAAC;QACtD,OAAO,EAAE,YAAY,CAAC,OAAO;QAC7B,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,WAAW;QACjD,GAAG,EAAE;YACH;gBACE,MAAM,EAAE;oBACN;wBACE,YAAY,EAAE,SAAS;wBACvB,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,SAAS;qBAChB;oBACD;wBACE,YAAY,EAAE,MAAM;wBACpB,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,MAAM;qBACb;iBACF;gBACD,IAAI,EAAE,mBAAmB;gBACzB,OAAO,EAAE,EAAE;gBACX,eAAe,EAAE,YAAY;gBAC7B,IAAI,EAAE,UAAU;aACjB;SACO;QACV,YAAY,EAAE,mBAAmB;QACjC,IAAI,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAE,CAAC,UAAU,EAAE,IAAI,CAAC;KACtD,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC,CAAC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { createPublicClient, http } from 'viem';
|
|
2
|
+
import { CHAIN_MAP } from '../../constants/chain-configs/chain';
|
|
3
|
+
import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
|
|
4
|
+
/**
|
|
5
|
+
* @dev This function relates with `viem` dependency
|
|
6
|
+
* Sets the order operator approval for the specified operator address on the given chain.
|
|
7
|
+
*
|
|
8
|
+
* @param {CHAIN_IDS} chainId The chain ID.
|
|
9
|
+
* @param {WalletClient} walletClient The wallet client.
|
|
10
|
+
* @param {`0x${string}`} operator The operator address to approve or revoke.
|
|
11
|
+
* @param {boolean} approved Whether to approve or revoke the operator.
|
|
12
|
+
* @param {Object} [options] Optional parameters for setting approval.
|
|
13
|
+
* @param {string} options.rpcUrl The RPC URL to use for executing the transaction.
|
|
14
|
+
* @returns {Promise<`0x${string}`>} Promise resolving to the transaction hash.
|
|
15
|
+
* @example
|
|
16
|
+
* import { setOrderOperatorApproval } from '@clober/v2-sdk'
|
|
17
|
+
* import { mnemonicToAccount } from 'viem/accounts'
|
|
18
|
+
*
|
|
19
|
+
* const walletClient = createWalletClient({
|
|
20
|
+
* chain: arbitrumSepolia,
|
|
21
|
+
* account: mnemonicToAccount('legal ...'),
|
|
22
|
+
* transport: http(),
|
|
23
|
+
* })
|
|
24
|
+
*
|
|
25
|
+
* const hash = await setOrderOperatorApproval({
|
|
26
|
+
* chainId: 421614,
|
|
27
|
+
* walletClient,
|
|
28
|
+
* operator: '0x1234567890123456789012345678901234567890',
|
|
29
|
+
* approved: true
|
|
30
|
+
* })
|
|
31
|
+
*/
|
|
32
|
+
export const setOrderOperatorApproval = async ({ chainId, walletClient, operator, approved, options, }) => {
|
|
33
|
+
if (!walletClient.account) {
|
|
34
|
+
throw new Error('Account is not found');
|
|
35
|
+
}
|
|
36
|
+
const publicClient = createPublicClient({
|
|
37
|
+
chain: CHAIN_MAP[chainId],
|
|
38
|
+
transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
|
|
39
|
+
});
|
|
40
|
+
// Simulate the contract call first to validate it will succeed
|
|
41
|
+
const { request } = await publicClient.simulateContract({
|
|
42
|
+
account: walletClient.account,
|
|
43
|
+
chain: CHAIN_MAP[chainId],
|
|
44
|
+
address: CONTRACT_ADDRESSES[chainId].BookManager,
|
|
45
|
+
abi: [
|
|
46
|
+
{
|
|
47
|
+
inputs: [
|
|
48
|
+
{
|
|
49
|
+
internalType: 'address',
|
|
50
|
+
name: 'operator',
|
|
51
|
+
type: 'address',
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
internalType: 'bool',
|
|
55
|
+
name: 'approved',
|
|
56
|
+
type: 'bool',
|
|
57
|
+
},
|
|
58
|
+
],
|
|
59
|
+
name: 'setOrderOperator',
|
|
60
|
+
outputs: [],
|
|
61
|
+
stateMutability: 'nonpayable',
|
|
62
|
+
type: 'function',
|
|
63
|
+
},
|
|
64
|
+
],
|
|
65
|
+
functionName: 'setOrderOperator',
|
|
66
|
+
args: [operator, approved],
|
|
67
|
+
});
|
|
68
|
+
return walletClient.writeContract(request);
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=order.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"order.js","sourceRoot":"","sources":["../../../../src/calls/approval/order.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAgB,MAAM,MAAM,CAAC;AAE9D,OAAO,EAAa,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAE3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAE7E;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG,KAAK,EAAE,EAC7C,OAAO,EACP,YAAY,EACZ,QAAQ,EACR,QAAQ,EACR,OAAO,GAOR,EAA0B,EAAE;IAC3B,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;IAC1C,CAAC;IACD,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;KAC3D,CAAC,CAAC;IACH,+DAA+D;IAC/D,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,YAAY,CAAC,gBAAgB,CAAC;QACtD,OAAO,EAAE,YAAY,CAAC,OAAO;QAC7B,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,WAAW;QACjD,GAAG,EAAE;YACH;gBACE,MAAM,EAAE;oBACN;wBACE,YAAY,EAAE,SAAS;wBACvB,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,SAAS;qBAChB;oBACD;wBACE,YAAY,EAAE,MAAM;wBACpB,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,MAAM;qBACb;iBACF;gBACD,IAAI,EAAE,kBAAkB;gBACxB,OAAO,EAAE,EAAE;gBACX,eAAe,EAAE,YAAY;gBAC7B,IAAI,EAAE,UAAU;aACjB;SACO;QACV,YAAY,EAAE,kBAAkB;QAChC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;KAC3B,CAAC,CAAC;IAEH,OAAO,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC,CAAC"}
|