viem 0.0.0-w-20230725184008 → 0.0.0-w-20230810155401
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 +6 -0
- package/chains/utils/package.json +5 -0
- package/dist/cjs/accounts/index.js +6 -2
- package/dist/cjs/accounts/index.js.map +1 -1
- package/dist/cjs/accounts/utils/privateKeyToAddress.js +12 -0
- package/dist/cjs/accounts/utils/privateKeyToAddress.js.map +1 -0
- package/dist/cjs/accounts/utils/signMessage.js +1 -1
- package/dist/cjs/accounts/utils/signMessage.js.map +1 -1
- package/dist/cjs/accounts/utils/signTransaction.js.map +1 -1
- package/dist/cjs/accounts/utils/signTypedData.js +1 -1
- package/dist/cjs/accounts/utils/signTypedData.js.map +1 -1
- package/dist/cjs/actions/ens/getEnsAddress.js +18 -13
- package/dist/cjs/actions/ens/getEnsAddress.js.map +1 -1
- package/dist/cjs/actions/index.js.map +1 -1
- package/dist/cjs/actions/public/createContractEventFilter.js.map +1 -1
- package/dist/cjs/actions/public/createEventFilter.js +16 -8
- package/dist/cjs/actions/public/createEventFilter.js.map +1 -1
- package/dist/cjs/actions/public/estimateContractGas.js +1 -1
- package/dist/cjs/actions/public/estimateContractGas.js.map +1 -1
- package/dist/cjs/actions/public/estimateGas.js +3 -1
- package/dist/cjs/actions/public/estimateGas.js.map +1 -1
- package/dist/cjs/actions/public/getBlock.js +3 -1
- package/dist/cjs/actions/public/getBlock.js.map +1 -1
- package/dist/cjs/actions/public/getBlockNumber.js +2 -2
- package/dist/cjs/actions/public/getBlockNumber.js.map +1 -1
- package/dist/cjs/actions/public/getFilterChanges.js.map +1 -1
- package/dist/cjs/actions/public/getFilterLogs.js +1 -1
- package/dist/cjs/actions/public/getFilterLogs.js.map +1 -1
- package/dist/cjs/actions/public/getLogs.js +16 -10
- package/dist/cjs/actions/public/getLogs.js.map +1 -1
- package/dist/cjs/actions/public/getTransaction.js +2 -1
- package/dist/cjs/actions/public/getTransaction.js.map +1 -1
- package/dist/cjs/actions/public/watchBlockNumber.js +1 -1
- package/dist/cjs/actions/public/watchBlockNumber.js.map +1 -1
- package/dist/cjs/actions/public/watchBlocks.js +2 -1
- package/dist/cjs/actions/public/watchBlocks.js.map +1 -1
- package/dist/cjs/actions/public/watchContractEvent.js +135 -65
- package/dist/cjs/actions/public/watchContractEvent.js.map +1 -1
- package/dist/cjs/actions/public/watchEvent.js +138 -59
- package/dist/cjs/actions/public/watchEvent.js.map +1 -1
- package/dist/cjs/actions/wallet/sendTransaction.js.map +1 -1
- package/dist/cjs/actions/wallet/writeContract.js.map +1 -1
- package/dist/cjs/chains/{formatters/celo.js → celo/formatters.js} +1 -1
- package/dist/cjs/chains/celo/formatters.js.map +1 -0
- package/dist/cjs/chains/{serializers/celo.js → celo/serializers.js} +1 -1
- package/dist/cjs/chains/celo/serializers.js.map +1 -0
- package/dist/cjs/{types/formatter.js → chains/celo/types.js} +1 -1
- package/dist/cjs/chains/celo/types.js.map +1 -0
- package/dist/cjs/chains/index.js +30 -15
- package/dist/cjs/chains/index.js.map +1 -1
- package/dist/cjs/chains/optimism/fees.js +7 -0
- package/dist/cjs/chains/optimism/fees.js.map +1 -0
- package/dist/cjs/chains/{formatters/optimism.js → optimism/formatters.js} +13 -1
- package/dist/cjs/chains/optimism/formatters.js.map +1 -0
- package/dist/cjs/{types/serializer.js → chains/optimism/types.js} +1 -1
- package/dist/cjs/chains/optimism/types.js.map +1 -0
- package/dist/cjs/chains/utils.js +11 -0
- package/dist/cjs/chains/utils.js.map +1 -0
- package/dist/cjs/clients/createClient.js +2 -1
- package/dist/cjs/clients/createClient.js.map +1 -1
- package/dist/cjs/clients/createPublicClient.js.map +1 -1
- package/dist/cjs/clients/createTestClient.js.map +1 -1
- package/dist/cjs/clients/createWalletClient.js.map +1 -1
- package/dist/cjs/clients/decorators/public.js.map +1 -1
- package/dist/cjs/constants/abis.js +12 -2
- package/dist/cjs/constants/abis.js.map +1 -1
- package/dist/cjs/constants/number.js +101 -0
- package/dist/cjs/constants/number.js.map +1 -0
- package/dist/cjs/contract.js.map +1 -1
- package/dist/cjs/errors/abi.js +8 -1
- package/dist/cjs/errors/abi.js.map +1 -1
- package/dist/cjs/errors/contract.js +56 -32
- package/dist/cjs/errors/contract.js.map +1 -1
- package/dist/cjs/errors/node.js +1 -1
- package/dist/cjs/errors/node.js.map +1 -1
- package/dist/cjs/errors/version.js +1 -1
- package/dist/cjs/errors/version.js.map +1 -1
- package/dist/cjs/index.js +110 -7
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/public.js.map +1 -1
- package/dist/cjs/utils/abi/encodeAbiParameters.js +11 -14
- package/dist/cjs/utils/abi/encodeAbiParameters.js.map +1 -1
- package/dist/cjs/utils/abi/encodePacked.js +2 -0
- package/dist/cjs/utils/abi/encodePacked.js.map +1 -1
- package/dist/cjs/utils/chain.js +5 -3
- package/dist/cjs/utils/chain.js.map +1 -1
- package/dist/cjs/utils/formatters/block.js.map +1 -1
- package/dist/cjs/utils/formatters/extract.js.map +1 -1
- package/dist/cjs/utils/formatters/formatter.js +1 -0
- package/dist/cjs/utils/formatters/formatter.js.map +1 -1
- package/dist/cjs/utils/formatters/transaction.js.map +1 -1
- package/dist/cjs/utils/formatters/transactionReceipt.js.map +1 -1
- package/dist/cjs/utils/formatters/transactionRequest.js.map +1 -1
- package/dist/cjs/utils/hash/hashFunction.js +3 -2
- package/dist/cjs/utils/hash/hashFunction.js.map +1 -1
- package/dist/cjs/utils/promise/withCache.js +3 -3
- package/dist/cjs/utils/promise/withCache.js.map +1 -1
- package/dist/cjs/utils/signature/hexToSignature.js +12 -0
- package/dist/cjs/utils/signature/hexToSignature.js.map +1 -0
- package/dist/cjs/utils/signature/signatureToHex.js.map +1 -0
- package/dist/cjs/utils/transaction/prepareRequest.js +19 -12
- package/dist/cjs/utils/transaction/prepareRequest.js.map +1 -1
- package/dist/cjs/utils/unit/parseUnits.js +2 -1
- package/dist/cjs/utils/unit/parseUnits.js.map +1 -1
- package/dist/esm/accounts/index.js +3 -1
- package/dist/esm/accounts/index.js.map +1 -1
- package/dist/esm/accounts/utils/privateKeyToAddress.js +15 -0
- package/dist/esm/accounts/utils/privateKeyToAddress.js.map +1 -0
- package/dist/esm/accounts/utils/signMessage.js +1 -1
- package/dist/esm/accounts/utils/signMessage.js.map +1 -1
- package/dist/esm/accounts/utils/signTransaction.js.map +1 -1
- package/dist/esm/accounts/utils/signTypedData.js +1 -1
- package/dist/esm/accounts/utils/signTypedData.js.map +1 -1
- package/dist/esm/actions/ens/getEnsAddress.js +19 -14
- package/dist/esm/actions/ens/getEnsAddress.js.map +1 -1
- package/dist/esm/actions/index.js.map +1 -1
- package/dist/esm/actions/public/createContractEventFilter.js.map +1 -1
- package/dist/esm/actions/public/createEventFilter.js +16 -8
- package/dist/esm/actions/public/createEventFilter.js.map +1 -1
- package/dist/esm/actions/public/estimateContractGas.js +1 -1
- package/dist/esm/actions/public/estimateContractGas.js.map +1 -1
- package/dist/esm/actions/public/estimateGas.js +4 -2
- package/dist/esm/actions/public/estimateGas.js.map +1 -1
- package/dist/esm/actions/public/getBlock.js +3 -1
- package/dist/esm/actions/public/getBlock.js.map +1 -1
- package/dist/esm/actions/public/getBlockNumber.js +2 -2
- package/dist/esm/actions/public/getBlockNumber.js.map +1 -1
- package/dist/esm/actions/public/getFilterChanges.js.map +1 -1
- package/dist/esm/actions/public/getFilterLogs.js +1 -1
- package/dist/esm/actions/public/getFilterLogs.js.map +1 -1
- package/dist/esm/actions/public/getLogs.js +16 -10
- package/dist/esm/actions/public/getLogs.js.map +1 -1
- package/dist/esm/actions/public/getTransaction.js +2 -1
- package/dist/esm/actions/public/getTransaction.js.map +1 -1
- package/dist/esm/actions/public/watchBlockNumber.js +1 -1
- package/dist/esm/actions/public/watchBlockNumber.js.map +1 -1
- package/dist/esm/actions/public/watchBlocks.js +2 -1
- package/dist/esm/actions/public/watchBlocks.js.map +1 -1
- package/dist/esm/actions/public/watchContractEvent.js +145 -71
- package/dist/esm/actions/public/watchContractEvent.js.map +1 -1
- package/dist/esm/actions/public/watchEvent.js +148 -65
- package/dist/esm/actions/public/watchEvent.js.map +1 -1
- package/dist/esm/actions/wallet/sendTransaction.js +1 -1
- package/dist/esm/actions/wallet/sendTransaction.js.map +1 -1
- package/dist/esm/actions/wallet/writeContract.js.map +1 -1
- package/dist/esm/chains/{formatters/celo.js → celo/formatters.js} +2 -2
- package/dist/esm/chains/celo/formatters.js.map +1 -0
- package/dist/esm/chains/{serializers/celo.js → celo/serializers.js} +1 -1
- package/dist/esm/chains/celo/serializers.js.map +1 -0
- package/dist/esm/chains/celo/types.js +2 -0
- package/dist/esm/chains/celo/types.js.map +1 -0
- package/dist/esm/chains/index.js +22 -7
- package/dist/esm/chains/index.js.map +1 -1
- package/dist/esm/chains/optimism/fees.js +4 -0
- package/dist/esm/chains/optimism/fees.js.map +1 -0
- package/dist/esm/chains/{formatters/optimism.js → optimism/formatters.js} +15 -2
- package/dist/esm/chains/optimism/formatters.js.map +1 -0
- package/dist/esm/chains/optimism/types.js +2 -0
- package/dist/esm/chains/optimism/types.js.map +1 -0
- package/dist/esm/chains/utils.js +4 -0
- package/dist/esm/chains/utils.js.map +1 -0
- package/dist/esm/clients/createClient.js +2 -1
- package/dist/esm/clients/createClient.js.map +1 -1
- package/dist/esm/clients/createPublicClient.js.map +1 -1
- package/dist/esm/clients/createTestClient.js.map +1 -1
- package/dist/esm/clients/createWalletClient.js.map +1 -1
- package/dist/esm/clients/decorators/public.js.map +1 -1
- package/dist/esm/constants/abis.js +11 -1
- package/dist/esm/constants/abis.js.map +1 -1
- package/dist/esm/constants/number.js +97 -0
- package/dist/esm/constants/number.js.map +1 -0
- package/dist/esm/contract.js.map +1 -1
- package/dist/esm/errors/abi.js +8 -1
- package/dist/esm/errors/abi.js.map +1 -1
- package/dist/esm/errors/contract.js +56 -32
- package/dist/esm/errors/contract.js.map +1 -1
- package/dist/esm/errors/node.js +1 -1
- package/dist/esm/errors/node.js.map +1 -1
- package/dist/esm/errors/version.js +1 -1
- package/dist/esm/errors/version.js.map +1 -1
- package/dist/esm/index.js +4 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/public.js.map +1 -1
- package/dist/esm/utils/abi/encodeAbiParameters.js +13 -14
- package/dist/esm/utils/abi/encodeAbiParameters.js.map +1 -1
- package/dist/esm/utils/abi/encodePacked.js +2 -0
- package/dist/esm/utils/abi/encodePacked.js.map +1 -1
- package/dist/esm/utils/chain.js +5 -3
- package/dist/esm/utils/chain.js.map +1 -1
- package/dist/esm/utils/formatters/block.js.map +1 -1
- package/dist/esm/utils/formatters/extract.js.map +1 -1
- package/dist/esm/utils/formatters/formatter.js +1 -0
- package/dist/esm/utils/formatters/formatter.js.map +1 -1
- package/dist/esm/utils/formatters/transaction.js.map +1 -1
- package/dist/esm/utils/formatters/transactionReceipt.js.map +1 -1
- package/dist/esm/utils/formatters/transactionRequest.js.map +1 -1
- package/dist/esm/utils/hash/hashFunction.js +3 -2
- package/dist/esm/utils/hash/hashFunction.js.map +1 -1
- package/dist/esm/utils/promise/withCache.js +3 -3
- package/dist/esm/utils/promise/withCache.js.map +1 -1
- package/dist/esm/utils/signature/hexToSignature.js +18 -0
- package/dist/esm/utils/signature/hexToSignature.js.map +1 -0
- package/dist/esm/utils/signature/signatureToHex.js +21 -0
- package/dist/esm/utils/signature/signatureToHex.js.map +1 -0
- package/dist/esm/utils/transaction/prepareRequest.js +20 -13
- package/dist/esm/utils/transaction/prepareRequest.js.map +1 -1
- package/dist/esm/utils/unit/parseUnits.js +2 -1
- package/dist/esm/utils/unit/parseUnits.js.map +1 -1
- package/dist/types/accounts/index.d.ts +3 -1
- package/dist/types/accounts/index.d.ts.map +1 -1
- package/dist/types/accounts/utils/privateKeyToAddress.d.ts +11 -0
- package/dist/types/accounts/utils/privateKeyToAddress.d.ts.map +1 -0
- package/dist/types/accounts/utils/signTransaction.d.ts +2 -2
- package/dist/types/accounts/utils/signTransaction.d.ts.map +1 -1
- package/dist/types/actions/ens/getEnsAddress.d.ts +3 -1
- package/dist/types/actions/ens/getEnsAddress.d.ts.map +1 -1
- package/dist/types/actions/index.d.ts +5 -1
- package/dist/types/actions/index.d.ts.map +1 -1
- package/dist/types/actions/public/createContractEventFilter.d.ts +5 -5
- package/dist/types/actions/public/createContractEventFilter.d.ts.map +1 -1
- package/dist/types/actions/public/createEventFilter.d.ts +20 -7
- package/dist/types/actions/public/createEventFilter.d.ts.map +1 -1
- package/dist/types/actions/public/estimateGas.d.ts.map +1 -1
- package/dist/types/actions/public/getBlock.d.ts +5 -5
- package/dist/types/actions/public/getBlock.d.ts.map +1 -1
- package/dist/types/actions/public/getBlockNumber.d.ts +4 -2
- package/dist/types/actions/public/getBlockNumber.d.ts.map +1 -1
- package/dist/types/actions/public/getFilterChanges.d.ts +5 -8
- package/dist/types/actions/public/getFilterChanges.d.ts.map +1 -1
- package/dist/types/actions/public/getFilterLogs.d.ts +5 -4
- package/dist/types/actions/public/getFilterLogs.d.ts.map +1 -1
- package/dist/types/actions/public/getLogs.d.ts +17 -6
- package/dist/types/actions/public/getLogs.d.ts.map +1 -1
- package/dist/types/actions/public/getTransaction.d.ts +4 -4
- package/dist/types/actions/public/getTransaction.d.ts.map +1 -1
- package/dist/types/actions/public/getTransactionReceipt.d.ts +1 -1
- package/dist/types/actions/public/getTransactionReceipt.d.ts.map +1 -1
- package/dist/types/actions/public/simulateContract.d.ts +2 -2
- package/dist/types/actions/public/simulateContract.d.ts.map +1 -1
- package/dist/types/actions/public/watchBlocks.d.ts +10 -10
- package/dist/types/actions/public/watchBlocks.d.ts.map +1 -1
- package/dist/types/actions/public/watchContractEvent.d.ts +35 -9
- package/dist/types/actions/public/watchContractEvent.d.ts.map +1 -1
- package/dist/types/actions/public/watchEvent.d.ts +48 -14
- package/dist/types/actions/public/watchEvent.d.ts.map +1 -1
- package/dist/types/actions/wallet/deployContract.d.ts +1 -1
- package/dist/types/actions/wallet/deployContract.d.ts.map +1 -1
- package/dist/types/actions/wallet/sendTransaction.d.ts +2 -2
- package/dist/types/actions/wallet/sendTransaction.d.ts.map +1 -1
- package/dist/types/actions/wallet/writeContract.d.ts +4 -2
- package/dist/types/actions/wallet/writeContract.d.ts.map +1 -1
- package/dist/types/chains/{formatters/celo.d.ts → celo/formatters.d.ts} +30 -85
- package/dist/types/chains/celo/formatters.d.ts.map +1 -0
- package/dist/types/chains/{serializers/celo.d.ts → celo/serializers.d.ts} +4 -4
- package/dist/types/chains/celo/serializers.d.ts.map +1 -0
- package/dist/types/chains/celo/types.d.ts +60 -0
- package/dist/types/chains/celo/types.d.ts.map +1 -0
- package/dist/types/chains/index.d.ts +2527 -2722
- package/dist/types/chains/index.d.ts.map +1 -1
- package/dist/types/chains/optimism/fees.d.ts +4 -0
- package/dist/types/chains/optimism/fees.d.ts.map +1 -0
- package/dist/types/chains/{formatters/optimism.d.ts → optimism/formatters.d.ts} +79 -54
- package/dist/types/chains/optimism/formatters.d.ts.map +1 -0
- package/dist/types/chains/optimism/types.d.ts +53 -0
- package/dist/types/chains/optimism/types.d.ts.map +1 -0
- package/dist/types/chains/utils.d.ts +6 -0
- package/dist/types/chains/utils.d.ts.map +1 -0
- package/dist/types/clients/createClient.d.ts +7 -0
- package/dist/types/clients/createClient.d.ts.map +1 -1
- package/dist/types/clients/createPublicClient.d.ts +1 -1
- package/dist/types/clients/createPublicClient.d.ts.map +1 -1
- package/dist/types/clients/createTestClient.d.ts +1 -1
- package/dist/types/clients/createTestClient.d.ts.map +1 -1
- package/dist/types/clients/createWalletClient.d.ts +1 -1
- package/dist/types/clients/createWalletClient.d.ts.map +1 -1
- package/dist/types/clients/decorators/public.d.ts +11 -10
- package/dist/types/clients/decorators/public.d.ts.map +1 -1
- package/dist/types/constants/abis.d.ts +16 -1
- package/dist/types/constants/abis.d.ts.map +1 -1
- package/dist/types/constants/number.d.ts +97 -0
- package/dist/types/constants/number.d.ts.map +1 -0
- package/dist/types/contract.d.ts +5 -1
- package/dist/types/contract.d.ts.map +1 -1
- package/dist/types/errors/abi.d.ts +1 -0
- package/dist/types/errors/abi.d.ts.map +1 -1
- package/dist/types/errors/contract.d.ts +1 -0
- package/dist/types/errors/contract.d.ts.map +1 -1
- package/dist/types/errors/node.d.ts.map +1 -1
- package/dist/types/errors/version.d.ts +1 -1
- package/dist/types/errors/version.d.ts.map +1 -1
- package/dist/types/index.d.ts +24 -6
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/public.d.ts +5 -1
- package/dist/types/public.d.ts.map +1 -1
- package/dist/types/types/block.d.ts +7 -7
- package/dist/types/types/block.d.ts.map +1 -1
- package/dist/types/types/chain.d.ts +52 -8
- package/dist/types/types/chain.d.ts.map +1 -1
- package/dist/types/types/contract.d.ts +1 -1
- package/dist/types/types/contract.d.ts.map +1 -1
- package/dist/types/types/filter.d.ts +7 -3
- package/dist/types/types/filter.d.ts.map +1 -1
- package/dist/types/types/log.d.ts +8 -8
- package/dist/types/types/log.d.ts.map +1 -1
- package/dist/types/types/misc.d.ts.map +1 -1
- package/dist/types/types/rpc.d.ts +3 -3
- package/dist/types/types/rpc.d.ts.map +1 -1
- package/dist/types/types/transaction.d.ts +8 -8
- package/dist/types/types/transaction.d.ts.map +1 -1
- package/dist/types/types/utils.d.ts +10 -0
- package/dist/types/types/utils.d.ts.map +1 -1
- package/dist/types/utils/abi/encodeAbiParameters.d.ts.map +1 -1
- package/dist/types/utils/chain.d.ts +3 -6
- package/dist/types/utils/chain.d.ts.map +1 -1
- package/dist/types/utils/formatters/block.d.ts +18 -4
- package/dist/types/utils/formatters/block.d.ts.map +1 -1
- package/dist/types/utils/formatters/extract.d.ts +2 -2
- package/dist/types/utils/formatters/extract.d.ts.map +1 -1
- package/dist/types/utils/formatters/formatter.d.ts +2 -1
- package/dist/types/utils/formatters/formatter.d.ts.map +1 -1
- package/dist/types/utils/formatters/transaction.d.ts +15 -4
- package/dist/types/utils/formatters/transaction.d.ts.map +1 -1
- package/dist/types/utils/formatters/transactionReceipt.d.ts +4 -4
- package/dist/types/utils/formatters/transactionReceipt.d.ts.map +1 -1
- package/dist/types/utils/formatters/transactionRequest.d.ts +5 -5
- package/dist/types/utils/formatters/transactionRequest.d.ts.map +1 -1
- package/dist/types/utils/hash/hashFunction.d.ts +1 -1
- package/dist/types/utils/hash/hashFunction.d.ts.map +1 -1
- package/dist/types/utils/promise/withCache.d.ts +3 -3
- package/dist/types/utils/promise/withCache.d.ts.map +1 -1
- package/dist/types/utils/signature/hexToSignature.d.ts +13 -0
- package/dist/types/utils/signature/hexToSignature.d.ts.map +1 -0
- package/dist/types/utils/signature/signatureToHex.d.ts +17 -0
- package/dist/types/utils/signature/signatureToHex.d.ts.map +1 -0
- package/dist/types/utils/transaction/prepareRequest.d.ts +6 -11
- package/dist/types/utils/transaction/prepareRequest.d.ts.map +1 -1
- package/dist/types/utils/unit/parseUnits.d.ts.map +1 -1
- package/package.json +9 -2
- package/src/accounts/index.ts +7 -1
- package/src/accounts/utils/privateKeyToAddress.ts +20 -0
- package/src/accounts/utils/signMessage.ts +1 -1
- package/src/accounts/utils/signTransaction.ts +2 -2
- package/src/accounts/utils/signTypedData.ts +1 -1
- package/src/actions/ens/getEnsAddress.ts +24 -15
- package/src/actions/index.ts +6 -2
- package/src/actions/public/createContractEventFilter.ts +30 -7
- package/src/actions/public/createEventFilter.ts +78 -24
- package/src/actions/public/estimateContractGas.ts +1 -1
- package/src/actions/public/estimateGas.ts +11 -2
- package/src/actions/public/getBlock.ts +18 -8
- package/src/actions/public/getBlockNumber.ts +5 -3
- package/src/actions/public/getFilterChanges.ts +46 -10
- package/src/actions/public/getFilterLogs.ts +26 -10
- package/src/actions/public/getLogs.ts +73 -18
- package/src/actions/public/getTransaction.ts +15 -8
- package/src/actions/public/simulateContract.ts +2 -2
- package/src/actions/public/watchBlockNumber.ts +1 -1
- package/src/actions/public/watchBlocks.ts +37 -18
- package/src/actions/public/watchContractEvent.ts +208 -90
- package/src/actions/public/watchEvent.ts +262 -104
- package/src/actions/wallet/deployContract.ts +1 -1
- package/src/actions/wallet/sendTransaction.ts +9 -6
- package/src/actions/wallet/writeContract.ts +11 -7
- package/src/chains/{formatters/celo.ts → celo/formatters.ts} +29 -48
- package/src/chains/{serializers/celo.ts → celo/serializers.ts} +5 -5
- package/src/chains/celo/types.ts +111 -0
- package/src/chains/index.ts +22 -7
- package/src/chains/optimism/fees.ts +5 -0
- package/src/chains/optimism/formatters.ts +74 -0
- package/src/chains/optimism/types.ts +102 -0
- package/src/chains/utils.ts +41 -0
- package/src/clients/createClient.ts +9 -0
- package/src/clients/createPublicClient.ts +7 -1
- package/src/clients/createTestClient.ts +7 -1
- package/src/clients/createWalletClient.ts +7 -1
- package/src/clients/decorators/public.ts +117 -28
- package/src/constants/abis.ts +11 -1
- package/src/constants/number.ts +98 -0
- package/src/contract.ts +6 -2
- package/src/errors/abi.ts +5 -1
- package/src/errors/contract.ts +52 -31
- package/src/errors/node.ts +2 -1
- package/src/errors/version.ts +1 -1
- package/src/index.ts +133 -11
- package/src/public.ts +6 -2
- package/src/types/block.ts +25 -10
- package/src/types/chain.ts +91 -14
- package/src/types/contract.ts +7 -3
- package/src/types/filter.ts +32 -26
- package/src/types/log.ts +13 -8
- package/src/types/misc.ts +3 -0
- package/src/types/rpc.ts +16 -6
- package/src/types/transaction.ts +22 -11
- package/src/types/utils.ts +11 -0
- package/src/utils/abi/encodeAbiParameters.ts +14 -17
- package/src/utils/abi/encodePacked.ts +1 -0
- package/src/utils/chain.ts +21 -10
- package/src/utils/formatters/block.ts +34 -5
- package/src/utils/formatters/extract.ts +2 -2
- package/src/utils/formatters/formatter.ts +3 -2
- package/src/utils/formatters/transaction.ts +28 -3
- package/src/utils/formatters/transactionReceipt.ts +9 -3
- package/src/utils/formatters/transactionRequest.ts +9 -3
- package/src/utils/hash/hashFunction.ts +3 -2
- package/src/utils/promise/withCache.ts +5 -5
- package/src/utils/signature/hexToSignature.ts +20 -0
- package/src/utils/signature/signatureToHex.ts +26 -0
- package/src/utils/transaction/prepareRequest.ts +55 -30
- package/src/utils/unit/parseUnits.ts +2 -1
- package/dist/cjs/accounts/utils/signatureToHex.js.map +0 -1
- package/dist/cjs/chains/formatters/celo.js.map +0 -1
- package/dist/cjs/chains/formatters/optimism.js.map +0 -1
- package/dist/cjs/chains/serializers/celo.js.map +0 -1
- package/dist/cjs/types/formatter.js.map +0 -1
- package/dist/cjs/types/serializer.js.map +0 -1
- package/dist/esm/accounts/utils/signatureToHex.js +0 -7
- package/dist/esm/accounts/utils/signatureToHex.js.map +0 -1
- package/dist/esm/chains/formatters/celo.js.map +0 -1
- package/dist/esm/chains/formatters/optimism.js.map +0 -1
- package/dist/esm/chains/serializers/celo.js.map +0 -1
- package/dist/esm/types/formatter.js +0 -2
- package/dist/esm/types/formatter.js.map +0 -1
- package/dist/esm/types/serializer.js +0 -2
- package/dist/esm/types/serializer.js.map +0 -1
- package/dist/types/accounts/utils/signatureToHex.d.ts +0 -3
- package/dist/types/accounts/utils/signatureToHex.d.ts.map +0 -1
- package/dist/types/chains/formatters/celo.d.ts.map +0 -1
- package/dist/types/chains/formatters/optimism.d.ts.map +0 -1
- package/dist/types/chains/serializers/celo.d.ts.map +0 -1
- package/dist/types/types/formatter.d.ts +0 -14
- package/dist/types/types/formatter.d.ts.map +0 -1
- package/dist/types/types/serializer.d.ts +0 -7
- package/dist/types/types/serializer.d.ts.map +0 -1
- package/src/accounts/utils/signatureToHex.ts +0 -12
- package/src/chains/formatters/optimism.ts +0 -91
- package/src/types/formatter.ts +0 -33
- package/src/types/serializer.ts +0 -19
- /package/dist/cjs/{accounts/utils → utils/signature}/signatureToHex.js +0 -0
@@ -1,4 +1,4 @@
|
|
1
1
|
import type { AbiEvent, AbiFunction } from 'abitype';
|
2
2
|
export declare function hashFunction(def: string): `0x${string}`;
|
3
|
-
export declare function hashAbiItem(
|
3
|
+
export declare function hashAbiItem(abiItem: AbiFunction | AbiEvent): `0x${string}`;
|
4
4
|
//# sourceMappingURL=hashFunction.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"hashFunction.d.ts","sourceRoot":"","sources":["../../../../src/utils/hash/hashFunction.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"hashFunction.d.ts","sourceRoot":"","sources":["../../../../src/utils/hash/hashFunction.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAMpD,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,iBAIvC;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,QAAQ,iBAE1D"}
|
@@ -25,12 +25,12 @@ export declare function getCache<TData>(cacheKey: string): {
|
|
25
25
|
export type WithCacheParameters = {
|
26
26
|
/** The key to cache the data against. */
|
27
27
|
cacheKey: string;
|
28
|
-
/** The
|
29
|
-
|
28
|
+
/** The time that cached data will remain in memory. Default: Infinity (no expiry) */
|
29
|
+
cacheTime?: number;
|
30
30
|
};
|
31
31
|
/**
|
32
32
|
* @description Returns the result of a given promise, and caches the result for
|
33
33
|
* subsequent invocations against a provided cache key.
|
34
34
|
*/
|
35
|
-
export declare function withCache<TData>(fn: () => Promise<TData>, { cacheKey,
|
35
|
+
export declare function withCache<TData>(fn: () => Promise<TData>, { cacheKey, cacheTime }: WithCacheParameters): Promise<TData>;
|
36
36
|
//# sourceMappingURL=withCache.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"withCache.d.ts","sourceRoot":"","sources":["../../../../src/utils/promise/withCache.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,eAA0B,CAAA;AACnD,eAAO,MAAM,aAAa,eAA0B,CAAA;AAEpD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM;;;;;;;;;;qBAQP,IAAI;kBAAQ,KAAK;;;qBAAjB,IAAI;kBAAQ,KAAK;;qBAAjB,IAAI;kBAAQ,KAAK;;;EAazD;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,yCAAyC;IACzC,QAAQ,EAAE,MAAM,CAAA;IAChB,
|
1
|
+
{"version":3,"file":"withCache.d.ts","sourceRoot":"","sources":["../../../../src/utils/promise/withCache.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,eAA0B,CAAA;AACnD,eAAO,MAAM,aAAa,eAA0B,CAAA;AAEpD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM;;;;;;;;;;qBAQP,IAAI;kBAAQ,KAAK;;;qBAAjB,IAAI;kBAAQ,KAAK;;qBAAjB,IAAI;kBAAQ,KAAK;;;EAazD;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,yCAAyC;IACzC,QAAQ,EAAE,MAAM,CAAA;IAChB,qFAAqF;IACrF,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED;;;GAGG;AACH,wBAAsB,SAAS,CAAC,KAAK,EACnC,EAAE,EAAE,MAAM,OAAO,CAAC,KAAK,CAAC,EACxB,EAAE,QAAQ,EAAE,SAAoB,EAAE,EAAE,mBAAmB,kBAmCxD"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import type { Hex, Signature } from '../../types/misc.js';
|
2
|
+
/**
|
3
|
+
* @description Parses a hex formatted signature into a structured signature.
|
4
|
+
*
|
5
|
+
* @param signatureHex Signature in hex format.
|
6
|
+
* @returns The structured signature.
|
7
|
+
*
|
8
|
+
* @example
|
9
|
+
* hexToSignature('0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c')
|
10
|
+
* // { r: '0x...', s: '0x...', v: 28n }
|
11
|
+
*/
|
12
|
+
export declare function hexToSignature(signatureHex: Hex): Signature;
|
13
|
+
//# sourceMappingURL=hexToSignature.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"hexToSignature.d.ts","sourceRoot":"","sources":["../../../../src/utils/signature/hexToSignature.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAGzD;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAAC,YAAY,EAAE,GAAG,GAAG,SAAS,CAI3D"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
import type { Hex, Signature } from '../../types/misc.js';
|
2
|
+
/**
|
3
|
+
* @description Converts a signature into hex format.
|
4
|
+
*
|
5
|
+
* @param signature The signature to convert.
|
6
|
+
* @returns The signature in hex format.
|
7
|
+
*
|
8
|
+
* @example
|
9
|
+
* signatureToHex({
|
10
|
+
* r: '0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf',
|
11
|
+
* s: '0x4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db8',
|
12
|
+
* v: 28n
|
13
|
+
* })
|
14
|
+
* // "0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c"
|
15
|
+
*/
|
16
|
+
export declare function signatureToHex({ r, s, v }: Signature): Hex;
|
17
|
+
//# sourceMappingURL=signatureToHex.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"signatureToHex.d.ts","sourceRoot":"","sources":["../../../../src/utils/signature/signatureToHex.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAIzD;;;;;;;;;;;;;GAaG;AACH,wBAAgB,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,SAAS,GAAG,GAAG,CAK1D"}
|
@@ -4,15 +4,11 @@ import type { SendTransactionParameters } from '../../actions/wallet/sendTransac
|
|
4
4
|
import type { Client } from '../../clients/createClient.js';
|
5
5
|
import type { Transport } from '../../clients/transports/createTransport.js';
|
6
6
|
import type { GetAccountParameter } from '../../types/account.js';
|
7
|
-
import type { Chain } from '../../types/chain.js';
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
maxPriorityFeePerGas?: SendTransactionParameters['maxPriorityFeePerGas'];
|
13
|
-
nonce?: SendTransactionParameters['nonce'];
|
14
|
-
};
|
15
|
-
export type PrepareRequestReturnType<TAccount extends Account | undefined = undefined, TParameters extends PrepareRequestParameters<TAccount> = PrepareRequestParameters<TAccount>> = TParameters & {
|
7
|
+
import type { Chain, GetChain } from '../../types/chain.js';
|
8
|
+
import type { UnionOmit } from '../../types/utils.js';
|
9
|
+
import type { FormattedTransactionRequest } from '../index.js';
|
10
|
+
export type PrepareRequestParameters<TChain extends Chain | undefined = Chain | undefined, TAccount extends Account | undefined = Account | undefined, TChainOverride extends Chain | undefined = Chain | undefined> = UnionOmit<FormattedTransactionRequest<TChainOverride extends Chain ? TChainOverride : TChain>, 'from'> & GetAccountParameter<TAccount> & GetChain<TChain, TChainOverride>;
|
11
|
+
export type PrepareRequestReturnType<TChain extends Chain | undefined = Chain | undefined, TAccount extends Account | undefined = Account | undefined, TChainOverride extends Chain | undefined = Chain | undefined, TArgs extends PrepareRequestParameters<TChain, TAccount, TChainOverride> = PrepareRequestParameters<TChain, TAccount, TChainOverride>> = TArgs & {
|
16
12
|
from: Address;
|
17
13
|
gas: SendTransactionParameters['gas'];
|
18
14
|
gasPrice?: SendTransactionParameters['gasPrice'];
|
@@ -20,6 +16,5 @@ export type PrepareRequestReturnType<TAccount extends Account | undefined = unde
|
|
20
16
|
maxPriorityFeePerGas?: SendTransactionParameters['maxPriorityFeePerGas'];
|
21
17
|
nonce: SendTransactionParameters['nonce'];
|
22
18
|
};
|
23
|
-
export declare
|
24
|
-
export declare function prepareRequest<TChain extends Chain | undefined, TAccount extends Account | undefined, TParameters extends PrepareRequestParameters<TAccount>>(client: Client<Transport, TChain, TAccount>, args: TParameters): Promise<PrepareRequestReturnType<TAccount, TParameters>>;
|
19
|
+
export declare function prepareRequest<TChain extends Chain | undefined, TAccount extends Account | undefined, TChainOverride extends Chain | undefined, TArgs extends PrepareRequestParameters<TChain, TAccount, TChainOverride>>(client: Client<Transport, TChain, TAccount>, args: TArgs): Promise<PrepareRequestReturnType<TChain, TAccount, TChainOverride, TArgs>>;
|
25
20
|
//# sourceMappingURL=prepareRequest.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"prepareRequest.d.ts","sourceRoot":"","sources":["../../../../src/utils/transaction/prepareRequest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AAStD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yCAAyC,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAA;AAG5E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAA;
|
1
|
+
{"version":3,"file":"prepareRequest.d.ts","sourceRoot":"","sources":["../../../../src/utils/transaction/prepareRequest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AAStD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yCAAyC,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAA;AAG5E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAA;AACrD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAA;AAG9D,MAAM,MAAM,wBAAwB,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EACpD,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,EAC1D,cAAc,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,IAC1D,SAAS,CACX,2BAA2B,CACzB,cAAc,SAAS,KAAK,GAAG,cAAc,GAAG,MAAM,CACvD,EACD,MAAM,CACP,GACC,mBAAmB,CAAC,QAAQ,CAAC,GAC7B,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;AAElC,MAAM,MAAM,wBAAwB,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EACpD,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,EAC1D,cAAc,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EAC5D,KAAK,SAAS,wBAAwB,CACpC,MAAM,EACN,QAAQ,EACR,cAAc,CACf,GAAG,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,IAC5D,KAAK,GAAG;IACV,IAAI,EAAE,OAAO,CAAA;IACb,GAAG,EAAE,yBAAyB,CAAC,KAAK,CAAC,CAAA;IACrC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,UAAU,CAAC,CAAA;IAChD,YAAY,CAAC,EAAE,yBAAyB,CAAC,cAAc,CAAC,CAAA;IACxD,oBAAoB,CAAC,EAAE,yBAAyB,CAAC,sBAAsB,CAAC,CAAA;IACxE,KAAK,EAAE,yBAAyB,CAAC,OAAO,CAAC,CAAA;CAC1C,CAAA;AAED,wBAAsB,cAAc,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,EAChC,QAAQ,SAAS,OAAO,GAAG,SAAS,EACpC,cAAc,SAAS,KAAK,GAAG,SAAS,EACxC,KAAK,SAAS,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,EAExE,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAC3C,IAAI,EAAE,KAAK,GACV,OAAO,CAAC,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC,CAiF5E"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"parseUnits.d.ts","sourceRoot":"","sources":["../../../../src/utils/unit/parseUnits.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,
|
1
|
+
{"version":3,"file":"parseUnits.d.ts","sourceRoot":"","sources":["../../../../src/utils/unit/parseUnits.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,UAqCzD"}
|
package/package.json
CHANGED
@@ -3,10 +3,11 @@
|
|
3
3
|
"description": "TypeScript Interface for Ethereum",
|
4
4
|
"dependencies": {
|
5
5
|
"@adraffy/ens-normalize": "1.9.0",
|
6
|
-
"@noble/curves": "1.
|
6
|
+
"@noble/curves": "1.1.0",
|
7
7
|
"@noble/hashes": "1.3.0",
|
8
8
|
"@scure/bip32": "1.3.0",
|
9
9
|
"@scure/bip39": "1.2.0",
|
10
|
+
"@types/ws": "^8.5.4",
|
10
11
|
"@wagmi/chains": "1.6.0",
|
11
12
|
"abitype": "0.9.3",
|
12
13
|
"isomorphic-ws": "5.0.0",
|
@@ -20,7 +21,7 @@
|
|
20
21
|
"optional": true
|
21
22
|
}
|
22
23
|
},
|
23
|
-
"version": "0.0.0-w-
|
24
|
+
"version": "0.0.0-w-20230810155401",
|
24
25
|
"files": [
|
25
26
|
"dist",
|
26
27
|
"!dist/**/*.tsbuildinfo",
|
@@ -33,6 +34,7 @@
|
|
33
34
|
"accounts",
|
34
35
|
"actions",
|
35
36
|
"chains",
|
37
|
+
"chains/utils",
|
36
38
|
"contract",
|
37
39
|
"ens",
|
38
40
|
"public",
|
@@ -67,6 +69,11 @@
|
|
67
69
|
"import": "./dist/esm/chains/index.js",
|
68
70
|
"default": "./dist/cjs/chains/index.js"
|
69
71
|
},
|
72
|
+
"./chains/utils": {
|
73
|
+
"types": "./dist/types/chains/utils.d.ts",
|
74
|
+
"import": "./dist/esm/chains/utils.js",
|
75
|
+
"default": "./dist/cjs/chains/utils.js"
|
76
|
+
},
|
70
77
|
"./contract": {
|
71
78
|
"types": "./dist/types/contract.d.ts",
|
72
79
|
"import": "./dist/esm/contract.js",
|
package/src/accounts/index.ts
CHANGED
@@ -17,12 +17,17 @@ export type {
|
|
17
17
|
PrivateKeyAccount,
|
18
18
|
} from './types.js'
|
19
19
|
export { type SignParameters, type SignReturnType, sign } from './utils/sign.js'
|
20
|
-
export { signatureToHex } from '
|
20
|
+
export { signatureToHex } from '../utils/signature/signatureToHex.js'
|
21
21
|
export {
|
22
22
|
type SignMessageParameters,
|
23
23
|
type SignMessageReturnType,
|
24
24
|
signMessage,
|
25
25
|
} from './utils/signMessage.js'
|
26
|
+
export {
|
27
|
+
type SignTransactionParameters,
|
28
|
+
type SignTransactionReturnType,
|
29
|
+
signTransaction,
|
30
|
+
} from './utils/signTransaction.js'
|
26
31
|
export {
|
27
32
|
type SignTypedDataParameters,
|
28
33
|
type SignTypedDataReturnType,
|
@@ -30,6 +35,7 @@ export {
|
|
30
35
|
} from './utils/signTypedData.js'
|
31
36
|
export { parseAccount } from './utils/parseAccount.js'
|
32
37
|
export { publicKeyToAddress } from './utils/publicKeyToAddress.js'
|
38
|
+
export { privateKeyToAddress } from './utils/privateKeyToAddress.js'
|
33
39
|
export { czech } from './wordlists/czech.js'
|
34
40
|
export { english } from './wordlists/english.js'
|
35
41
|
export { french } from './wordlists/french.js'
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { secp256k1 } from '@noble/curves/secp256k1'
|
2
|
+
import type { Address } from 'abitype'
|
3
|
+
|
4
|
+
import type { Hex } from '../../types/misc.js'
|
5
|
+
import { bytesToHex } from '../../utils/encoding/toHex.js'
|
6
|
+
import { publicKeyToAddress } from './publicKeyToAddress.js'
|
7
|
+
|
8
|
+
/**
|
9
|
+
* @description Converts an ECDSA private key to an address.
|
10
|
+
*
|
11
|
+
* @param privateKey The private key to convert.
|
12
|
+
*
|
13
|
+
* @returns The address.
|
14
|
+
*/
|
15
|
+
export function privateKeyToAddress(privateKey: Hex): Address {
|
16
|
+
const publicKey = bytesToHex(
|
17
|
+
secp256k1.getPublicKey(privateKey.slice(2), false),
|
18
|
+
)
|
19
|
+
return publicKeyToAddress(publicKey)
|
20
|
+
}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
import type { Hex, SignableMessage } from '../../types/misc.js'
|
2
2
|
import { hashMessage } from '../../utils/signature/hashMessage.js'
|
3
|
+
import { signatureToHex } from '../../utils/signature/signatureToHex.js'
|
3
4
|
|
4
5
|
import { sign } from './sign.js'
|
5
|
-
import { signatureToHex } from './signatureToHex.js'
|
6
6
|
|
7
7
|
export type SignMessageParameters = {
|
8
8
|
/** The message to sign. */
|
@@ -12,7 +12,7 @@ import {
|
|
12
12
|
|
13
13
|
import { sign } from './sign.js'
|
14
14
|
|
15
|
-
export type
|
15
|
+
export type SignTransactionParameters<
|
16
16
|
TTransactionSerializable extends TransactionSerializable = TransactionSerializable,
|
17
17
|
> = {
|
18
18
|
privateKey: Hex
|
@@ -31,7 +31,7 @@ export async function signTransaction<
|
|
31
31
|
privateKey,
|
32
32
|
transaction,
|
33
33
|
serializer = serializeTransaction,
|
34
|
-
}:
|
34
|
+
}: SignTransactionParameters<TTransactionSerializable>): Promise<
|
35
35
|
SignTransactionReturnType<TTransactionSerializable>
|
36
36
|
> {
|
37
37
|
const signature = await sign({
|
@@ -3,9 +3,9 @@ import type { TypedData } from 'abitype'
|
|
3
3
|
import type { Hex } from '../../types/misc.js'
|
4
4
|
import type { TypedDataDefinition } from '../../types/typedData.js'
|
5
5
|
import { hashTypedData } from '../../utils/signature/hashTypedData.js'
|
6
|
+
import { signatureToHex } from '../../utils/signature/signatureToHex.js'
|
6
7
|
|
7
8
|
import { sign } from './sign.js'
|
8
|
-
import { signatureToHex } from './signatureToHex.js'
|
9
9
|
|
10
10
|
export type SignTypedDataParameters<
|
11
11
|
typedData extends TypedData | Record<string, unknown> = TypedData,
|
@@ -3,7 +3,7 @@ import type { Address } from 'abitype'
|
|
3
3
|
import type { Client } from '../../clients/createClient.js'
|
4
4
|
import type { Transport } from '../../clients/transports/createTransport.js'
|
5
5
|
import {
|
6
|
-
|
6
|
+
addressResolverAbi,
|
7
7
|
universalResolverResolveAbi,
|
8
8
|
} from '../../constants/abis.js'
|
9
9
|
import type { Chain } from '../../types/chain.js'
|
@@ -23,6 +23,8 @@ import {
|
|
23
23
|
|
24
24
|
export type GetEnsAddressParameters = Prettify<
|
25
25
|
Pick<ReadContractParameters, 'blockNumber' | 'blockTag'> & {
|
26
|
+
/** ENSIP-9 compliant coinType used to resolve addresses for other chains */
|
27
|
+
coinType?: number
|
26
28
|
/** Name to get the address for. */
|
27
29
|
name: string
|
28
30
|
/** Address of ENS Universal Resolver Contract. */
|
@@ -65,6 +67,7 @@ export async function getEnsAddress<TChain extends Chain | undefined,>(
|
|
65
67
|
{
|
66
68
|
blockNumber,
|
67
69
|
blockTag,
|
70
|
+
coinType,
|
68
71
|
name,
|
69
72
|
universalResolverAddress: universalResolverAddress_,
|
70
73
|
}: GetEnsAddressParameters,
|
@@ -84,31 +87,37 @@ export async function getEnsAddress<TChain extends Chain | undefined,>(
|
|
84
87
|
}
|
85
88
|
|
86
89
|
try {
|
90
|
+
const functionData = encodeFunctionData({
|
91
|
+
abi: addressResolverAbi,
|
92
|
+
functionName: 'addr',
|
93
|
+
...(coinType != null
|
94
|
+
? { args: [namehash(name), BigInt(coinType)] }
|
95
|
+
: { args: [namehash(name)] }),
|
96
|
+
})
|
97
|
+
|
87
98
|
const res = await readContract(client, {
|
88
99
|
address: universalResolverAddress,
|
89
100
|
abi: universalResolverResolveAbi,
|
90
101
|
functionName: 'resolve',
|
91
|
-
args: [
|
92
|
-
toHex(packetToBytes(name)),
|
93
|
-
encodeFunctionData({
|
94
|
-
abi: singleAddressResolverAbi,
|
95
|
-
functionName: 'addr',
|
96
|
-
args: [namehash(name)],
|
97
|
-
}),
|
98
|
-
],
|
102
|
+
args: [toHex(packetToBytes(name)), functionData],
|
99
103
|
blockNumber,
|
100
104
|
blockTag,
|
101
105
|
})
|
102
106
|
|
103
107
|
if (res[0] === '0x') return null
|
104
108
|
|
105
|
-
const address =
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
109
|
+
const address = trim(
|
110
|
+
decodeFunctionResult({
|
111
|
+
abi: addressResolverAbi,
|
112
|
+
args: coinType != null ? [namehash(name), BigInt(coinType)] : undefined,
|
113
|
+
functionName: 'addr',
|
114
|
+
data: res[0],
|
115
|
+
}),
|
116
|
+
)
|
110
117
|
|
111
|
-
|
118
|
+
if (address === '0x') return null
|
119
|
+
if (trim(address) === '0x00') return null
|
120
|
+
return address
|
112
121
|
} catch (err) {
|
113
122
|
if (isNullUniversalResolverError(err, 'resolve')) return null
|
114
123
|
throw err
|
package/src/actions/index.ts
CHANGED
@@ -160,8 +160,12 @@ export {
|
|
160
160
|
watchBlockNumber,
|
161
161
|
} from './public/watchBlockNumber.js'
|
162
162
|
export {
|
163
|
-
type
|
164
|
-
|
163
|
+
type WatchEventOnLogsFn,
|
164
|
+
/** @deprecated - use `WatchEventOnLogsFn` instead. */
|
165
|
+
type WatchEventOnLogsFn as OnLogsFn,
|
166
|
+
type WatchEventOnLogsParameter,
|
167
|
+
/** @deprecated - use `WatchEventOnLogsParameter` instead. */
|
168
|
+
type WatchEventOnLogsParameter as OnLogsParameter,
|
165
169
|
type WatchEventParameters,
|
166
170
|
type WatchEventReturnType,
|
167
171
|
watchEvent,
|
@@ -9,6 +9,7 @@ import type {
|
|
9
9
|
MaybeExtractEventArgsFromAbi,
|
10
10
|
} from '../../types/contract.js'
|
11
11
|
import type { Filter } from '../../types/filter.js'
|
12
|
+
import type { Hex } from '../../types/misc.js'
|
12
13
|
import {
|
13
14
|
type EncodeEventTopicsParameters,
|
14
15
|
encodeEventTopics,
|
@@ -23,17 +24,19 @@ export type CreateContractEventFilterParameters<
|
|
23
24
|
| MaybeExtractEventArgsFromAbi<TAbi, TEventName>
|
24
25
|
| undefined = undefined,
|
25
26
|
TStrict extends boolean | undefined = undefined,
|
27
|
+
TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
|
28
|
+
TToBlock extends BlockNumber | BlockTag | undefined = undefined,
|
26
29
|
> = {
|
27
30
|
address?: Address | Address[]
|
28
31
|
abi: Narrow<TAbi>
|
29
32
|
eventName?: InferEventName<TAbi, TEventName>
|
30
|
-
fromBlock?: BlockNumber | BlockTag
|
33
|
+
fromBlock?: TFromBlock | BlockNumber | BlockTag
|
31
34
|
/**
|
32
35
|
* Whether or not the logs must match the indexed/non-indexed arguments in the event ABI item.
|
33
36
|
* @default false
|
34
37
|
*/
|
35
38
|
strict?: TStrict
|
36
|
-
toBlock?: BlockNumber | BlockTag
|
39
|
+
toBlock?: TToBlock | BlockNumber | BlockTag
|
37
40
|
} & (undefined extends TEventName
|
38
41
|
? {
|
39
42
|
args?: never
|
@@ -56,7 +59,9 @@ export type CreateContractEventFilterReturnType<
|
|
56
59
|
| MaybeExtractEventArgsFromAbi<TAbi, TEventName>
|
57
60
|
| undefined = undefined,
|
58
61
|
TStrict extends boolean | undefined = undefined,
|
59
|
-
|
62
|
+
TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
|
63
|
+
TToBlock extends BlockNumber | BlockTag | undefined = undefined,
|
64
|
+
> = Filter<'event', TAbi, TEventName, TArgs, TStrict, TFromBlock, TToBlock>
|
60
65
|
|
61
66
|
/**
|
62
67
|
* Creates a Filter to retrieve event logs that can be used with [`getFilterChanges`](https://viem.sh/docs/actions/public/getFilterChanges.html) or [`getFilterLogs`](https://viem.sh/docs/actions/public/getFilterLogs.html).
|
@@ -86,6 +91,8 @@ export async function createContractEventFilter<
|
|
86
91
|
TEventName extends string | undefined,
|
87
92
|
TArgs extends MaybeExtractEventArgsFromAbi<TAbi, TEventName> | undefined,
|
88
93
|
TStrict extends boolean | undefined = undefined,
|
94
|
+
TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
|
95
|
+
TToBlock extends BlockNumber | BlockTag | undefined = undefined,
|
89
96
|
>(
|
90
97
|
client: Client<Transport, TChain>,
|
91
98
|
{
|
@@ -96,9 +103,23 @@ export async function createContractEventFilter<
|
|
96
103
|
fromBlock,
|
97
104
|
strict,
|
98
105
|
toBlock,
|
99
|
-
}: CreateContractEventFilterParameters<
|
106
|
+
}: CreateContractEventFilterParameters<
|
107
|
+
TAbi,
|
108
|
+
TEventName,
|
109
|
+
TArgs,
|
110
|
+
TStrict,
|
111
|
+
TFromBlock,
|
112
|
+
TToBlock
|
113
|
+
>,
|
100
114
|
): Promise<
|
101
|
-
CreateContractEventFilterReturnType<
|
115
|
+
CreateContractEventFilterReturnType<
|
116
|
+
TAbi,
|
117
|
+
TEventName,
|
118
|
+
TArgs,
|
119
|
+
TStrict,
|
120
|
+
TFromBlock,
|
121
|
+
TToBlock
|
122
|
+
>
|
102
123
|
> {
|
103
124
|
const getRequest = createFilterRequestScope(client, {
|
104
125
|
method: 'eth_newFilter',
|
@@ -111,7 +132,7 @@ export async function createContractEventFilter<
|
|
111
132
|
eventName,
|
112
133
|
} as unknown as EncodeEventTopicsParameters)
|
113
134
|
: undefined
|
114
|
-
const id = await client.request({
|
135
|
+
const id: Hex = await client.request({
|
115
136
|
method: 'eth_newFilter',
|
116
137
|
params: [
|
117
138
|
{
|
@@ -136,6 +157,8 @@ export async function createContractEventFilter<
|
|
136
157
|
TAbi,
|
137
158
|
TEventName,
|
138
159
|
TArgs,
|
139
|
-
TStrict
|
160
|
+
TStrict,
|
161
|
+
TFromBlock,
|
162
|
+
TToBlock
|
140
163
|
>
|
141
164
|
}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import type {
|
1
|
+
import type { AbiEvent, Address, Narrow } from 'abitype'
|
2
2
|
|
3
3
|
import type { Client } from '../../clients/createClient.js'
|
4
4
|
import type { Transport } from '../../clients/transports/createTransport.js'
|
@@ -9,7 +9,7 @@ import type {
|
|
9
9
|
MaybeExtractEventArgsFromAbi,
|
10
10
|
} from '../../types/contract.js'
|
11
11
|
import type { Filter } from '../../types/filter.js'
|
12
|
-
import type { LogTopic } from '../../types/misc.js'
|
12
|
+
import type { Hex, LogTopic } from '../../types/misc.js'
|
13
13
|
import type { Prettify } from '../../types/utils.js'
|
14
14
|
import {
|
15
15
|
type EncodeEventTopicsParameters,
|
@@ -20,18 +20,23 @@ import { createFilterRequestScope } from '../../utils/filters/createFilterReques
|
|
20
20
|
|
21
21
|
export type CreateEventFilterParameters<
|
22
22
|
TAbiEvent extends AbiEvent | undefined = undefined,
|
23
|
+
TAbiEvents extends
|
24
|
+
| readonly AbiEvent[]
|
25
|
+
| readonly unknown[]
|
26
|
+
| undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
|
23
27
|
TStrict extends boolean | undefined = undefined,
|
24
|
-
|
28
|
+
TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
|
29
|
+
TToBlock extends BlockNumber | BlockTag | undefined = undefined,
|
25
30
|
_EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
|
26
31
|
_Args extends
|
27
|
-
| MaybeExtractEventArgsFromAbi<
|
32
|
+
| MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
|
28
33
|
| undefined = undefined,
|
29
34
|
> = {
|
30
35
|
address?: Address | Address[]
|
31
|
-
fromBlock?: BlockNumber | BlockTag
|
32
|
-
toBlock?: BlockNumber | BlockTag
|
36
|
+
fromBlock?: TFromBlock | BlockNumber | BlockTag
|
37
|
+
toBlock?: TToBlock | BlockNumber | BlockTag
|
33
38
|
} & (MaybeExtractEventArgsFromAbi<
|
34
|
-
|
39
|
+
TAbiEvents,
|
35
40
|
_EventName
|
36
41
|
> extends infer TEventFilterArgs
|
37
42
|
?
|
@@ -40,6 +45,7 @@ export type CreateEventFilterParameters<
|
|
40
45
|
| TEventFilterArgs
|
41
46
|
| (_Args extends TEventFilterArgs ? _Args : never)
|
42
47
|
event: Narrow<TAbiEvent>
|
48
|
+
events?: never
|
43
49
|
/**
|
44
50
|
* Whether or not the logs must match the indexed/non-indexed arguments on `event`.
|
45
51
|
* @default false
|
@@ -49,6 +55,7 @@ export type CreateEventFilterParameters<
|
|
49
55
|
| {
|
50
56
|
args?: never
|
51
57
|
event?: Narrow<TAbiEvent>
|
58
|
+
events?: never
|
52
59
|
/**
|
53
60
|
* Whether or not the logs must match the indexed/non-indexed arguments on `event`.
|
54
61
|
* @default false
|
@@ -58,23 +65,42 @@ export type CreateEventFilterParameters<
|
|
58
65
|
| {
|
59
66
|
args?: never
|
60
67
|
event?: never
|
68
|
+
events: Narrow<TAbiEvents>
|
69
|
+
/**
|
70
|
+
* Whether or not the logs must match the indexed/non-indexed arguments on `event`.
|
71
|
+
* @default false
|
72
|
+
*/
|
73
|
+
strict?: TStrict
|
74
|
+
}
|
75
|
+
| {
|
76
|
+
args?: never
|
77
|
+
event?: never
|
78
|
+
events?: never
|
61
79
|
strict?: never
|
62
80
|
}
|
63
81
|
: {
|
64
82
|
args?: never
|
65
83
|
event?: never
|
84
|
+
events?: never
|
66
85
|
strict?: never
|
67
86
|
})
|
68
87
|
|
69
88
|
export type CreateEventFilterReturnType<
|
70
89
|
TAbiEvent extends AbiEvent | undefined = undefined,
|
90
|
+
TAbiEvents extends
|
91
|
+
| readonly AbiEvent[]
|
92
|
+
| readonly unknown[]
|
93
|
+
| undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
|
71
94
|
TStrict extends boolean | undefined = undefined,
|
72
|
-
|
95
|
+
TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
|
96
|
+
TToBlock extends BlockNumber | BlockTag | undefined = undefined,
|
73
97
|
_EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
|
74
98
|
_Args extends
|
75
|
-
| MaybeExtractEventArgsFromAbi<
|
99
|
+
| MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
|
76
100
|
| undefined = undefined,
|
77
|
-
> = Prettify<
|
101
|
+
> = Prettify<
|
102
|
+
Filter<'event', TAbiEvents, _EventName, _Args, TStrict, TFromBlock, TToBlock>
|
103
|
+
>
|
78
104
|
|
79
105
|
/**
|
80
106
|
* Creates a [`Filter`](https://viem.sh/docs/glossary/types.html#filter) to listen for new events that can be used with [`getFilterChanges`](https://viem.sh/docs/actions/public/getFilterChanges.html).
|
@@ -101,12 +127,17 @@ export type CreateEventFilterReturnType<
|
|
101
127
|
*/
|
102
128
|
export async function createEventFilter<
|
103
129
|
TChain extends Chain | undefined,
|
104
|
-
TAbiEvent extends AbiEvent | undefined,
|
130
|
+
TAbiEvent extends AbiEvent | undefined = undefined,
|
131
|
+
TAbiEvents extends
|
132
|
+
| readonly AbiEvent[]
|
133
|
+
| readonly unknown[]
|
134
|
+
| undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
|
105
135
|
TStrict extends boolean | undefined = undefined,
|
106
|
-
|
136
|
+
TFromBlock extends BlockNumber<bigint> | BlockTag | undefined = undefined,
|
137
|
+
TToBlock extends BlockNumber<bigint> | BlockTag | undefined = undefined,
|
107
138
|
_EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
|
108
139
|
_Args extends
|
109
|
-
| MaybeExtractEventArgsFromAbi<
|
140
|
+
| MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
|
110
141
|
| undefined = undefined,
|
111
142
|
>(
|
112
143
|
client: Client<Transport, TChain>,
|
@@ -114,32 +145,51 @@ export async function createEventFilter<
|
|
114
145
|
address,
|
115
146
|
args,
|
116
147
|
event,
|
148
|
+
events: events_,
|
117
149
|
fromBlock,
|
118
150
|
strict,
|
119
151
|
toBlock,
|
120
152
|
}: CreateEventFilterParameters<
|
121
153
|
TAbiEvent,
|
154
|
+
TAbiEvents,
|
122
155
|
TStrict,
|
123
|
-
|
156
|
+
TFromBlock,
|
157
|
+
TToBlock,
|
124
158
|
_EventName,
|
125
159
|
_Args
|
126
160
|
> = {} as any,
|
127
161
|
): Promise<
|
128
|
-
CreateEventFilterReturnType<
|
162
|
+
CreateEventFilterReturnType<
|
163
|
+
TAbiEvent,
|
164
|
+
TAbiEvents,
|
165
|
+
TStrict,
|
166
|
+
TFromBlock,
|
167
|
+
TToBlock,
|
168
|
+
_EventName,
|
169
|
+
_Args
|
170
|
+
>
|
129
171
|
> {
|
172
|
+
const events = events_ ?? (event ? [event] : undefined)
|
173
|
+
|
130
174
|
const getRequest = createFilterRequestScope(client, {
|
131
175
|
method: 'eth_newFilter',
|
132
176
|
})
|
133
177
|
|
134
178
|
let topics: LogTopic[] = []
|
135
|
-
if (
|
136
|
-
topics =
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
179
|
+
if (events) {
|
180
|
+
topics = [
|
181
|
+
(events as AbiEvent[]).flatMap((event) =>
|
182
|
+
encodeEventTopics({
|
183
|
+
abi: [event],
|
184
|
+
eventName: (event as AbiEvent).name,
|
185
|
+
args,
|
186
|
+
} as EncodeEventTopicsParameters),
|
187
|
+
),
|
188
|
+
]
|
189
|
+
if (event) topics = topics[0] as LogTopic[]
|
190
|
+
}
|
141
191
|
|
142
|
-
const id = await client.request({
|
192
|
+
const id: Hex = await client.request({
|
143
193
|
method: 'eth_newFilter',
|
144
194
|
params: [
|
145
195
|
{
|
@@ -153,17 +203,21 @@ export async function createEventFilter<
|
|
153
203
|
})
|
154
204
|
|
155
205
|
return {
|
156
|
-
abi:
|
206
|
+
abi: events,
|
157
207
|
args,
|
158
208
|
eventName: event ? (event as AbiEvent).name : undefined,
|
209
|
+
fromBlock,
|
159
210
|
id,
|
160
211
|
request: getRequest(id),
|
161
212
|
strict,
|
213
|
+
toBlock,
|
162
214
|
type: 'event',
|
163
215
|
} as unknown as CreateEventFilterReturnType<
|
164
216
|
TAbiEvent,
|
217
|
+
TAbiEvents,
|
165
218
|
TStrict,
|
166
|
-
|
219
|
+
TFromBlock,
|
220
|
+
TToBlock,
|
167
221
|
_EventName,
|
168
222
|
_Args
|
169
223
|
>
|