<!--
Sitemap:
- [Why Viem](/docs/introduction): A brief preamble on why we built Viem
- [Installation](/docs/installation)
- [Getting Started](/docs/getting-started): Get started with viem in just a few lines of code.
- [Platform Compatibility](/docs/compatibility): Platforms compatible with Viem
- [Frequently Asked Questions](/docs/faq)
- [Migration Guide](/docs/migration-guide)
- [Ethers v5 → viem Migration Guide](/docs/ethers-migration): Migrate from Ethers v5 to viem
- [TypeScript](/docs/typescript): TypeScript support for Viem
- [Error Handling](/docs/error-handling)
- [EIP-7702 Overview](/docs/eip7702): An Overview of EIP-7702
- [Contract Writes with EIP-7702](/docs/eip7702/contract-writes)
- [Sending Transactions with EIP-7702](/docs/eip7702/sending-transactions)
- [Blob Transactions](/docs/guides/blob-transactions): Sending your first Blob Transaction with Viem.
- [Introduction to Clients & Transports](/docs/clients/intro): A brief introduction to Clients & Transports.
- [Public Client](/docs/clients/public): A function to create a Public Client
- [Wallet Client](/docs/clients/wallet): A function to create a Wallet Client.
- [Test Client](/docs/clients/test): A function to create a Test Client
- [Build your own Client](/docs/clients/custom)
- [HTTP Transport](/docs/clients/transports/http): A function to create a HTTP Transport for a Client
- [WebSocket Transport](/docs/clients/transports/websocket): A function to create a WebSocket Transport for a Client
- [Custom Transport](/docs/clients/transports/custom): A function to create a Custom Transport for a Client
- [IPC Transport](/docs/clients/transports/ipc): A function to create an IPC Transport for a Client
- [Fallback Transport](/docs/clients/transports/fallback): A function to create a Fallback Transport for a Client
- [Introduction to Public Actions](/docs/actions/public/introduction): A brief introduction on what Public Actions are in viem.
- [createAccessList](/docs/actions/public/createAccessList)
- [getBalance](/docs/actions/public/getBalance): Returns the balance of an address in wei.
- [getTransactionCount](/docs/actions/public/getTransactionCount): Returns the number of Transactions an Account has sent.
- [getBlock](/docs/actions/public/getBlock): Returns information about a block at a block number, hash or tag.
- [getBlockReceipts](/docs/actions/public/getBlockReceipts): Returns the transaction receipts of a block at a block number, hash or tag.
- [getBlockNumber](/docs/actions/public/getBlockNumber): Returns the number of the most recent block seen.
- [getBlockTransactionCount](/docs/actions/public/getBlockTransactionCount): Returns the number of Transactions at a block number, hash or tag.
- [simulateBlocks](/docs/actions/public/simulateBlocks): Simulates a set of calls on block(s).
- [watchBlockNumber](/docs/actions/public/watchBlockNumber): Watches and returns incoming block numbers.
- [watchBlocks](/docs/actions/public/watchBlocks): Watches and returns information for incoming blocks.
- [call](/docs/actions/public/call): An Action for executing a new message call.
- [simulateCalls](/docs/actions/public/simulateCalls): Simulates a set of calls on block(s).
- [getChainId](/docs/actions/public/getChainId): Returns the chain ID associated with the current network
- [getEip712Domain](/docs/actions/public/getEip712Domain): Reads the EIP-712 domain from a contract.
- [estimateFeesPerGas](/docs/actions/public/estimateFeesPerGas): Returns an estimate for the fees per gas (in wei) for a transaction to be likely included in the next block.
- [estimateGas](/docs/actions/public/estimateGas): An Action for estimating gas for a transaction.
- [estimateMaxPriorityFeePerGas](/docs/actions/public/estimateMaxPriorityFeePerGas): Returns an estimate for the max priority fee per gas (in wei) for a transaction to be likely included in the next block.
- [getBlobBaseFee](/docs/actions/public/getBlobBaseFee): Returns the current blob base fee (in wei).
- [getFeeHistory](/docs/actions/public/getFeeHistory): Returns a collection of historical gas information.
- [getGasPrice](/docs/actions/public/getGasPrice): Returns the current price of gas (in wei).
- [createBlockFilter](/docs/actions/public/createBlockFilter): An Action for creating a new Block Filter.
- [createEventFilter](/docs/actions/public/createEventFilter): An Action for creating a new Event Filter.
- [createPendingTransactionFilter](/docs/actions/public/createPendingTransactionFilter): An Action for creating a new pending transaction filter.
- [getFilterChanges](/docs/actions/public/getFilterChanges): Returns a list of logs or hashes based on a Filter.
- [getFilterLogs](/docs/actions/public/getFilterLogs): Returns a list of event logs since the filter was created.
- [getLogs](/docs/actions/public/getLogs): Returns a list of event logs matching the provided parameters.
- [watchEvent](/docs/actions/public/watchEvent): Watches and returns emitted Event Logs.
- [uninstallFilter](/docs/actions/public/uninstallFilter): Destroys a Filter.
- [getProof](/docs/actions/public/getProof): Returns the account and storage values of the specified account including the Merkle-proof.
- [verifyMessage](/docs/actions/public/verifyMessage): Verifies if a signed message was generated by the provided address.
- [verifyTypedData](/docs/actions/public/verifyTypedData): Verifies a typed data signature
- [prepareTransactionRequest](/docs/actions/wallet/prepareTransactionRequest): Prepares a transaction request for signing.
- [getTransaction](/docs/actions/public/getTransaction): Returns information about a transaction given a hash or block identifier.
- [getTransactionConfirmations](/docs/actions/public/getTransactionConfirmations): Returns the number of blocks passed (confirmations) since the transaction was processed on a block.
- [getTransactionReceipt](/docs/actions/public/getTransactionReceipt): Returns the transaction receipt given a transaction hash.
- [sendRawTransaction](/docs/actions/wallet/sendRawTransaction): Sends a signed transaction to the network
- [waitForTransactionReceipt](/docs/actions/public/waitForTransactionReceipt): Retrieves a Transaction Receipt for a given Transaction hash.
- [watchPendingTransactions](/docs/actions/public/watchPendingTransactions): Watches and returns pending transaction hashes.
- [Introduction to Wallet Actions](/docs/actions/wallet/introduction): A brief introduction to Wallet Actions in viem.
- [getAddresses](/docs/actions/wallet/getAddresses): Returns a list of addresses owned by the wallet or client.
- [requestAddresses](/docs/actions/wallet/requestAddresses): Requests a list of accounts managed by a wallet.
- [watchAsset](/docs/actions/wallet/watchAsset): Requests that the user tracks the token in their wallet.
- [getCallsStatus](/docs/actions/wallet/getCallsStatus): Returns the status of a call batch.
- [getCapabilities](/docs/actions/wallet/getCapabilities): Extract capabilities that a connected wallet supports.
- [sendCalls](/docs/actions/wallet/sendCalls): Sign and broadcast a batch of calls to the network.
- [sendCallsSync](/docs/actions/wallet/sendCallsSync): Sign and broadcast a batch of calls to the network, and waits for the calls to be included in a block.
- [showCallsStatus](/docs/actions/wallet/showCallsStatus): Requests for the wallet to show information about a call batch.
- [waitForCallsStatus](/docs/actions/wallet/waitForCallsStatus): Waits for a call batch to be confirmed & included on a Block.
- [addChain](/docs/actions/wallet/addChain): Adds an EVM chain to the wallet.
- [switchChain](/docs/actions/wallet/switchChain): Switch the target chain in a wallet.
- [signMessage](/docs/actions/wallet/signMessage): Signs a message with the Account's private key.
- [signTypedData](/docs/actions/wallet/signTypedData): Signs typed data with the Account's private key.
- [getPermissions](/docs/actions/wallet/getPermissions): Gets the wallets current permissions.
- [requestPermissions](/docs/actions/wallet/requestPermissions): Requests permissions for a wallet.
- [sendRawTransactionSync](/docs/actions/wallet/sendRawTransactionSync): Sends a signed transaction to the network synchronously
- [sendTransaction](/docs/actions/wallet/sendTransaction): Creates, signs, and sends a new transaction to the network.
- [sendTransactionSync](/docs/actions/wallet/sendTransactionSync): Creates, signs, and sends a new transaction to the network synchronously.
- [signTransaction](/docs/actions/wallet/signTransaction): Signs a transaction.
- [Introduction to Test Actions](/docs/actions/test/introduction): A brief introduction on what Test Actions are in viem.
- [impersonateAccount](/docs/actions/test/impersonateAccount): Impersonate an account or contract address.
- [setBalance](/docs/actions/test/setBalance): Modifies the balance of an account.
- [setCode](/docs/actions/test/setCode): Modifies the bytecode stored at an account's address.
- [setNonce](/docs/actions/test/setNonce): Modifies (overrides) the nonce of an account.
- [setStorageAt](/docs/actions/test/setStorageAt): Writes to a slot of an account's storage.
- [stopImpersonatingAccount](/docs/actions/test/stopImpersonatingAccount): Stop impersonating an account after having previously used impersonateAccount.
- [getAutomine](/docs/actions/test/getAutomine): Returns the automatic mining status of the node.
- [increaseTime](/docs/actions/test/increaseTime): Jump forward in time by the given amount of time, in seconds.
- [mine](/docs/actions/test/mine): Mine a specified number of blocks.
- [removeBlockTimestampInterval](/docs/actions/test/removeBlockTimestampInterval): Removes setBlockTimestampInterval if it exists.
- [setAutomine](/docs/actions/test/setAutomine): Enables or disables the automatic mining of new blocks with each new transaction submitted to the network.
- [setIntervalMining](/docs/actions/test/setIntervalMining): Sets the automatic mining interval (in seconds) of blocks.
- [setBlockTimestampInterval](/docs/actions/test/setBlockTimestampInterval): Sets the block's timestamp interval.
- [setBlockGasLimit](/docs/actions/test/setBlockGasLimit): Sets the block's gas limit.
- [setNextBlockBaseFeePerGas](/docs/actions/test/setNextBlockBaseFeePerGas): Sets the next block's base fee per gas.
- [setNextBlockTimestamp](/docs/actions/test/setNextBlockTimestamp): Sets the next block's timestamp.
- [setCoinbase](/docs/actions/test/setCoinbase): Sets the coinbase address to be used in new blocks.
- [setMinGasPrice](/docs/actions/test/setMinGasPrice): Change the minimum gas price accepted by the network (in wei).
- [reset](/docs/actions/test/reset): Resets the fork back to its original state.
- [setLoggingEnabled](/docs/actions/test/setLoggingEnabled): Enable or disable logging on the test node network.
- [setRpcUrl](/docs/actions/test/setRpcUrl): Sets the backend RPC URL.
- [dumpState](/docs/actions/test/dumpState): Serializes the current state into a savable data blob.
- [loadState](/docs/actions/test/loadState): Adds state previously dumped to the current chain.
- [revert](/docs/actions/test/revert): Revert the state of the blockchain at the current block.
- [snapshot](/docs/actions/test/snapshot): Snapshot the state of the blockchain at the current block.
- [dropTransaction](/docs/actions/test/dropTransaction): Removes a transaction from the mempool.
- [getTxpoolContent](/docs/actions/test/getTxpoolContent): Returns the details of all transactions currently pending for inclusion in the next block(s).
- [getTxpoolStatus](/docs/actions/test/getTxpoolStatus): Returns a summary of all the transactions currently pending for inclusion in the next block(s).
- [inspectTxpool](/docs/actions/test/inspectTxpool): Returns a summary of all the transactions currently pending for inclusion in the next block(s).
- [sendUnsignedTransaction](/docs/actions/test/sendUnsignedTransaction): Executes a transaction regardless of the signature.
- [JSON-RPC Account](/docs/accounts/jsonRpc): A function to create a JSON-RPC Account.
- [Local Accounts (Private Key, Mnemonic, etc)](/docs/accounts/local)
- [privateKeyToAccount](/docs/accounts/local/privateKeyToAccount): A function to create a Private Key Account.
- [mnemonicToAccount](/docs/accounts/local/mnemonicToAccount): A function to create a Mnemonic Account.
- [hdKeyToAccount](/docs/accounts/local/hdKeyToAccount): A function to create a Hierarchical Deterministic (HD) Account.
- [toAccount](/docs/accounts/local/toAccount): A function to create a Custom Account.
- [createNonceManager](/docs/accounts/local/createNonceManager): Creates a Nonce Manager for automatic nonce generation
- [signMessage (Local Account)](/docs/accounts/local/signMessage): Signs a message with the Account's private key.
- [signTransaction (Local Account)](/docs/accounts/local/signTransaction): Signs a transaction with the Account's private key.
- [signTypedData (Local Account)](/docs/accounts/local/signTypedData): Signs typed data with the Account's private key.
- [Chains](/docs/chains/introduction)
- [Fees](/docs/chains/fees): Configure chain-based fee data in Viem
- [Formatters](/docs/chains/formatters): Configure chain-based formatters in Viem
- [Serializers](/docs/chains/serializers): Configure chain-based serializers in Viem
- [Celo](/docs/chains/celo): Integrating with Celo in Viem
- [Getting Started with OP Stack](/op-stack): Getting started with the OP Stack in Viem
- [Getting Started with ZKsync](/zksync): Getting started with the ZKsync in Viem
- [Contract Instances](/docs/contract/getContract): A Contract Instance is a type-safe interface for performing contract-related actions with a specific ABI and address, created by the getContract function.
- [createContractEventFilter](/docs/contract/createContractEventFilter): Creates a Filter to retrieve contract event logs.
- [deployContract](/docs/contract/deployContract): Deploys a contract to the network, given bytecode & constructor arguments.
- [estimateContractGas](/docs/contract/estimateContractGas): Estimates the gas required to successfully execute a contract write function call.
- [getCode](/docs/contract/getCode): Retrieves the bytecode at an address.
- [getContractEvents](/docs/contract/getContractEvents): Returns a list of event logs matching the provided parameters.
- [getStorageAt](/docs/contract/getStorageAt): Returns the value from a storage slot at a given address.
- [multicall](/docs/contract/multicall): Batches up multiple functions on a contract in a single call.
- [readContract](/docs/contract/readContract): Calls a read-only function on a contract, and returns the response.
- [simulateContract](/docs/contract/simulateContract): Simulates & validates a contract interaction.
- [writeContract](/docs/contract/writeContract): Executes a write function on a contract.
- [writeContractSync](/docs/contract/writeContractSync): Executes a write function on a contract synchronously.
- [watchContractEvent](/docs/contract/watchContractEvent): Watches and returns emitted contract event logs.
- [decodeDeployData](/docs/contract/decodeDeployData): Decodes ABI encoded deploy data (bytecode & arguments).
- [decodeErrorResult](/docs/contract/decodeErrorResult): Decodes reverted error from a contract function call.
- [decodeEventLog](/docs/contract/decodeEventLog): Decodes ABI encoded event topics & data.
- [decodeFunctionData](/docs/contract/decodeFunctionData): Decodes ABI encoded data (4 byte selector & arguments) into a function name and arguments.
- [decodeFunctionResult](/docs/contract/decodeFunctionResult): Decodes the result of a function call on a contract.
- [encodeDeployData](/docs/contract/encodeDeployData): Encodes deploy data (bytecode & constructor args) into an ABI encoded value.
- [encodeErrorResult](/docs/contract/encodeErrorResult): Encodes a reverted error from a function call.
- [encodeEventTopics](/docs/contract/encodeEventTopics): Encodes an event (with optional arguments) into filter topics.
- [encodeFunctionData](/docs/contract/encodeFunctionData): Encodes the function name and parameters into an ABI encoded value (4 byte selector & arguments).
- [encodeFunctionResult](/docs/contract/encodeFunctionResult): Encodes structured return data into ABI encoded data.
- [parseEventLogs](/docs/contract/parseEventLogs): Extracts & decodes logs from a set of opaque logs.
- [getEnsAddress](/docs/ens/actions/getEnsAddress): Gets address for ENS name.
- [getEnsAvatar](/docs/ens/actions/getEnsAvatar): Gets the avatar of an ENS name.
- [getEnsName](/docs/ens/actions/getEnsName): Gets primary name for specified address.
- [getEnsResolver](/docs/ens/actions/getEnsResolver): Gets resolver for ENS name.
- [getEnsText](/docs/ens/actions/getEnsText): Gets a text record for specified ENS name.
- [labelhash](/docs/ens/utilities/labelhash): Hashes ENS label.
- [namehash](/docs/ens/utilities/namehash): Hashes ENS name.
- [normalize](/docs/ens/utilities/normalize): Normalizes ENS name to UTS46.
- [verifySiweMessage](/docs/siwe/actions/verifySiweMessage): Verifies EIP-4361 formatted message was signed.
- [createSiweMessage](/docs/siwe/utilities/createSiweMessage): Creates EIP-4361 formatted message.
- [generateSiweNonce](/docs/siwe/utilities/generateSiweNonce): Generates random EIP-4361 nonce.
- [parseSiweMessage](/docs/siwe/utilities/parseSiweMessage): Parses EIP-4361 formatted message into message fields object.
- [validateSiweMessage](/docs/siwe/utilities/validateSiweMessage): Validates EIP-4361 message.
- [decodeAbiParameters](/docs/abi/decodeAbiParameters): Decodes ABI encoded data.
- [encodeAbiParameters](/docs/abi/encodeAbiParameters): Generates ABI encoded data.
- [encodePacked](/docs/abi/encodePacked): Generates ABI encoded data.
- [getAbiItem](/docs/abi/getAbiItem): Retrieves an item from the ABI array.
- [parseAbi](/docs/abi/parseAbi): Parses human-readable ABI into JSON.
- [parseAbiItem](/docs/abi/parseAbiItem): Parses human-readable ABI item (e.g. error, event, function) into ABI item.
- [parseAbiParameter](/docs/abi/parseAbiParameter): Parses human-readable ABI parameter into ABI parameter.
- [parseAbiParameters](/docs/abi/parseAbiParameters): Parses human-readable ABI parameters into ABI parameters.
- [getDelegation](/docs/eip7702/getDelegation): Returns the address an account has delegated to via EIP-7702.
- [prepareAuthorization](/docs/eip7702/prepareAuthorization): Prepares an EIP-7702 Authorization for signing.
- [signAuthorization](/docs/eip7702/signAuthorization): Signs an EIP-7702 Authorization object.
- [hashAuthorization](/docs/eip7702/hashAuthorization): Calculates an Authorization object hash in EIP-7702 format.
- [recoverAuthorizationAddress](/docs/eip7702/recoverAuthorizationAddress): Recovers the original signing address from a signed Authorization object.
- [verifyAuthorization](/docs/eip7702/verifyAuthorization): Verifies that an Authorization object was signed by the provided address.
- [getAddress](/docs/utilities/getAddress): Converts an address into an address that is checksum encoded.
- [getContractAddress](/docs/utilities/getContractAddress): Retrieves a contract address.
- [isAddress](/docs/utilities/isAddress): Checks if the address is valid.
- [isAddressEqual](/docs/utilities/isAddressEqual): Checks if the given addresses (checksummed) are equal.
- [blobsToProofs](/docs/utilities/blobsToProofs): Compute the proofs for a list of blobs and their commitments.
- [blobsToCommitments](/docs/utilities/blobsToCommitments): Compute commitments from a list of blobs.
- [commitmentsToVersionedHashes](/docs/utilities/commitmentsToVersionedHashes): Transform a list of commitments to their versioned hashes.
- [commitmentToVersionedHash](/docs/utilities/commitmentToVersionedHash): Transform a commitment to it's versioned hash.
- [fromBlobs](/docs/utilities/fromBlobs): Transforms blobs into the originating data.
- [sidecarsToVersionedHashes](/docs/utilities/sidecarsToVersionedHashes): Transforms a list of sidecars to their versioned hashes.
- [toBlobs](/docs/utilities/toBlobs): Transforms arbitrary data into blobs.
- [toBlobSidecars](/docs/utilities/toBlobSidecars): Transforms arbitrary data into blob sidecars.
- [extractChain](/docs/utilities/extractChain)
- [concat](/docs/utilities/concat): Concatenates a set of hex values or byte arrays.
- [isBytes](/docs/utilities/isBytes): Checks whether the value is a byte array or not.
- [isHex](/docs/utilities/isHex): Checks whether the value is a hex value or not.
- [pad](/docs/utilities/pad): Pads a hex value or byte array with leading or trailing zeros.
- [slice](/docs/utilities/slice): Returns a section of the hex or byte array given a start/end bytes offset.
- [size](/docs/utilities/size): Retrieves the size of the value (in bytes).
- [trim](/docs/utilities/trim): Trims the leading or trailing zero byte data from a hex value or byte array.
- [fromBytes](/docs/utilities/fromBytes): Decodes a byte array to a string, hex value, boolean or number.
- [fromHex](/docs/utilities/fromHex): Decodes a hex value to a string, number or byte array.
- [fromRlp](/docs/utilities/fromRlp): Decodes a RLP value into a decoded hex value or byte array.
- [toBytes](/docs/utilities/toBytes): Encodes a string, hex value, number or boolean to a byte array.
- [toHex](/docs/utilities/toHex): Encodes a string, number, boolean or byte array to a hex value.
- [toRlp](/docs/utilities/toRlp): Encodes a hex value or byte array into a RLP encoded value.
- [isHash](/docs/utilities/isHash): Checks if a string is a valid 32-byte hex hash.
- [keccak256](/docs/utilities/keccak256): Calculates the Keccak256 hash of a byte array.
- [ripemd160](/docs/utilities/ripemd160): Calculates the Ripemd160 hash of a byte array.
- [sha256](/docs/utilities/sha256): Calculates the Sha256 hash of a byte array.
- [toEventHash](/docs/utilities/toEventHash): Returns the hash (of the event signature) for a given event definition.
- [toEventSelector](/docs/utilities/toEventSelector): Returns the event selector for a given event definition.
- [toEventSignature](/docs/utilities/toEventSignature): Returns the signature for a given event or event definition.
- [toFunctionHash](/docs/utilities/toFunctionHash): Returns the hash (of the function signature) for a given function definition.
- [toFunctionSelector](/docs/utilities/toFunctionSelector): Returns the function selector (4 byte encoding) for a given function definition.
- [toFunctionSignature](/docs/utilities/toFunctionSignature): Returns the signature for a given function definition.
- [setupKzg](/docs/utilities/setupKzg): Sets up and returns a KZG interface.
- [compactSignatureToSignature](/docs/utilities/compactSignatureToSignature): Parses a compact signature into signature format.
- [hashMessage](/docs/utilities/hashMessage): Hashes a message in EIP-191 format.
- [hashTypedData](/docs/utilities/hashTypedData): Hashes EIP-712 typed data.
- [isErc6492Signature](/docs/utilities/isErc6492Signature): Checks whether the signature is in ERC-6492 format.
- [parseCompactSignature](/docs/utilities/parseCompactSignature): Parses a hex formatted compact signature into a structured compact signature.
- [parseErc6492Signature](/docs/utilities/parseErc6492Signature): Parses a hex-formatted ERC-6492 flavoured signature.
- [parseSignature](/docs/utilities/parseSignature): Parses a hex formatted signature into a structured signature.
- [recoverAddress](/docs/utilities/recoverAddress): Recovers the signing address from a hash & signature.
- [recoverMessageAddress](/docs/utilities/recoverMessageAddress): Recovers the signing address from a message & signature.
- [recoverPublicKey](/docs/utilities/recoverPublicKey): Recovers the signing public key from a hash & signature.
- [recoverTransactionAddress](/docs/utilities/recoverTransactionAddress): Recovers the signing address from a transaction & signature.
- [recoverTypedDataAddress](/docs/utilities/recoverTypedDataAddress): Recovers the signing address from EIP-712 typed data & signature.
- [serializeCompactSignature](/docs/utilities/serializeCompactSignature): Serializes a compact signature into hex format.
- [serializeErc6492Signature](/docs/utilities/serializeErc6492Signature): Serializes a ERC-6492 flavoured signature into hex format.
- [serializeSignature](/docs/utilities/serializeSignature): Serializes a structured signature into hex format.
- [signatureToCompactSignature](/docs/utilities/signatureToCompactSignature): Parses a signature into a compact signature.
- [verifyMessage](/docs/utilities/verifyMessage): Verifies if a signed message was generated by the provided address.
- [verifyTypedData](/docs/utilities/verifyTypedData): Verifies a typed data signature
- [parseTransaction](/docs/utilities/parseTransaction): Converts a serialized transaction to a structured transaction.
- [serializeTransaction](/docs/utilities/serializeTransaction): Serializes a transaction object.
- [formatEther](/docs/utilities/formatEther): Converts numerical wei to a string representation of ether.
- [formatGwei](/docs/utilities/formatGwei): Converts numerical wei to a string representation of gwei.
- [formatUnits](/docs/utilities/formatUnits): Divides a number by a given exponent of base 10, and formats it into a string representation of the number.
- [parseEther](/docs/utilities/parseEther): Converts a string representation of ether to numerical wei.
- [parseGwei](/docs/utilities/parseGwei): Converts a string representation of gwei to numerical wei.
- [parseUnits](/docs/utilities/parseUnits): Multiplies a string representation of a number by a given exponent of base 10.
- [Terms](/docs/glossary/terms): Glossary of Terms in viem.
- [Types](/docs/glossary/types): Glossary of Types in viem.
- [Errors](/docs/glossary/errors): Glossary of Errors in viem.
- [Getting Started with Account Abstraction](/account-abstraction): Getting Started with Account Abstraction in Viem
- [Sending User Operations](/account-abstraction/guides/sending-user-operations)
- [Bundler Client](/account-abstraction/clients/bundler): A function to create a Bundler Client.
- [Paymaster Client](/account-abstraction/clients/paymaster): A function to create a Paymaster Client.
- [Smart Accounts](/account-abstraction/accounts/smart)
- [Coinbase Smart Wallet](/account-abstraction/accounts/smart/toCoinbaseSmartAccount)
- [MetaMask Smart Account](/account-abstraction/accounts/smart/toMetaMaskSmartAccount)
- [Thirdweb Smart Account](/account-abstraction/accounts/smart/toThirdwebSmartAccount)
- [Nexus Smart Account](/account-abstraction/accounts/smart/toNexusSmartAccount)
- [Light Smart Account](/account-abstraction/accounts/smart/toLightSmartAccount)
- [Kernel (ZeroDev) Smart Account](/account-abstraction/accounts/smart/toEcdsaKernelSmartAccount)
- [Safe Smart Account](/account-abstraction/accounts/smart/toSafeSmartAccount)
- [Simple Smart Account](/account-abstraction/accounts/smart/toSimpleSmartAccount)
- [Solady Smart Account](/account-abstraction/accounts/smart/toSoladySmartAccount)
- [Trust Smart Account](/account-abstraction/accounts/smart/toTrustSmartAccount)
- [toSmartAccount](/account-abstraction/accounts/smart/toSmartAccount): Creates a Smart Account with a provided Account Implementation.
- [signMessage (Smart Account)](/account-abstraction/accounts/smart/signMessage)
- [signTypedData (Smart Account)](/account-abstraction/accounts/smart/signTypedData)
- [signUserOperation (Smart Account)](/account-abstraction/accounts/smart/signUserOperation)
- [WebAuthn Account](/account-abstraction/accounts/webauthn)
- [toWebAuthnAccount](/account-abstraction/accounts/webauthn/toWebAuthnAccount)
- [createWebAuthnCredential](/account-abstraction/accounts/webauthn/createWebAuthnCredential)
- [estimateUserOperationGas](/account-abstraction/actions/bundler/estimateUserOperationGas): Estimates the gas values for a User Operation to be executed successfully.
- [getChainId](/account-abstraction/actions/bundler/getChainId): Returns the chain ID associated with the bundler
- [getSupportedEntryPoints](/account-abstraction/actions/bundler/getSupportedEntryPoints): Returns the EntryPoints that the bundler supports.
- [getUserOperation](/account-abstraction/actions/bundler/getUserOperation): Retrieves information about a User Operation given a hash.
- [getUserOperationReceipt](/account-abstraction/actions/bundler/getUserOperationReceipt): Returns the User Operation receipt given a User Operation hash.
- [prepareUserOperation](/account-abstraction/actions/bundler/prepareUserOperation): Prepares a User Operation for execution and fills in missing properties.
- [sendUserOperation](/account-abstraction/actions/bundler/sendUserOperation): Broadcasts a User Operation to the Bundler.
- [waitForUserOperationReceipt](/account-abstraction/actions/bundler/waitForUserOperationReceipt): Waits for the User Operation to be included on a Block, and then returns the User Operation receipt.
- [getPaymasterData](/account-abstraction/actions/paymaster/getPaymasterData): Retrieves paymaster-related properties to be used for the User Operation.
- [getPaymasterStubData](/account-abstraction/actions/paymaster/getPaymasterStubData): Retrieves paymaster-related properties to be used for the User Operation.
- [Getting Started](/experimental): Getting started with experimental features in Viem
- [Extending Client with ERC-7715](/experimental/erc7715/client): Setting up your Viem Client
- [grantPermissions](/experimental/erc7715/grantPermissions): Request permissions from a wallet to perform actions on behalf of a user.
- [Extending Client with ERC-7739 Actions](/experimental/erc7739/client): Setting up your Viem Client
- [signMessage](/experimental/erc7739/signMessage): Signs a personal sign message via Solady's ERC-1271 format.
- [signTypedData](/experimental/erc7739/signTypedData): Signs typed data via Solady's ERC-1271 format.
- [hashMessage](/experimental/erc7739/hashMessage): Hashes an EIP-191 message via ERC-7739 format.
- [hashTypedData](/experimental/erc7739/hashTypedData): Hashes EIP-712 typed data via Solady's ERC-1271 format.
- [wrapTypedDataSignature](/experimental/erc7739/wrapTypedDataSignature)
- [Extending Client with ERC-7811 Actions](/experimental/erc7811/client): Setting up your Viem Client
- [getAssets](/experimental/erc7811/getAssets): Requests to get assets for an account from a Wallet.
- [Extending Client with ERC-7821 Actions](/experimental/erc7821/client): Setting up your Viem Client
- [execute](/experimental/erc7821/execute): Executes call(s) using the `execute` function on an ERC-7821-compatible contract.
- [executeBatches](/experimental/erc7821/executeBatches): Executes batches of call(s) on an ERC-7821-compatible contract.
- [supportsExecutionMode](/experimental/erc7821/supportsExecutionMode): Checks if the contract supports the ERC-7821 execution mode.
- [Extending Client with ERC-7846 Actions](/experimental/erc7846/client): Setting up your Viem Client
- [connect](/experimental/erc7846/connect): Requests to connect Account(s).
- [disconnect](/experimental/erc7846/disconnect): Requests to disconnect account(s).
- [Extending Client with ERC-7895 Actions](/experimental/erc7895/client): Setting up your Viem Client
- [addSubAccount](/experimental/erc7895/addSubAccount): Requests to add a Sub Account.
- [Client](/op-stack/client): Setting up your Viem Client with the OP Stack
- [Chains](/op-stack/chains)
- [Deposits](/op-stack/guides/deposits)
- [Withdrawals](/op-stack/guides/withdrawals)
- [buildDepositTransaction](/op-stack/actions/buildDepositTransaction): Builds & prepares parameters for a deposit transaction to be initiated on an L1 and executed on the L2.
- [buildProveWithdrawal](/op-stack/actions/buildProveWithdrawal): Builds the transaction that proves a withdrawal was initiated on an L2.
- [estimateContractL1Fee](/op-stack/actions/estimateContractL1Fee): Estimates the L1 fee to execute an L2 contract write.
- [estimateContractL1Gas](/op-stack/actions/estimateContractL1Gas): Estimates the L1 gas to execute an L2 contract write.
- [estimateContractTotalFee](/op-stack/actions/estimateContractTotalFee): Estimates the total (L1 + L2) fee to execute an L2 contract write.
- [estimateContractTotalGas](/op-stack/actions/estimateContractTotalGas): Estimates the total (L1 + L2) gas to execute an L2 contract write.
- [estimateInitiateWithdrawalGas](/op-stack/actions/estimateInitiateWithdrawalGas): Estimates gas required to initiate a withdrawal on an L2 to the L1.
- [estimateL1Fee](/op-stack/actions/estimateL1Fee): Estimates the L1 fee to execute an L2 transaction.
- [estimateL1Gas](/op-stack/actions/estimateL1Gas): Estimates the amount of L1 gas required to execute an L2 transaction
- [estimateOperatorFee](/op-stack/actions/estimateOperatorFee): Estimates the operator fee to execute an L2 transaction.
- [estimateTotalFee](/op-stack/actions/estimateTotalFee): Estimates the L1 + L2 + operator fee to execute an L2 transaction.
- [estimateTotalGas](/op-stack/actions/estimateTotalGas): Estimates the amount of L1 + L2 gas required to execute an L2 transaction
- [initiateWithdrawal](/op-stack/actions/initiateWithdrawal): Initiates a withdrawal on an L2 to the L1.
- [buildInitiateWithdrawal](/op-stack/actions/buildInitiateWithdrawal): Builds & prepares parameters for a withdrawal to be initiated on an L2.
- [estimateDepositTransactionGas](/op-stack/actions/estimateDepositTransactionGas): Estimates gas to initiate a deposit transaction on an L1, which executes a transaction on an L2.
- [estimateFinalizeWithdrawalGas](/op-stack/actions/estimateFinalizeWithdrawalGas): Estimates gas required to finalize a withdrawal that occurred on an L2.
- [estimateProveWithdrawalGas](/op-stack/actions/estimateProveWithdrawalGas): Estimates gas required to prove a withdrawal that occurred on an L2.
- [getGame](/op-stack/actions/getGame): Retrieves a valid dispute game on an L2 that occurred after a provided L2 block number.
- [getGames](/op-stack/actions/getGames): Retrieves dispute games for an L2.
- [getL2Output](/op-stack/actions/getL2Output): Retrieves the first L2 output proposal that occurred after a provided block number.
- [getTimeToFinalize](/op-stack/actions/getTimeToFinalize): Returns the time until the withdrawal transaction can be finalized.
- [getTimeToNextGame](/op-stack/actions/getTimeToNextGame): Returns the time until the next L2 dispute game is submitted.
- [getTimeToNextL2Output](/op-stack/actions/getTimeToNextL2Output): Builds & prepares parameters for a withdrawal to be initiated on an L2.
- [getTimeToProve](/op-stack/actions/getTimeToProve): Gets time until the L2 withdrawal transaction is ready to be proved.
- [getWithdrawalStatus](/op-stack/actions/getWithdrawalStatus): Returns the current status of a withdrawal.
- [waitForNextGame](/op-stack/actions/waitForNextGame): Waits for the next dispute game to be submitted.
- [waitForNextL2Output](/op-stack/actions/waitForNextL2Output): Waits for the next L2 output (after the provided block number) to be submitted.
- [waitToFinalize](/op-stack/actions/waitToFinalize): Waits until the withdrawal transaction can be finalized.
- [waitToProve](/op-stack/actions/waitToProve): Waits until the L2 withdrawal transaction is ready to be proved.
- [depositTransaction](/op-stack/actions/depositTransaction): Initiates a deposit transaction on an L1, which executes a transaction on an L2.
- [finalizeWithdrawal](/op-stack/actions/finalizeWithdrawal): Finalizes a withdrawal that occurred on an L2.
- [proveWithdrawal](/op-stack/actions/proveWithdrawal): Proves a withdrawal that occurred on an L2.
- [extractTransactionDepositedLogs](/op-stack/utilities/extractTransactionDepositedLogs): Extracts "TransactionDeposited" logs from an opaque array of logs.
- [extractWithdrawalMessageLogs](/op-stack/utilities/extractWithdrawalMessageLogs): Extracts "MessagePassed" logs from a withdrawal initialization from an opaque array of logs.
- [getL2TransactionHash](/op-stack/utilities/getL2TransactionHash): Computes the L2 transaction hash from an L1 "TransactionDeposited" log.
- [getL2TransactionHashes](/op-stack/utilities/getL2TransactionHashes): Computes the L2 transaction hashes from an array of L1 "TransactionDeposited" logs.
- [getWithdrawals](/op-stack/utilities/getWithdrawals): Gets the messages from a withdrawal initialization.
- [getSourceHash](/op-stack/utilities/getSourceHash): Computes source hash of a deposit transaction.
- [opaqueDataToDepositData](/op-stack/utilities/opaqueDataToDepositData): Converts opaque data into a structured deposit data format.
- [getWithdrawalHashStorageSlot](/op-stack/utilities/getWithdrawalHashStorageSlot): Computes the withdrawal hash storage slot to be used when proving a withdrawal.
- [parseTransaction (OP Stack)](/op-stack/utilities/parseTransaction): Converts a serialized transaction to a structured transaction, with support for OP Stack.
- [serializeTransaction (OP Stack)](/op-stack/utilities/serializeTransaction): Serializes a transaction object, with support for OP Stack.
- [USDC (Circle)](/circle-usdc)
- [Integrating USDC into Your Application](/circle-usdc/guides/integrating)
- [Cross-Chain USDC Transfers](/circle-usdc/guides/cross-chain)
- [Cross Chain USDC Transfers with Bridge Kit](/circle-usdc/guides/bridge-kit)
- [Cross Chain USDC Transfers (CCTP Integration)](/circle-usdc/guides/manual-cctp)
- [Gasless USDC Transfers with Circle Paymaster](/circle-usdc/guides/paymaster)
- [Circle Smart Account](/circle-usdc/guides/smart-account)
- [Getting Started](/tempo/)
- [Chains](/tempo/chains)
- [Guides](/tempo/guides/): Task-oriented guides for building common Tempo features with Viem.
- [Create an Account](/tempo/guides/accounts/create): Create a Tempo Account from a private key, passkey, or device-bound key, and use it with a Viem client.
- [Sign In with a Passkey](/tempo/guides/accounts/passkeys): Create and restore WebAuthn passkey accounts for non-custodial browser sign-in on Tempo.
- [Use the Tempo Accounts SDK](/tempo/guides/accounts/accounts-sdk): Connect a Tempo account with the Tempo Accounts SDK and drive it with Viem and Tempo Actions.
- [Tempo Transactions](/tempo/transactions): Send your first Tempo Transaction with Viem, and discover the payment-native features they unlock.
- [Batch Calls](/tempo/guides/batch-calls): Bundle multiple operations into a single atomic Tempo Transaction.
- [Concurrent Transactions](/tempo/guides/concurrent-transactions): Send multiple Tempo Transactions in parallel using concurrent nonces.
- [Scheduled Transactions](/tempo/guides/scheduled-transactions): Sign a Tempo Transaction now and define when it can execute onchain.
- [Pay Fees in a Stablecoin](/tempo/guides/pay-fees): Pay Tempo transaction fees in any USD-denominated TIP-20 stablecoin.
- [Sponsor User Fees](/tempo/guides/sponsor-fees): Sponsor transaction fees on behalf of your users for a gasless experience on Tempo.
- [Multisig Transactions](/tempo/guides/multisig-transactions): Send a Tempo Transaction from a native multisig account by collecting owner approvals.
- [Create a TIP-20 Token](/tempo/guides/create-token): Deploy a TIP-20 stablecoin on Tempo and read its onchain metadata.
- [Mint & Burn Tokens](/tempo/guides/manage-token-balances): Mint and burn TIP-20 token supply on Tempo.
- [Transfer Tokens](/tempo/guides/transfer-tokens): Transfer TIP-20 tokens, authorize spenders, and read balances on Tempo.
- [Manage Token Roles & Supply](/tempo/guides/manage-token-roles): Grant and revoke TIP-20 roles, cap supply, and pause transfers on Tempo.
- [Configure Transfer Policies](/tempo/guides/transfer-policies): Restrict which accounts can send or receive a TIP-20 token with a transfer policy.
- [Distribute Token Rewards](/tempo/guides/token-rewards): Distribute rewards to TIP-20 holders and let them claim their share on Tempo.
- [Access Keys](/tempo/guides/access-keys/): Delegate signing to a secondary key with access keys, with spending limits, scopes, admin keys, and signature verification.
- [Authorize Access Keys](/tempo/guides/access-keys/authorize): Authorize an access key to sign transactions on behalf of an account, and defer authorization to a transaction.
- [Set Permissions & Limits](/tempo/guides/access-keys/permissions): Restrict an access key with an expiry, per-token spending limits, recurring limits, and call scopes.
- [Manage Access Keys](/tempo/guides/access-keys/manage): Update spending limits, revoke access keys, and inspect their onchain metadata and remaining limits.
- [Admin Access Keys](/tempo/guides/access-keys/admin): Authorize unrestricted admin access keys that can manage an account's other keys, and check admin status.
- [Witnesses](/tempo/guides/access-keys/witnesses): Bind a witness to a key authorization and burn it to revoke signed-but-not-yet-submitted authorizations.
- [Verify Signatures](/tempo/guides/access-keys/verify): Verify that a keychain signature was produced by an active access key for the expected account.
- [Stablecoin Exchange](/tempo/guides/stablecoin-exchange/): Trade stablecoins on Tempo's enshrined DEX, manage orders and balances, create trading pairs, and provide Fee AMM liquidity.
- [Swap Stablecoins](/tempo/guides/stablecoin-exchange/swap): Quote and swap one USD-denominated TIP-20 stablecoin for another on Tempo's enshrined DEX.
- [Place & Manage Orders](/tempo/guides/stablecoin-exchange/orders): Place limit and flip orders on Tempo's Stablecoin DEX, then read, inspect, and cancel them.
- [Manage Exchange Balances](/tempo/guides/stablecoin-exchange/balances): Read your internal Stablecoin DEX balances and withdraw them back to your Tempo wallet.
- [Create a Trading Pair](/tempo/guides/stablecoin-exchange/create-pair): Create a new trading pair on Tempo's Stablecoin DEX and configure a token's quote token.
- [Provide Fee AMM Liquidity](/tempo/guides/stablecoin-exchange/fee-amm-liquidity): Add and remove liquidity in Tempo's Fee AMM so stablecoin fee conversions can settle.
- [Virtual Addresses](/tempo/guides/virtual-addresses/): Register a master address and accept TIP-20 deposits at unlimited virtual addresses that forward to you without sweeps.
- [Register a Master Address](/tempo/guides/virtual-addresses/register): Mine a TIP-1022 proof-of-work salt and register a master address for virtual-address deposit forwarding.
- [Resolve & Accept Payments](/tempo/guides/virtual-addresses/resolve): Derive per-customer virtual deposit addresses offchain and resolve them to your master wallet.
- [Receive Policies](/tempo/guides/receive-policies/): Control who can pay you on Tempo with receive policies, validate inbound transfers, and recover blocked funds.
- [Set a Receive Policy](/tempo/guides/receive-policies/set): Set and read an account's receive policy to control which senders and tokens it accepts.
- [Validate Transfers](/tempo/guides/receive-policies/validate): Check whether a TIP-20 transfer would be accepted by a recipient's receive policy before sending it.
- [Handle Blocked Funds](/tempo/guides/receive-policies/blocked): Read, claim, and burn TIP-20 funds that a receive policy blocked from being credited.
- [Payment Channels](/tempo/guides/payment-channels/): Open funded TIP-20 channels on Tempo, stream off-chain vouchers, and settle or close to move funds onchain.
- [Open & Fund a Channel](/tempo/guides/payment-channels/open): Open and fund a TIP-20 payment channel on Tempo, top it up, and read its onchain state.
- [Send & Settle Vouchers](/tempo/guides/payment-channels/vouchers): Sign off-chain TIP-20 channel vouchers as the payer and settle them onchain as the payee.
- [Close & Withdraw](/tempo/guides/payment-channels/close): Close a TIP-20 payment channel from either side and withdraw the remaining deposit on Tempo.
- [Private Zones](/tempo/guides/zones/): Connect to private Tempo Zones, deposit funds into them, and withdraw back to Tempo Mainnet.
- [Connect to a Zone](/tempo/guides/zones/connect): Connect a Viem client to a private Tempo Zone and authenticate with an authorization token.
- [Deposit to a Zone](/tempo/guides/zones/deposit): Deposit TIP-20 stablecoins from Tempo Mainnet into a private Tempo Zone.
- [Withdraw from a Zone](/tempo/guides/zones/withdraw): Withdraw TIP-20 stablecoins from a private Tempo Zone back to Tempo Mainnet.
- [Accounts](/tempo/accounts/)
- [Account.fromSecp256k1](/tempo/accounts/account.fromSecp256k1)
- [Account.fromP256](/tempo/accounts/account.fromP256)
- [Account.fromWebAuthnP256](/tempo/accounts/account.fromWebAuthnP256)
- [Account.fromWebCryptoP256](/tempo/accounts/account.fromWebCryptoP256)
- [Account.fromMultisig](/tempo/accounts/account.fromMultisig)
- [Overview](/tempo/actions/)
- [accessKey.authorize](/tempo/actions/accessKey.authorize)
- [accessKey.burnWitness](/tempo/actions/accessKey.burnWitness)
- [accessKey.getMetadata](/tempo/actions/accessKey.getMetadata)
- [accessKey.getRemainingLimit](/tempo/actions/accessKey.getRemainingLimit)
- [accessKey.isAdmin](/tempo/actions/accessKey.isAdmin)
- [accessKey.isWitnessBurned](/tempo/actions/accessKey.isWitnessBurned)
- [accessKey.revoke](/tempo/actions/accessKey.revoke)
- [accessKey.signAuthorization](/tempo/actions/accessKey.signAuthorization)
- [accessKey.updateLimit](/tempo/actions/accessKey.updateLimit)
- [accessKey.verifyHash](/tempo/actions/accessKey.verifyHash)
- [accessKey.watchAdminAuthorized](/tempo/actions/accessKey.watchAdminAuthorized)
- [accessKey.watchWitness](/tempo/actions/accessKey.watchWitness)
- [accessKey.watchWitnessBurned](/tempo/actions/accessKey.watchWitnessBurned)
- [amm.burn](/tempo/actions/amm.burn)
- [amm.getLiquidityBalance](/tempo/actions/amm.getLiquidityBalance)
- [amm.getPool](/tempo/actions/amm.getPool)
- [amm.mint](/tempo/actions/amm.mint)
- [amm.rebalanceSwap](/tempo/actions/amm.rebalanceSwap)
- [amm.watchBurn](/tempo/actions/amm.watchBurn)
- [amm.watchMint](/tempo/actions/amm.watchMint)
- [amm.watchRebalanceSwap](/tempo/actions/amm.watchRebalanceSwap)
- [channel.close](/tempo/actions/channel.close)
- [channel.getStates](/tempo/actions/channel.getStates)
- [channel.open](/tempo/actions/channel.open)
- [channel.requestClose](/tempo/actions/channel.requestClose)
- [channel.settle](/tempo/actions/channel.settle)
- [channel.signVoucher](/tempo/actions/channel.signVoucher)
- [channel.topUp](/tempo/actions/channel.topUp)
- [channel.withdraw](/tempo/actions/channel.withdraw)
- [fee.getUserToken](/tempo/actions/fee.getUserToken)
- [fee.setUserToken](/tempo/actions/fee.setUserToken)
- [fee.watchSetUserToken](/tempo/actions/fee.watchSetUserToken)
- [nonce.getNonce](/tempo/actions/nonce.getNonce)
- [nonce.watchNonceIncremented](/tempo/actions/nonce.watchNonceIncremented)
- [policy.create](/tempo/actions/policy.create)
- [policy.getData](/tempo/actions/policy.getData)
- [policy.isAuthorized](/tempo/actions/policy.isAuthorized)
- [policy.modifyBlacklist](/tempo/actions/policy.modifyBlacklist)
- [policy.modifyWhitelist](/tempo/actions/policy.modifyWhitelist)
- [policy.setAdmin](/tempo/actions/policy.setAdmin)
- [policy.watchAdminUpdated](/tempo/actions/policy.watchAdminUpdated)
- [policy.watchBlacklistUpdated](/tempo/actions/policy.watchBlacklistUpdated)
- [policy.watchCreate](/tempo/actions/policy.watchCreate)
- [policy.watchWhitelistUpdated](/tempo/actions/policy.watchWhitelistUpdated)
- [receivePolicy.burn](/tempo/actions/receivePolicy.burn)
- [receivePolicy.claim](/tempo/actions/receivePolicy.claim)
- [receivePolicy.get](/tempo/actions/receivePolicy.get)
- [receivePolicy.getBlockedBalance](/tempo/actions/receivePolicy.getBlockedBalance)
- [receivePolicy.set](/tempo/actions/receivePolicy.set)
- [receivePolicy.validate](/tempo/actions/receivePolicy.validate)
- [receivePolicy.watchBlocked](/tempo/actions/receivePolicy.watchBlocked)
- [receivePolicy.watchBurned](/tempo/actions/receivePolicy.watchBurned)
- [receivePolicy.watchClaimed](/tempo/actions/receivePolicy.watchClaimed)
- [receivePolicy.watchUpdated](/tempo/actions/receivePolicy.watchUpdated)
- [faucet.fund](/tempo/actions/faucet.fund)
- [reward.claim](/tempo/actions/reward.claim)
- [reward.distribute](/tempo/actions/reward.distribute)
- [reward.getGlobalRewardPerToken](/tempo/actions/reward.getGlobalRewardPerToken)
- [reward.getPendingRewards](/tempo/actions/reward.getPendingRewards)
- [reward.getUserRewardInfo](/tempo/actions/reward.getUserRewardInfo)
- [reward.setRecipient](/tempo/actions/reward.setRecipient)
- [reward.watchRewardDistributed](/tempo/actions/reward.watchRewardDistributed)
- [reward.watchRewardRecipientSet](/tempo/actions/reward.watchRewardRecipientSet)
- [simulate.simulateBlocks](/tempo/actions/simulate.simulateBlocks)
- [simulate.simulateCalls](/tempo/actions/simulate.simulateCalls)
- [dex.buy](/tempo/actions/dex.buy)
- [dex.cancel](/tempo/actions/dex.cancel)
- [dex.cancelStale](/tempo/actions/dex.cancelStale)
- [dex.createPair](/tempo/actions/dex.createPair)
- [dex.getBalance](/tempo/actions/dex.getBalance)
- [dex.getBuyQuote](/tempo/actions/dex.getBuyQuote)
- [dex.getOrder](/tempo/actions/dex.getOrder)
- [dex.getTickLevel](/tempo/actions/dex.getTickLevel)
- [dex.getSellQuote](/tempo/actions/dex.getSellQuote)
- [dex.place](/tempo/actions/dex.place)
- [dex.placeFlip](/tempo/actions/dex.placeFlip)
- [dex.sell](/tempo/actions/dex.sell)
- [dex.watchFlipOrderPlaced](/tempo/actions/dex.watchFlipOrderPlaced)
- [dex.watchOrderCancelled](/tempo/actions/dex.watchOrderCancelled)
- [dex.watchOrderFilled](/tempo/actions/dex.watchOrderFilled)
- [dex.watchOrderPlaced](/tempo/actions/dex.watchOrderPlaced)
- [dex.withdraw](/tempo/actions/dex.withdraw)
- [token.approve](/tempo/actions/token.approve)
- [token.burn](/tempo/actions/token.burn)
- [token.burnBlocked](/tempo/actions/token.burnBlocked)
- [token.changeTransferPolicy](/tempo/actions/token.changeTransferPolicy)
- [token.create](/tempo/actions/token.create)
- [token.getAllowance](/tempo/actions/token.getAllowance)
- [token.getBalance](/tempo/actions/token.getBalance)
- [token.getMetadata](/tempo/actions/token.getMetadata)
- [token.grantRoles](/tempo/actions/token.grantRoles)
- [token.hasRole](/tempo/actions/token.hasRole)
- [token.mint](/tempo/actions/token.mint)
- [token.pause](/tempo/actions/token.pause)
- [token.renounceRoles](/tempo/actions/token.renounceRoles)
- [token.revokeRoles](/tempo/actions/token.revokeRoles)
- [token.setRoleAdmin](/tempo/actions/token.setRoleAdmin)
- [token.setSupplyCap](/tempo/actions/token.setSupplyCap)
- [token.transfer](/tempo/actions/token.transfer)
- [token.unpause](/tempo/actions/token.unpause)
- [token.watchAdminRole](/tempo/actions/token.watchAdminRole)
- [token.watchApprove](/tempo/actions/token.watchApprove)
- [token.watchBurn](/tempo/actions/token.watchBurn)
- [token.watchCreate](/tempo/actions/token.watchCreate)
- [token.watchMint](/tempo/actions/token.watchMint)
- [token.watchRole](/tempo/actions/token.watchRole)
- [token.watchTransfer](/tempo/actions/token.watchTransfer)
- [validator.add](/tempo/actions/validator.add)
- [validator.changeOwner](/tempo/actions/validator.changeOwner)
- [validator.changeStatus](/tempo/actions/validator.changeStatus)
- [validator.get](/tempo/actions/validator.get)
- [validator.getByIndex](/tempo/actions/validator.getByIndex)
- [validator.getCount](/tempo/actions/validator.getCount)
- [validator.getNextFullDkgCeremony](/tempo/actions/validator.getNextFullDkgCeremony)
- [validator.getOwner](/tempo/actions/validator.getOwner)
- [validator.list](/tempo/actions/validator.list)
- [validator.setNextFullDkgCeremony](/tempo/actions/validator.setNextFullDkgCeremony)
- [validator.update](/tempo/actions/validator.update)
- [virtualAddress.getMasterAddress](/tempo/actions/virtualAddress.getMasterAddress)
- [virtualAddress.registerMaster](/tempo/actions/virtualAddress.registerMaster)
- [virtualAddress.resolve](/tempo/actions/virtualAddress.resolve)
- [wallet.deposit](/tempo/actions/wallet.deposit)
- [wallet.transfer](/tempo/actions/wallet.transfer)
- [wallet.swap](/tempo/actions/wallet.swap)
- [zone.deposit](/tempo/actions/zone.deposit)
- [zone.encryptedDeposit](/tempo/actions/zone.encryptedDeposit)
- [zone.getAuthorizationTokenInfo](/tempo/actions/zone.getAuthorizationTokenInfo)
- [zone.getDepositStatus](/tempo/actions/zone.getDepositStatus)
- [zone.getWithdrawalFee](/tempo/actions/zone.getWithdrawalFee)
- [zone.getZoneInfo](/tempo/actions/zone.getZoneInfo)
- [zone.requestVerifiableWithdrawal](/tempo/actions/zone.requestVerifiableWithdrawal)
- [zone.requestWithdrawal](/tempo/actions/zone.requestWithdrawal)
- [zone.signAuthorizationToken](/tempo/actions/zone.signAuthorizationToken)
- [withRelay](/tempo/transports/withRelay)
- [TempoAddress.format](/tempo/utilities/TempoAddress.format)
- [TempoAddress.parse](/tempo/utilities/TempoAddress.parse)
- [TempoAddress.validate](/tempo/utilities/TempoAddress.validate)
- [Storage.defaultStorage](/tempo/utilities/Storage.defaultStorage)
- [Storage.from](/tempo/utilities/Storage.from)
- [Storage.memory](/tempo/utilities/Storage.memory)
- [Storage.session](/tempo/utilities/Storage.session)
- [Client](/zksync/client): Setting up your ZKsync Viem Client
- [Chains](/zksync/chains)
- [toSinglesigSmartAccount (ZKsync)](/zksync/accounts/toSinglesigSmartAccount): Creates a single-signature ZKsync Smart Account
- [toMultisigSmartAccount (ZKsync)](/zksync/accounts/toMultisigSmartAccount): Creates a multi-signature ZKsync Smart Account
- [toSmartAccount (ZKsync)](/zksync/accounts/toSmartAccount): Creates a ZKsync Smart Account
- [deployContract](/zksync/actions/deployContract): Deploys a contract to the network, given bytecode & constructor arguments by using EIP712 transaction.
- [sendTransaction](/zksync/actions/sendTransaction): Creates, signs, and sends a new transaction to the network, with EIP712 transaction support.
- [signTransaction](/zksync/actions/signTransaction): Signs a transaction, with EIP712 transaction support.
- [writeContract](/zksync/actions/writeContract): Executes a write function on a contract, with EIP712 transaction support.
- [estimateGasL1ToL2](/zksync/actions/estimateGasL1ToL2): Returns an estimated gas for L1 to L2 execution.
- [getBlockDetails](/zksync/actions/getBlockDetails): Returns additional ZKsync-specific information about the L2 block.
- [getBridgehubContractAddress](/zksync/actions/getBridgehubContractAddress): Returns the Bridgehub smart contract address.
- [getDefaultBridgeAddresses](/zksync/actions/getDefaultBridgeAddress): Returns the addresses of the default ZKsync Era bridge contracts on both L1 and L2.
- [getGasPerPubData](/zksync/actions/getGasPerPubData): Returns the scaled gas per pubdata limit for the currently open batch.
- [getL1BatchDetails](/zksync/actions/getL1BatchDetails): Returns data pertaining to a given batch.
- [getL1BatchBlockRange](/zksync/actions/getL1BatchBlockRange): Returns the range of blocks contained within a batch given by batch number.
- [getL1BatchNumber](/zksync/actions/getL1BatchNumber): Returns the latest L1 batch number.
- [getL1TokenAddress](/zksync/actions/getL1TokenAddress): Returns the L1 token address equivalent for a L2 token address as they are not equal.
- [getL2TokenAddress](/zksync/actions/getL2TokenAddress): Returns the L2 token address equivalent for a L1 token address as they are not equal.
- [getLogProof](/zksync/actions/getLogProof): Given a transaction hash, and an index of the L2 to L1 log produced within the transaction, it returns the proof for the corresponding L2 to L1 log.
- [getTransactionDetails](/zksync/actions/getTransactionDetails): Returns data from a specific transaction given by the transaction hash.
- [estimateFee](/zksync/actions/estimateFee): Returns an estimated Fee for requested transaction.
- [getAllBalances](/zksync/actions/getAllBalances): Returns all known balances for a given account.
- [getBaseTokenL1Address](/zksync/actions/getBaseTokenL1Address): Returns the base token L1 address.
- [getL1ChainId](/zksync/actions/getL1ChainId): Returns the Chain Id of underlying L1 network.
- [getMainContractAddress](/zksync/actions/getMainContractAddress): Returns the address of a Main ZKsync Contract.
- [getRawBlockTransaction](/zksync/actions/getRawBlockTransactions): Returns data of transactions in a block.
- [getTestnetPaymasterAddress (depreated)](/zksync/actions/getTestnetPaymasterAddress): Returns the address of a Paymaster on a Testnet.
- [getL1Allowance](/zksync/actions/getL1Allowance): Determines the amount of approved tokens for a specific L1 bridge.
- [getL1Balance](/zksync/actions/getL1Balance): Returns the amount of the token held by the account on the L1 network.
- [getL1TokenBalance](/zksync/actions/getL1TokenBalance): Retrieve the token balance held by the contract on L1.
- [isWithdrawalFinalized](/zksync/actions/isWithdrawalFinalized): Returns whether the withdrawal transaction is finalized on the L1 network.
- [withdraw](/zksync/actions/withdraw): Initiates the withdrawal process which withdraws ETH or any ERC20 token from the associated account on L2 network to the target account on L1 network.
- [requestExecute](/zksync/actions/requestExecute): Requests execution of a L2 transaction from L1.
- [finalizeWithdrawal](/zksync/actions/finalizeWithdrawal): Proves the inclusion of the `L2->L1` withdrawal message.
- [deposit](/zksync/actions/deposit): Transfers the specified token from the associated account on the L1 network to the target account on the L2 network.
- [claimFailedDeposit](/zksync/actions/claimFailedDeposit): Withdraws funds from the initiated deposit, which failed when finalizing on L2.
- [getApprovalBasedPaymasterInput](/zksync/utilities/paymaster/getApprovalBasedPaymasterInput): Returns encoded formatted approval-based paymaster params.
- [getGeneralPaymasterInput](/zksync/utilities/paymaster/getGeneralPaymasterInput): Returns encoded formatted general-based paymaster params.
- [getL2HashFromPriorityOp](/zksync/utilities/bridge/getL2HashFromPriorityOp): Returns the hash of the L2 priority operation from a given L1 transaction receipt.
- [parseEip712Transaction](/zksync/utilities/parseEip712Transaction): Parse EIP712 transaction.
- [Viem · TypeScript Interface for Ethereum](/index)
- [Client](/experimental/client): Setting up your Viem Client
- [ZKsync](/docs/chains/zksync): Integrating with ZKsync in Viem
- [defineKzg](/docs/utilities/defineKzg): Defines a KZG interface.
- [fromBase58](/docs/utilities/fromBase58)
- [fromBase64](/docs/utilities/fromBase64)
- [toBase58](/docs/utilities/toBase58)
- [toBase64](/docs/utilities/toBase64)
- [opaqueDataToDepositData](/op-stack/utilities/fromOpaqueData): Decodes opaque deposit data found in the "TransactionDeposited" event log.
- [fee.validateToken](/tempo/actions/fee.validateToken)
- [Setup](/tempo/actions/setup)
- [withFeePayer](/tempo/transports/withFeePayer)
- [TODO](/account-abstraction/actions/bundler/introduction)
- [verifyHash](/docs/actions/public/verifyHash): Verifies if a signed hash was generated by the provided address.
-->

# call \[An Action for executing a new message call.]

Executes a new message call immediately without submitting a transaction to the network.

## Usage

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"b078ec6791e11f65435df90572e706abe5afc8ec0869995e5e2307e7932dee6e","data":"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="}
import { account, publicClient } from './config'

const data = await publicClient.call({ // [!code focus:7]
  account,
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"de60e072e719e665a354134113201f9df7c0946c09e832d292290b93aa9f8f18","data":"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"}
import { createPublicClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { mainnet } from 'viem/chains'

// @log: ↓ JSON-RPC Account
export const account = '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266'

// @log: ↓ Local Account
// export const account = privateKeyToAccount(...)

export const publicClient = createPublicClient({
  chain: mainnet,
  transport: http()
})
```

:::

### Deployless Calls

It is possible to call a function on a contract that has not been deployed yet. For instance, we may want
to call a function on an [ERC-4337 Smart Account](https://eips.ethereum.org/EIPS/eip-4337) contract which has not been deployed.

Viem offers two ways of performing a Deployless Call, via:

* [Bytecode](#bytecode)
* a [Deploy Factory](#deploy-factory): "temporarily deploys" a contract with a provided [Deploy Factory](https://docs.alchemy.com/docs/create2-an-alternative-to-deriving-contract-addresses#create2-contract-factory), and calls the function on the deployed contract.

:::tip
The **Deployless Call** pattern is also accessible via the [`readContract`](/docs/contract/readContract#deployless-reads) & [Contract Instance](/docs/contract/getContract) APIs.
:::

#### Bytecode

The example below demonstrates how we can utilize a Deployless Call **via Bytecode** to call the `name` function on the [Wagmi Example ERC721 contract](https://etherscan.io/address/0xFBA3912Ca04dd458c843e2EE08967fC04f3579c2#code) which has not been deployed:

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"b917388f32ce0899d341d81b08fab2816b1714216c883c227df610033e5b8eff","data":"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"}
import { encodeFunctionData, parseAbi } from 'viem'
import { publicClient } from './config'

const data = await publicClient.call({
  // Bytecode of the contract. Accessible here: https://etherscan.io/address/0xFBA3912Ca04dd458c843e2EE08967fC04f3579c2#code
  code: '0x...',
  // Function to call on the contract.
  data: encodeFunctionData({
    abi: parseAbi(['function name() view returns (string)']),
    functionName: 'name'
  }),
})
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"577792133a9967accac50a843d8303e77374676885f2bcb57ea8c47a16ff755b","data":"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"}
import { createPublicClient, http } from 'viem'
import { mainnet } from 'viem/chains'

export const publicClient = createPublicClient({
  chain: mainnet,
  transport: http()
})
```

:::

#### Deploy Factory

The example below demonstrates how we can utilize a Deployless Call **via a [Deploy Factory](https://docs.alchemy.com/docs/create2-an-alternative-to-deriving-contract-addresses#create2-contract-factory)** to call the `entryPoint` function on an [ERC-4337 Smart Account](https://eips.ethereum.org/EIPS/eip-4337) which has not been deployed:

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"3ba35a4df71b811cc290be20322c11d6be192056accf488f8c147082948854e8","data":"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"}
import { encodeFunctionData, parseAbi } from 'viem'
import { owner, publicClient } from './config'

const data = await publicClient.call({
  // Address of the contract deployer (e.g. Smart Account Factory).
  factory: '0xE8Df82fA4E10e6A12a9Dab552bceA2acd26De9bb',

  // Function to execute on the factory to deploy the contract.
  factoryData: encodeFunctionData({
    abi: parseAbi(['function createAccount(address owner, uint256 salt)']),
    functionName: 'createAccount',
    args: [owner, 0n],
  }),

  // Function to call on the contract (e.g. Smart Account contract).
  data: encodeFunctionData({
    abi: parseAbi(['function entryPoint() view returns (address)']),
    functionName: 'entryPoint'
  }),

  // Address of the contract.
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"a2d8e61960cbb1f477b6647b03a5ddbffe1176a82a95b3b466f481ac3d95d20e","data":"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"}
import { createPublicClient, http } from 'viem'
import { mainnet } from 'viem/chains'

export const owner = '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266'

export const publicClient = createPublicClient({
  chain: mainnet,
  transport: http()
})
```

:::

:::note
This example utilizes the [SimpleAccountFactory](https://github.com/eth-infinitism/account-abstraction/blob/develop/contracts/samples/SimpleAccountFactory.sol).
:::

## Returns

`0x${string}`

The call data.

## Parameters

### account

* **Type:** `Account | Address`

The Account to call from.

Accepts a [JSON-RPC Account](/docs/clients/wallet#json-rpc-accounts) or [Local Account (Private Key, etc)](/docs/clients/wallet#local-accounts-private-key-mnemonic-etc).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"057a9f619a8e54ed70d9529e55f6f8985ae3ba12f18af2dd1d49f1e1e5bf193c","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266', // [!code focus]
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### data

* **Type:** `0x${string}`

A contract hashed method call with encoded args.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"fec0f6e8125499e46078d55626bcc004325578f00a3a15147f268c1757cf9b1e","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAigEM0vF2AwlwA2wgEow0AV1JgAKtlxU2XUg0QA2KsJhgA5mnxIALFV6k9kvN16UQwgJZhciAAxVG+VV0Y1ymgF8KdEU8QhJyMzp1EGZWDiwpACNHRgFHXTR+YAAdMHYC9h9mKTAs9lLYADMnGCgAbjzC9iSeTwB+bKbmwoBbKWE0B0YRYU6WiAgdLnyAH3YABVJJIaqMAB4AWQGhkdEAITb8AHksIZY4AD52ecqYGucG7oKAm4qwatqn/MKRzxg5A5ejB+GApL0kmRGj8CoxGA4sBIuFBxlURHAYG9cjCessAI5SeBocYACiw3mBfjg/AE8MRMAJRIWFMkZDgAEp2ABea5LCC9BwY9a0hESRlsCTSWQKHCXaHNV63D73L7y35eJxdHHNFIQRgAawAorQsMIIMtSNT2Nierb2MtkSxhBhOPcuDstXavfaYI6wM72GAuMD+DkQIbDGyRmAw2rvbjfVAnS6ZMJQwQ0GgsNSAPQ5yT4KMzAB0Dggsee8cKDqT/pdXCwDgAqqQ0+ww/hM9nEHmGw5iwWi2BSxAc32K9q7QE4z1p5XmsXF+wAIwadi9c2YxfFmfNCIONYACS4cHw4wEGrAADUyAeMMfTwAxObvT6PGdznHb9gaAAc683dhtxnaJdCgfh1jiNh2EYDIynYUCPjga150KYDK1eAAydhjR8NBmTUBwRHWbdLkuEkqjAfgSVghxMhpOC0BIxdLk5HkYMYtjrnSOiymY4s5TyAI7BUNQkGXABObRdAMIxEGXAAmMxVEsGJEhSYYeMyOxHGcJB3FiLxSDwshxIkoIQhwMJiFMqJ6DwMlSAgHA1AwTk9jbMkWSpGlRgI4NWUtdYbUKXUDWNU1N0tT07RrZNXTRD0UMnW04rrQMAvTCNC0taMJyrH0/QDVN007LNc3zSNcpLMt8qrNKAz7Fs2w7LsKr7AcqrgaMRzHRs6ttT8FRnML9UBEMVwU1xppnOI0GM3wrRC1LE3i3Q4CbMAHAiOARAkOApgiGL4wa+soCgZY4CtMNXFoGB7oe+7l2MKAAHZl1/RgFKSYxXqgCSJIUgBmWAuCSZcgaBgBWGBnuMR6Bu9U6WjNA0BAdGhwPYYHXF/KH8d/XdCiG2LVvS/pBmGUYgeOpGyca87LuukBbpGZdlySWBXChiTXtepIgY0IH2Y0V7XAU39fw0b6YAUrhl1eoHeY0Nnl0Rr1kdG9HfUx/hnuhwXXGXImXg/EDWDkYQoDgcZkbYUgnD0ZAAF03juB46hnBwseNysgwmsNsrIGBwURoMhhIAQZGWMBGAwWnmmR/2QXbcMqvV6t6ZdOAMAhKYsrkQ8M4KZHYHhXp0T1wmMJnb9l1cADliAxcZ33I8TzPGlLxvB326fF93dVITWO5XknIFIUhFESUZHkRRLjsJNGAQRBwzuxgpBoZCuEDGAAHd13gXbLBg0Z2CBYEoCImgAz3hxDAgTf2DgZIBUzR2inYeaZl23wy3yNAEAv6Fl3mgPe5p9TFjyHkAAtOwAAInqK0ZVux5iIHRXoxZTw5iXnAMcf8Lg5nUqkHMHlYHsAAFIAGVjgADkYFiAWAIdgmwCzQCtMgAABgWAA+h5ThzsSQoIqoOZY4Jizmj0PmMAOCYAkDNC5PBuC+qChzAAKwOmAGBpAsCMBzAAYl4R5dkdheB6BXsgZAIByTGV6HYFSyE4HAAAAK6X1IIPy3k2TCWdhQKxywpSsDsHIEBHlOA8C4MWa0rinDuKnuISQs8ZQwB8X4kAdBgymiUCAIEWBzQcGADBDGMAFjJFSFpMoFB2AoPYK8Ko492AAHJ0EwF6I0vIuT8nWnXFwJwzgOB1Iac0jBpDLxwHaTGWOFwOC0UyNyIpOsSllM0oxEkIVPC9Koj0vpkgKDdG/qwPJah+AoJJOyPZYAAjsjyFBDgNgd5ciKHvXpMzGLFg8ms7oxRH5lH4I026VQlZVCgBoGAUNlxcGRJLKoGgqjGEYDADQYNJYKVeqiiSjAqhYqSIDBSGgNCNIuQUe5fzWbi0hVwJWSQFLAyqDAX8UBXBcFcGCxgxgqiosTBJXGQNGCvShirL6hL9kQFJbQMWANXq81cIwcFv5FJQEYEDZl9c+WMo5lDFlrgoAK0VVKxgv5hWXJMc7XxIBRLqCBkpewMlDAmGUhYKwq8PI6VqPpDwRkTL+CtRZagoRV7hFstQaIDksBORcpgTk3zSjEn4Jw26AASYA9tHYBE4W8AAgnCH5HAlRvjqIvJBeAs0lHgjwXg/woBfyAZGU+oh2Akl6HAPQWCwJkHZMWES5h1DGGXNJfQdrECvQdapPA0ayiur0vJD13hfCmUQApX1mArIBpspEYN9lV6OWcmQSN4TeDpjJXLSFVKaVAzpQyplLKoZso5a9LlPK+UCrhApMMXbVDqAkr+ftsl7XUBUk6kA9zJ0uGtRshafgkCLuCH6ldBA12mJDVusNO7XKckAYe8VrhJXStlR9BVSqVUyr+kbJImqYDat1XyjFv433KG7eJDQUkbUDrkta8wo7V6AJA0gIGM6IPzsXWa5gsAmDTP3Q8p5Lz2DEJWbxNA7zRifJ+OO8o/zaCAoksC0F4LIVQGhbC+FiLkW/lReizF2LcX4qNcSiJYrGDkpPRJaltL6WMuZay9lnLkTct/Ly/lgqFKEvYHmdgyAACEInMRVD1FIOAzsRViolbzXDcqCPKqNsR9VZGtU6r+tRg1Rqrl2EpFwJAoBEJwH/ngNACAAgBCAA"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2', // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### to

* **Type:** [`Address`](/docs/glossary/types#address)

The contract address or recipient.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"10443660978183eb78d852533cd31505fc12ed6ba93d674a2ad1303761cf188e","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8', // [!code focus]
})
```

### accessList (optional)

* **Type:** [`AccessList`](/docs/glossary/types#accesslist)

The access list.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"818d9c0db1cb1ec6cb9564c357b741622ac8215814cde9088c69668f56ac7e7e","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAigEM0vF2AwlwA2wgEow0AV1JgAKtlxU2XUg0QA2KsJhgA5mnxIALFV6k9kvN16UQwgJZhciAAxVG+VV0Y1ymgF8KdEU8QhJyMzp1EGZWDiwpACNHRgFHXTR+YAAdMHYC9h9mKTAs9lLYADMnGCgAbjzC9iSeTwB+bKbmwoBbKWE0B0YRYU6WiAgdLnyAH3YABVJJIaqMAB4AWQGhkdEAITb8AHksIZY4AD52ecqYGucG7oKAm4qwatqn/MKRzxg5A5ejB+GApL0kmRGj8CoxGA4sBIuFBxlURHAYG9cjCessAI5SeBocYACiw3mBfjg/AE8MRMAJRIWFMkZDgAEp2ABea5LCC9BwY9a0hESRlsCTSWQKHCXaHNV63D73L7y35eJxdHHNFIQRgAawAorQsMIIMtSNT2Nierb2MtkSxhBhOPcuDstXavfaYI6wM72GAuMD+DkQIbDGyRmAw2rvbjfVAnS6ZMJQwQ0GgsNSAPQ5yT4KMzAB0Dggsee8cKDqT/pdXCwDgAqqQ0+ww/hM9nEHmGw5iwWi2BSxAc32K9q7QE4z1p5XmsXF+wAIwadi9c2YxfFmfNCIONYACS4cHw4wEGrAADUyAeMMfTwAxObvT6PGdznHb9gaAAc683dhtxnaJdCgfh1jiNh2EYDIynYUCPjga150KYDK1eAAydhjR8NBmTUBwRHWbdLkuEkqjAfgSVghxMhpOC0BIxdLk5HkYMYtjrnSOiymY4s5TyAI7BUNQkGXABObRdAMIxEGXAAmMxVEsGJEhSYYeMyOxHGcJB3FiLxSDwshxIkoIQhwMJiFMqJ6DwMlSAgHA1AwTk9jbMkWSpGlRgI4NWUtdYbUKXUDWNU1N0tT07RrZNXTRD0UMnW04rrQMAvTCNC0taMJyrH0/QDVN007LNc3zSNcpLMt8qrNKAz7Fs2w7LsKr7AcqrgaMRzHRs6ttT8FRnML9UBEMVwU1xppnOI0GM3wrRC1LE3i3Q4CbMAHAiOARAkOApgiGL4wa+soCgZY4CtMNXFoGB7oe+7l2MKAAHZl1/RgFKSYxXqgCSJIUgBmWAuCSZcgaBgBWGBnuMR6Bu9U6WjNA0BAdGhwPYYHXF/KH8d/XdCiG2LVvS/pBmGUYgeOpGyca87LuukBbpGZdlySWBXChiTXtepIgY0IH2Y0V7XAU39fw0b6YAUrhl1eoHeY0Nnl0Rr1kdG9HfUx/hnuhwXXGXImXg/EDWDkYQoDgcZkbYUgnD0ZAAF03juB46hnBwseNysgwmsNsrIGBwURoMhhIAQZGWMBGAwWnmmR/2QXbcMqvV6t6ZdOAMAhKYsrkQ8M4KZHYHhXp0T1wmMJnb9l1cADliAxcZ33I8TzPGlLxvB326fF93dVITWO5XknIFIUhFESUZHkRRLjsJNGAQRBwzuxgpBoZCuEDGAAHd13gXbLBg0Z2CBYEoCImgAz3hxDAgTf2DgZIBUzR2inYeaZl23wy3yNAEAv6Fl3mgPe5p9TFjyHkAAtOwAAInqK0ZVux5iIHRXoxZTw5iXnAMcf8Lg5nUqkHMHlYHsAAFIAGVjgADkYFiAWAIdgmwCzQCtMgAABgWAA+h5ThzsSQoIqoOZY4Jizmj0PmMAOCYAkDNC5PBuC+qChzAAKwOmAGBpAsCMBzAAYl4R5dkdheB6BXsgZAIByTGV6HYFSyE4HAAAAK6X1IIPy3k2TCWdhQKxywpSsDsHIEBHlOA8C4MWa0rinDuKnuISQs8ZQwB8X4kAdBgymiUCAIEWBzQcGADBDGMAFjJFSFpMoFB2AoPYK8Ko492AAHJ0EwF6I0vIuT8nWnXFwJwzgOB1Iac0jBpDLxwHaTGWOFwOC0UyNyIpOsSllM0oxEkIVPC9Koj0vpkgKDdG/qwPJah+AoJJOyPZYAAjsjyFBDgNgd5ciKHvXpMzGLFg8ms7oxRH5lH4I026VQlZVCgBoGAUNlxcGRJLKoGgqjGEYDADQYNJYKVeqiiSjAqhYqSIDBSGgNCNIuQUe5fzWbi0hVwJWSQFLAyqDAX8UBXBcFcGCxgxgqiosTBJXGQNGCvShirL6hL9kQFJbQMWANXq81cIwcFv5FJQEYEDZl9c+WMo5lDFlrgoAK0VVKxgv5hWXJMc7XxIBRLqCBkpewMlDAmGUhYKwq8PI6VqPpDwRkTL+CtRZagoRV7hFstQaIDksBORcpgTk3zSjEn4Jw26AASYA9tHYBE4W8AAgnCH5HAlRvjqIvJBeAs0lHgjwXg/woBfyAZGU+oh2Akl6HAPQWCwJkHZMWES5h1DGGXNJfQdrECvQdapPA0ayiur0vJD13hfCmUQApX1mArIBpspEYN9lV6OWcmQSNRQ4RHwADKCnKMtIojMj7plumrEAM42Dmi4JYAA0jADAzNr1hhdtCAILsu2qHUBJX8/bZLiQMuYUdq9ihHpPZOlw1qNkLT8EgRdwQ/UroIGu0xIat1hp3a5KNF6rpxsTcm+aqbOF/rEvJYwQNgODuHdQFSTqQDIgukfWD9rDKzqQ4EVDy6XAYYiFhzdIBt0Rrcs/QBxln2vqtMjeNtAk0pv0Gm39yhu3iQ0FDOjcl2YjuY/e6TMAX1vo44gbTXHEPzo0Eu/1gmg00BE2J3dEmSWpzJXLSFVKaVAzpQyplLKoZso5a9LlPK+UCrhApMMlH1BTT7TagdclTCMcdTEe5ZmgOWa9ch2z6HA3rsczEZz+Hq1XvFa4SV0rZUfQVUqlVMq/pGySJqmA2rdV8oxb+GL6n/3Ifxjp5D+mYiALM1JbLc7/CLrNcwWATBpnhN4PMrgzz77sGISs3iaB3mjE+T8cd5R/m0EBRJYFoLwWQqgNC2F8LEXIt/Ki9FmLsW4vxUagoUGrrHrYPwZA7A8zsGQAAQlm5iKoeopDUg0M7SsZ6PuEatEd5c72eiGcfcZ2Tv2keNN8RhIl7Bcc/Dc0dxg5KvMSWpbS+ljLmWsvZZy5E3Lfy8v5YKhSKPAFiolbzarcq6vKqNo19VLWtU6r+p1g1Rqrl2EpFwJAoBEJwH/ngNACAAgBCAA="}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  accessList: [ // [!code focus:6]
    {
      address: '0x1',
      storageKeys: ['0x1'],
    },
  ],
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### blockNumber (optional)

* **Type:** `number`

The block number to perform the call against.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"bbb45ad75b876f15ccb2a7aaaf1c8c848ca357d640918516ac1704b01e8cd28c","data":"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="}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  blockNumber: 15121123n, // [!code focus]
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### blockTag (optional)

* **Type:** `'latest' | 'earliest' | 'pending' | 'safe' | 'finalized'`
* **Default:** `'latest'`

The block tag to perform the call against.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"11aeff092386b9fbfff817f8ce93d4f20cd77593c9278f788f5224dcd28db329","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  blockTag: 'safe', // [!code focus]
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### blockHash (optional)

* **Type:** `Hash`

The block hash to perform the call against. Implements [EIP-1898](https://eips.ethereum.org/EIPS/eip-1898).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"525619186167d2cce7f03b6e63b2ae3df6400311b4996d87b3cb5f15f8cfb3eb","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  blockHash: '0x89644bbd5c8d682a2e9611170e6c1f02573d866d286f006cbf517eec7254ec2d', // [!code focus]
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### requireCanonical (optional)

* **Type:** `boolean`

Whether or not to throw an error if the block is not in the canonical chain. Only allowed in conjunction with `blockHash`. Implements [EIP-1898](https://eips.ethereum.org/EIPS/eip-1898).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"0f9b3fd484027434d83b351da5f0ea0c4aa6b835c531c70df14b473f3ea9a72a","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  blockHash: '0x89644bbd5c8d682a2e9611170e6c1f02573d866d286f006cbf517eec7254ec2d',
  requireCanonical: true, // [!code focus]
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### code (optional)

* **Type:**

Bytecode to perform the call against.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"714b06ddd32333caf6e8a8f0f4a948ddd48e7ff8fb63a66e31212b00b32aafa7","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  code: '0x...', // [!code focus]
  data: '0xdeadbeef',
})
```

### factory (optional)

* **Type:**

Contract deployment factory address (ie. Create2 factory, Smart Account factory, etc).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"a0571f46b0527bf7125afc03d67926f35bbf032768df52244cc722c5575bafda","data":"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="}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  factory: '0x0000000000ffe8b47b3e2130213b802212439497', // [!code focus]
  factoryData: '0xdeadbeef',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### factoryData (optional)

* **Type:**

Calldata to execute on the factory to deploy the contract.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"fb5d0bcdd9803ea326806836600113fcd3e9c1080b75c1eed3d39d7dec0fb1c4","data":"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="}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  factory: '0x0000000000ffe8b47b3e2130213b802212439497',
  factoryData: '0xdeadbeef', // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### gas (optional)

* **Type:** `bigint`

The gas provided for transaction execution.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"399c5237662f67db800cd59182606c2a9bec7ee829d86ea414aff978ccfd5d9a","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  gas: 1_000_000n, // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### gasPrice (optional)

* **Type:** `bigint`

The price (in wei) to pay per gas. Only applies to [Legacy Transactions](/docs/glossary/terms#legacy-transaction).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"fbf1dc53db2422561432e07df5575ba921e65a5a6842ba60c5bd42afdc2be2a3","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
import { parseGwei } from 'viem'

const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  gasPrice: parseGwei('20'), // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### maxFeePerGas (optional)

* **Type:** `bigint`

Total fee per gas (in wei), inclusive of `maxPriorityFeePerGas`. Only applies to [EIP-1559 Transactions](/docs/glossary/terms#eip-1559-transaction).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"6bf2b4c670473c66d2cbd790b3decfb73fa8978b17ae6c804e0faf0ce82a61ec","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvLM1JwYAcQDuMdoxhp8ZRLzhpS7MAHMKvYezQB+HQB0QK9ne46ARuyOG0NsOwC2WCFI0aVl5ZVVKECgIEQREEABhSRIguF5mXX1DI15SGCw8+TA0ZnFJXgh+XiMHXjQIXjBBXzJ2ETZeBwA6b28AWl4AERi4HXw0NCxRgHpponYYXy64fGno2OnBcQ5xeGmZOUUHSJKjOORkEDpmf1ZcKj8AoN5gEMPw9l4AXwFSCF9eAByeaLQG9MAHMIORiAgAsACYAAyA7jeWa8BGIrHYnFgEAAXXxVD0sgYiAAnFQ7sZNEhKdRZEYNHhIUcIlTDLhEIiqCJ8LJmGIyHSvhR0NguQRiMKqDR6HgRJI9LwoKVmDoEmxWAAlDSCUhgAAqEsiJKCSFhPJA1KMtMQsNljOZ8VVJUiHDAXPhvP5pEFNHIiAAbKLxTg8IQUic6GSQIqwMqsIIXBwRAkODBijpgN5eHn0iJFcI0DphLB+JyoABuXP5lylPnWF61/P53yCVjidqsVhNlwQCB3ZhSAA+vAACnkJux+BgADwAWQ7Xa1ACEG/gAPJYMoJgB8vDHZZgFc91Zb30PZjA5crNak+fafJghr8MB0TV8LjI99bhfYWC6swUBNvwbDyFeOYPq2eZ5AAjoI8BWDojAHDcGhkKMvAJCIAG6ghSHjgKLQBjwvAALwHpO/zsPIc44XhMAEXoupoPqRoSnuv75j8R43ied4XnyzCGNmF6timMQANYAKK0FgrCBJhYnQTBrZ5MBkisBgKonswy4qWpRn5hp0RgNpjTobYIAyZomHtGAdjccZammVpOn6qw1njJMMzTBoWhyA5XQSE54kubBMCaeZOnMFg7AAKqkF5vB2D5UyILMcXsF0AX2cOIUQNM2VhapxlfM5MEVeFeZdHVvAAIxBrwvhKbwdVdJVrYpDOGAABJcPgTYJPyhgAGqtLOA0rAAYqO163melXVapHW8EGAAcLVtR1lUxpmUA6HO8bKiIGbFLw+03mkUHGbtF4/AAZLwcn+kRQScKwc4dXue6MPwYAoWdCxZth51oN9dV7nwlG8MDmZoDDB7piDEM/feXymiU5qIAArAAzFSma2vgSANd6DKkEysZJimbQowj7qckgFPCX6QqBg15KhtQJrxJGMrUDGTAFBAOBBBgfDdilqHERhcgalq73oaRc63XWikiLJ8mKXkCvNmVJlRWZFnlvpnaGRFuTG+5lktNZtmBXADmlVb1vRRZnneRMGWzHlQUFaFIBdUZbkxek8VJSlaU+352W5XZAdgIVxXxa7Rkra2mca9Jr7241SJYpV8b6P6WHq65Nvh5mcAJT4KRwGwupwIOKSWxFYcWcBUCFFhdiIrQMBD8PQ8NbCUAAOwNRtIjwi4sIT1A5LkvC+OwMwLgNfj+O4zAY+wiP6cd1XFmSVrCQaTQh28KviIbbjD8bSHebZ5XHs6e2nZtFq+Pty5nexSgD3eAfcQAD3aA1BqLhYCIlxuSCeE8XD4yDPjSBQYJ6InhBtDaQY54wHhMwBqE98bwKDBAhqR9/4nx0mfKSF8opXx0GPHeyDEQNWft8Zae0EyGlYFAOATYAGZAMMYZA+IrzHlPDAc8ql2DX3YReMAVlUo2UTjAZolClHiBIAkfUeRRAYD/upahdt3wqMdmQShxj366AwF+QcDtDR9SsUbGxsBcK+HAkwp+D1KprQaoibaeR2p1Uqj1Kag1hqjTABNAwETZrzUkYJMAXxoYUSon8XwtEYD0S1KxdixocB7kiOsOINlB4iC2PAdIjQYBKBaiA5gTI4Zal4H4FoUBOA0AskoCwhAti6GTFk6cxgamlwTP6CQUh6h1C0LUtAShAhSR6I5MAAxhixDGLHTKcwFhLBWGsEYxUxBTLgPsZMqZpjS36LwAAUgAZU3AAOT6NqccCReALgCtALCyAAAGAUAD60s/n4kYOlPy/t1FLECEYfyYA1gwBIIpcWZzSmp1otMAAVi3NZpAsAiGmAAYiBdLbgJwmnnEuGhXwkRGRpAGMAAAAh6KS2ElZy1IpjIklwpzsQQFQQ0czpYqjVF0F4LLDBss1D2fJBpCkwG5RQS41xbj3BAI8QIwRXgiEvjAccFz6bg1MOlS8/BMlAhBL4MEPh/BapeC1ESYBPTBB+Oa/4lq9lXOiXAG13gTrBHhhdcicM9UGrpmmcGjB1bCVEo6wwLqKC1nGXAJ4JZeDpUYNwJNKTUSiCVMEV0GQQ3MCUCJQN4MujS2jbWQURZQaAgHvwEh/AoBBhgLjBqzBgLYP4EGfgsIRAwCDBvbB8IJ7jvJCIfgM6XAr3hEGIMgIc15iLToRttARCYO7cwEhLh4Sr34DADaUBETMERB2kQsJ+DjuNuSO++MRAT1xmQ2ey7k0QHXQPDBy8J7wMRCITtG1yZQBEPjc9ASn2nqgbjC9iIoBENA3+kQG1325oJESEAZoySLqJjSUm9pHRU2dHGLUTNPQsx9AKDmSB8bwh5pgcM/NpTkFlMLeIqE/ji0wHwOtEBixNj+QPAAJMAPQIijBfD+VeAAgoWfjF0+KLWkSUkYeA5P1uCKUEoz4oB1AaHZFpPZeCMF8HAIwywDpkG4F0LGpIkDPrwyTBzRHqZ4D48WcjXJCZxl9P6YUiB6Nil5kxqUUY2Pyg46LbjktRUlGsuA7d3a90Hvxkek9Z6L24yvTeied6H1PpfYWeEdg7M4y3hTG0doHSUzcy6NUXmLRUfZgGFmDG+ZhcFnKWMnGxZkB4462gM0h7jjIAoLgrh3CeDK2SaeQYnN2nJq5kjnihsjbG1wRreNmv+cDEFsMkoBasaFpFkALAOBcD4KyD46hE46HE9kUw5hkIqIcE4SbHhijeE1c8a7xwqClLwEkMAKQ0BpAyA90ZeQCjwARqUKZFQqg1FUPpxozRWjdk6KoFZNyNlYQhTsq1yxVjoq2OwHYCwzl/fZAyM4SALhXFoDcBS6qfvareFCFHbqLXAj2X6iEoQ2RqDhEiFEaJpgYkLjiXEGHiTYzJIXBbBH6TYzqyAan7Atu4x2zRxATV2uhaO9GU7vWYt8HqAl2gP74H/sA9PEDYGIMAcXmwlwsGYDwcQ0+qdG1Sty/s4F5BSvKO1ZI/ULb83fPUda4Fr4mHFSwDwGzh1GuzU86tfzgNcXi3pDLRYaQhrI2oyrVqGtD4PMNqbS2ttHau09o2n2gdQ6R0uDHRO5DM7+BzoPYutDq61Rfs3Ul3d5J92HuPae89l7r23uAvejaj7n2vvhH3wbw39UbawhrmEovs28HRMgAAhAnmAAgYiCDgPiD9g/rd/owXb4D8JQPgbYc76Dbu4MIcXt7lDaGvjkqoBImYCQFACujgCmTwDBxAC+C+CAA=="}
// [!include ~/snippets/publicClient.ts]
// ---cut---
import { parseGwei } from 'viem'

const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  maxFeePerGas: parseGwei('20'), // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### maxPriorityFeePerGas (optional)

* **Type:** `bigint`

Max priority fee per gas (in wei). Only applies to [EIP-1559 Transactions](/docs/glossary/terms#eip-1559-transaction).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"f9861e3917795219a461509d1791a57cd1659eeee58ddaeb0ed6048c0e472505","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvLM1JwYAcQDuMdoxhp8ZRLzhpS7MAHMKvYezQB+HQB0QK9ne46ARuyOG0NsOwC2WCFI0aVl5ZVVKECgIEQREEABhSRIguF5mXX1DI15SGCw8+TA0ZnFJXgh+XiMHXjQIXjBBXzJ2ETZeBwA6b28AWl4AERi4HXw0NCxRgHpponYYXy64fGno2OnBcQ5xeGmZOUUHSJKjOORkEDpmf1ZcKj8AoN5gEMPw9l4AXwFSCF9eAByeaLQG9MAHMIORiAgAsACYAAyA7jeWa8BGIrHYnFgEAAXXxVD0sgYiAAnFQ7sZNEhKdRZEYNHhIUcIlTDLhEIiqCJ8LJmGIyHSvhR0NguQRiMKqDR6HgRJI9LwoKVmDoEmxWAAlDSCUhgAAqEsiJKCSFhPJA1KMtMQsNljOZ8VVJUiHDAXPhvP5pEFNHIiAAbKLxTg8IQUic6GSQIqwMqsIIXBwRAkODBijpgN5eHn0iJFcI0DphLB+JyoABuXP5lylPnWF61/P53yCVjidqsVhNlwQCB3ZhSAA+vAACnkJux+BgADwAWQ7Xa1ACEG/gAPJYMoJgB8vDHZZgFc91Zb30PZjA5crNak+fafJghr8MB0TV8LjI99bhfYWC6swUBNvwbDyFeOYPq2eZ5AAjoI8BWDojAHDcGhkKMvAJCIAG6ghSHjgKLQBjwvAALwHpO/zsPIc44XhMAEXoupoPqRoSnuv75j8R43ied4XnyzCGNmF6timMQANYAKK0FgrCBJhYnQTBrZ5MBkisBgKonswy4qWpRn5hp0RgNpjTobYIAyZomHtGAdjccZammVpOn6qw1njJMMzTBoWhyA5XQSE54kubBMCaeZOnMFg7AAKqkF5vB2D5UyILMcXsF0AX2cOIUQNM2VhapxlfM5MEVeFeZdHVvAAIxBrwvhKbwdVdJVrYpDOGAABJcPgTYJPyhgAGqtLOA0rAAYqO163melXVapHW8EGAAcLVtR1lUxpmUA6HO8bKiIGbFLw+03mkUHGbtF4/AAZLwcn+kRQScKwc4dXue6MPwYAoWdCxZth51oN9dV7nwlG8MDmZoDDB7piDEM/feXymiU5qIAArAAzFSma2vgSANd6DKkEysZJimbQowj7qckgFPCX6QqBg15KhtQJrxJGMrUDGTAFBAOBBBgfDdilqHERhcgalq73oaRc63XWikiLJ8mKXkCvNmVJlRWZFnlvpnaGRFuTG+5lktNZtmBXADmlVb1vRRZnneRMGWzHlQUFaFIBdUZbkxek8VJSlaU+352W5XZAdgIVxXxa7Rkra2mca9Jr7241SJYpV8b6P6WHq65Nvh5mcAJT4KRwGwupwIOKSWxFYcWcBUCFFhdiIrQMBD8PQ8NbCUAAOwNRtIjwi4sIT1A5LkvC+OwMwLgNfj+O4zAY+wiP6cd1XFmSVrCQaTQh28KviIbbjD8bSHebZ5XHs6e2nZtFq+Pty5nexSgD3eAfcQAD3aA1BqLhYCIlxuSCeE8XD4yDPjSBQYJ6InhBtDaQY54wHhMwBqE98bwKDBAhqR9/4nx0mfKSF8opXx0GPHeyDEQNWft8Zae0EyGlYFAOATYAGZAMMYZA+IrzHlPDAc8ql2DX3YReMAVlUo2UTjAZolClHiBIAkfUeRRAYD/upahdt3wqMdmQShxj366AwF+QcDtDR9SsUbGxsBcK+HAkwp+D1KprQaoibaeR2p1Uqj1Kag1hqjTABNAwETZrzUkYJMAXxoYUSon8XwtEYD0S1KxdixocB7kiOsOINlB4iC2PAdIjQYBKBaiA5gTI4Zal4H4FoUBOA0AskoCwhAti6GTFk6cxgamlwTP6CQUh6h1C0LUtAShAhSR6I5MAAxhixDGLHTKcwFhLBWGsEYxUxBTLgPsZMqZpjS36LwAAUgAZU3AAOT6NqccCReALgCtALCyAAAGAUAD60s/n4kYOlPy/t1FLECEYfyYA1gwBIIpcWZzSmp1otMAAVi3NZpAsAiGmAAYiBdLbgJwmnnEuGhXwkRGRpAGMAAAAh6KS2ElZy1IpjIklwpzsQQFQQ0czpYqjVF0F4LLDBss1D2fJBpCkwG5RQS41xbj3BAI8QIwRXgiEvjAccFz6bg1MOlS8/BMlAhBL4MEPh/BapeC1ESYBPTBB+Oa/4lq9lXOiXAG13gTrBHhhdcicM9UGrpmmcGjB1bCVEo6wwLqKC1nGXAJ4JZeDpUYNwJNKTUSiCVMEV0GQQ3MCUCJQN4MujS2jbWQURZQaAgHvwEh/AoBBhgLjBqzBgLYP4EGfgsIRAwCDBvbB8IJ7jvJCIfgM6XAr3hEGIMgIc15iLToRttARCYO7cwEhLh4Sr34DADaUBETMERB2kQsJ+DjuNuSO++MRAT1xmQ2ey7k0QHXQPDBy8J7wMRCITtG1yZQBEPjc9ASn2nqgbjC9iIoBENA3+kQG1325oJESEAZoySLqJjSUm9pHRU2dHGLUTNPQsx9AKDmSB8bwh5pgcM/NpTkFlMLeIqE/ji0wHwOtEBixNj+QPAAJMAPQIijBfD+VeAAgoWfjF0+KLWkSUkYeA5P1uCKUEoz4oB1AaHZFpPZeCMF8HAIwywDpkG4F0LGpIkDPrwyTBzRHqZ4D48WcjXJCZxl9P6YUiB6Nil5kxqUUY2Pyg46LbjktRUlGsuA7d3a90Hvxkek9Z6L24yvTeied6H1PpfYWeEdg7M4y3hTG0doHSUzcy6NUXmLRUfZgGFmDG+ZhcFnKWMnGxZkB4462gM0h7jjIAoLgrh3CeDK2SaeQYnN2nJq5kjnihsjbG1wRreNmv+cDEFsMkoBasaFpFkALAOBcD4KyD46hE46HE9kUw5hkIqIcE4SbHhijeE1c8a7xwqClLwEkMAKQ0BpAyA90ZeQCjwARqUKZFQqg1FUPpxozRWjdk6KoFZNyNlYQhTsq1yxVjoq2OwHYCwzl/fZAyM4SALhXFoDcBS6qfvareFCFHbqLXAj2X6iEoQ2RqDhEiFEaJpgYkLjiXEGHiTYzJIXBbBH6TYzqyAan7Atu4x2zRxATV2uhaO9GU7vWYt8FW5OCQBhMDDf1RtrCbhPsMDl/ZwLXMlcsytKrlbzBaCW8CBYDAtvRukHGwK60zNgw69a4Fg3h2WPG562wTgZENe3cCvdrIxgns+Be3YN7IBnC8Ed54b7drfuC4+Kp2IQPkj9fB8I7I1sYdFBKLuRH1RagzM/Bjjo3RwTrJGFs3yhO9nE8ORsMnFO9ga4pXTlAKqmdqsiGzh1GuzU86tfztPIvkR5vRJiaXMvCQu5xvCWEDUPcUmWzTSv/2I8Uaj756jMfz9x4jAniLPXov9di/UBLtAP68C/6gG08IGYGEGAGi8bCLgsGMA8GiGT6U6G0pWp+CuE8821oxMdoFM3usY9QW2E80eAW9GmGiosAeAq+rw6+3OHqvOoI4IAacWxa6QZaFg0ghqkaqMVaWoNaD4HmDaTaLabaHaXaPaG0faA6Q6I6LgY6E6yGM6/Ac6B6i6aGq6aoX6m6SWu65I+6h6x6p656l616t6wE96G0j6z6r68Iahg2we9uOgO+ou2atYFuBgAeNu62oeE2HOQuMINh2avA6IyAAAhOQTAAIDEIIHAPiB+poUAX+hgqAcBvCKBuBmwlAdBrAXBghovEgShmhl8OSlQCRMwEgKAFdHAFMngGDiAF8F8EAA"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
import { parseGwei } from 'viem'

const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  maxFeePerGas: parseGwei('20'),
  maxPriorityFeePerGas: parseGwei('2'), // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### nonce (optional)

* **Type:** `bigint`

Unique number identifying this transaction.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"3cb72890d9e9369d441416f5cedd904fed01f8a54fb5b15bceea99d3478aea4f","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  nonce: 420, // [!code focus]
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
})
```

### stateOverride (optional)

* **Type:** [`StateOverride`](/docs/glossary/types#stateoverride)

The state override set is an optional address-to-state mapping, where each entry specifies some state to be ephemerally overridden prior to executing the call.

```ts
const data = await publicClient.call({
  account,
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
  stateOverride: [ // [!code focus]
    { // [!code focus]
      address: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC', // [!code focus]
      balance: parseEther('1'), // [!code focus]
      stateDiff: [ // [!code focus]
        { // [!code focus]
          slot: '0x3ea2f1d0abf3fc66cf29eebb70cbd4e7fe762ef8a09bcc06c8edf641230afec0', // [!code focus]
          value: '0x00000000000000000000000000000000000000000000000000000000000001a4', // [!code focus]
        }, // [!code focus]
      ], // [!code focus]
    } // [!code focus]
  ], // [!code focus]
})
```

### value (optional)

* **Type:** `bigint`

Value (in wei) sent with this transaction.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"7dabbf30842dc070013b74d3378e823b4fe13671ad37fe96e713ff8cbbf3cdc4","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
import { parseEther } from 'viem'

const data = await publicClient.call({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  data: '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2',
  to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
  value: parseEther('1'), // [!code focus]
})
```

## JSON-RPC Methods

[`eth_call`](https://ethereum.org/en/developers/docs/apis/json-rpc/#eth_call)
