<!--
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.
-->

# verifyTypedData

Verify that typed data was signed by the provided address.

Supports verification of:

* **Externally Owned Accounts**
* **Smart Contract Accounts:**
  * **Deployed** (via [ERC-1271](https://eips.ethereum.org/EIPS/eip-1271))
  * **Pre-deployed** (via [ERC-6492](https://eips.ethereum.org/EIPS/eip-6492))
  * **Pre-delegated** (via [ERC-8010](https://github.com/ethereum/ERCs/pull/1186))

:::info
**Why should I use this over the [`verifyTypedData`](/docs/utilities/verifyTypedData) util?**

This Action supports verifying typed data that was signed by either a Smart Contract Account or Externally Owned Account (via [ERC-6492](https://eips.ethereum.org/EIPS/eip-6492)). The [`verifyTypedData`](/docs/utilities/verifyTypedData) util only supports Externally Owned Accounts. This is getting increasingly important as more wallets implement [Account Abstraction](https://eips.ethereum.org/EIPS/eip-4337).
:::

## Usage

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"e4befd173e7479fced535bc7f3ee1e56379252eb53da7405d7de3cc27144fdf5","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpezfoICuYNIl4ADAAy0AJMBGl2YAOYBfeQB0w7ALZYIpUeKkzKIEc0tIAnFVYwdafEgDsVNI7aMAyIINYQ0gxuWriIilT8+I7iNOSIzroU6NixBMRkdjT0TGycPAJCIrwA7mzuaADCHB6yvMBGvJ1iEhEyctKwAGYxUADcHV0ARsxoiQD8cu1gXSu8JpKsaOz8dQu8kxAQ7szLAD68AAqkwVuDGAA8ALIbWzusrABCM4kA8lhblQAfLxzgMYMMwDAxhNOroQbwwRCoeNll0dokYAAVUwwORgSQmSZkFErCTsLAAJRgzCge0GbDgMHhS1WXWuAEdJPA0HtGFhkiZgmQ4HIGvxyVTOdyLgKhaRygBeYFXCAmdiM+5iiUwKUiKloSSkMCYnKAkldOGgsBDEbmzqJZhafrW8G2mG8KAzZgAZUkg2GtD2ABEvb7/exaPDEW7UZ06DhNIKZGwAPqTVgQfgAa0xzG0ew+Gezue0UZdSOhsd4ADpa7wAMwAVjWFiZterdt4dBo1rk90EwlE/GaMi79A8UDgbXdK3bnbhADJeABRWgpGWWTise7twGAxiDMByRjD9gtUUjtA72uAvhKgSXu/AppnmTX6tmoy6IymcyWGp1MEL4tHYDhOIgACMAAcbgeNoXhIBBABM/iBMEeC1O8QGXnYHCQkg8QgA6pApAUkFQZk2Q4HghAkOQ/jdiUHBcHwA5VFgkjptswF9NOVbhJEzo2pClYrNMsz4HsLKsmsLzbLscgHEc1JnJc1xoLcDzPJs8nvF8El/ACwjAlawnIu6loIuWMakuI+BYjieIEkSpCdmSlLUrScj0qwjLMjObI6lyIi8vyJGCqkIq8FqHm6mgG7MBFwpPmpqrqjAmrirFwVoPqhrGqa85lmZolokkTp8TJ+xFlmq5YBm1zyosAWstcNJCKwGAeuCzAvM1VZVSsbVQB1XVgIluK8AYIDLl4wo7GA02doNgXtWAnUIqQrByNN+AaVgIoAPSHcE9nygt1bsBAS0tYNw2jWIWDsAAqltO0EPtR2HcwT3Vqd80nJdEDfU9N0DTJujLRaUOdO2vAQQAbC21w1rWMO8HR7B3AAElwkmiuVYAAGpkFjGC43A+AAGKqdGInzp2cMI1ByNtmj7rdhOfZsUOl5jj2k6VTJc4WbwS6ruujhbGw757geR68Cel4Xq+V67ilp4tClPFqzeKLfsYZgWKIHFcfwOugQE4H1ihIDuJ43iQbbVtBCEICmxw5s4dE+FxAkSQkfwqRIDblHUDkNH5PR1CMaELDMeUPMeqqjoK9JnT3etY0Te9s1nbwjyOqwYNDZ5D10XAV0K9NEEl6tI1ZwIhMAJJQHIEGdpnG2Y3cWjaA0QhoIHrTTcoYoNGKEjmxP48zxP5sLwvM+L1PEgNGDBu/sbycmKnltS74tv2/BjsI6hpCu3gI271ouExIh/vJEHZEZFk4fUaEtEFAxxRx6ULEVEHLwTAOAorp14F3LqFxhRCDkJA3gqBbrwPGoKd6KCYB11amXRuIDJrTQ0H3TBvBMhCywWtDa6D3qYXqEQ0u5Cuq4PejSKA1w4BwCIboAAup3bBG1C7sG2hA3hXVEHgwzsI3glCpogEGKQVUtD64PUYdI6B8ohAcIoKQ1YyCc7SLQNdEA6N4HKOmqouA6jDEWU0eAuhDcKG6OmgOHsaB2GWLEUI+hwCcjvQIToDh3Cvw/iNv+XBCAqBgRCFBQix8EKIEbOfS+oRQl319hBR+w8yIQR8GHXBkc6KFFjkRSoohBRsLzJNcBsjVT9SqlI3x2h0bUOCHIepDN3T6JqTJOpQ8+6NMAq0VpFk3KDxaFFQZYBdD73AhBRQrg7ZwViX4agaE3alLgOUlJsR6zpNImkBGOSI6fyjgU3+IA+RyITJgPgVSTCdM6N0zQOhOxNIGT0p5X4pkhGQts+ZDskAABYEnoVCDczZAKdnPzSEhA5H88j5J/m7c5EBLkYD4A8vunzEJNlgn8xAgLlkX2BeACaYK4kQuDnimFuQv7RyKIirAFyyBXIAlhV5jztCYsgo2I+CzT5Ardi80lZ8iIB12QCqleTv4x1OUilFfAOlaPRe8qsLyWlvIaR88JVsQhIQgj8mJjtnYrLwPo0lMERVPwpdCt+uSjnwulfSxllhUWSN0fUzlSEkL6t5eCgliTiWClJXM4iYrKU2sOXCqVdKmAMuRUyl1qreDuq1QfRASF/nRJ9YgYVLsiWCp9rEGZ5KyL/IlXaqNhTZXxtYiMmQYz1WcvrIoNJvyT5IHNbmt2TjRmkuQsWqFZbI20sKUnSu2hxoGmuHIJQqh1Dqv0I27FrbYlzM7XgMdE7DS4ALYheJFqMl7MHTSk5iL/6J2KSy+oOs7ndBsK0Om5kqziXmDelY6wdJvFYHsJSxxVJXBuGTJ4clP36V+P8KucATJWRKkVUyrp6bunRPZbEqDJHOWJIhrKVIaR0gZEyc4NjApxVCrKSKoosNBWlKR5KvB7wqjVBqGKkocp5SNCaHAn4qyWQfaVe0hMhLwcfSsT0AQwwBmDKGP0AZiqCd42OBMOJkysDTDVEsBZVN5hkxWRmdYmys1Rh2Dm45ey8H7BezWo5ObWinIR2G7MuNixXGuIOG5pbbl3PuQ8x4LOtB1rLDWj5aPPkvLLfWQS/yiBeRbFN1tGzetxX2v1eb+nRbtvfLl/akDpqPcchFManXMo3exqEIYAh9nAfAsxsCPF2JEbZmrD0pHTXQQo8RniTH2HVRorRtjGsOJAC81rDWcHeOkcw1hrj5wBKrPA/hgj4GiKqjo1D00blDeMaN0xMDFpuJWCQ+ry28HUAMUYiRHWqs7fnNYpBEimtFJkKM9bZ3NudfZf4/WmjppzemvuQIUVvTsHHcVqApXmAJSSvKe4FWJEXbgRIxbMlDtoImk99rL36ndYO7d/rg3duI+ezgJhUAWHwEmxZabvXG5zbh54hHZDauupWzIuRJhUcM/O9tzHN3PF3f0WzpRL2Ltc/cUj6R3a6385G4T6RGO8ewmmyQr7RdpqaJ47eILqUGMZQB0DnIIOvSsYKhxuwI1+AIFCDr4QXicBQA9F6MQ1oBBsH4BsGY8AHcrjmtcAkABaOAOBxTDH4EmwHm6UZaAQcuZuFwfcQWcBBXggwLC7zQJwxge00AHUQMdGA5I4B/S9zAAk1YLDaEOlHi43oTrklj/H7g06swwAkMwLMSFGwI0YNNAwBhaBx7zmQIvJheCW6hAXUn5TEDd527wAA1Lwe2jA1nlL4HPpfQRuDcHkNWIwRgfe8CDJmKKGes/HSIGeEw1ZKaHVN3Ab6QcIOHReYdIrevQe794AAKW9D8AAcj7ikFwDQY+Xg0AIoEwe+X+v+/+gBvAAAgj0JEFFMgPIKdCmC/jbqDimEQP8vIGnsfl9DftWBFIlFwFmEDIdNoJIOwLAM/qHn3D7iJswAAMQbq4LE5eg+7YHcDgG8AAAymYbAcBCBdacgluU4RYdQGA1YvAP+EAn+3+f+ABQBHIOU1YhQeY5uyAyA7sAodgPmvAe+OswCchkgjIIAnCFA2hYUiUdgf2BhbQAAAnhFmMPqHsDqDuDnKHAJMhYdoepPlGEiAJiPZCHuOqPowdIcAE4VoC4Zbu4QbsEPlMVj4ZYSAHQIlPVNuiAFvP+MAAIG1DQAAOopaXiaIu4iCqjEKJ4s68AADkZ+MAJgtR4W28eRN8YAkIogcINydRDRJgh0DoWgcAzRi0YASc+hCo+R1IRRJRqsjA0kgxCs7RnRFAEwQ8Jw/uxscg5R+iJgjA1QWgI01QBeZ0g+3AqxEy3BYxF6G6MwW6tGYgtQ7AvMqsl+bhr+Xo8xEwAkvEtRygsBigDQgwPgzgUEUEiMQY/ykwzg0JUECMCMkwcWTay4y4zA/yCMzA0E9YUESEgwbeEEMAtRFxnQ18qcN6UitR/epABcRcRJ7oFcVccgtREEdJVYixrc7cxJXQPcGAfcA8Mgw8TJY808q8c808Yp48a84pK8oprJsIXJoSN6sOCCAUeRFJ6CRJ1uk0tR9StRxCXJKwapuitRLympyitR42pOepmQ7oFh7o1OKp4MRpqGtRNyZpo2tRF21pBpXQzp2p+i7p0unp223pqpjO2p4uLigZ2pup+ptpXJNpqIDKpgjgGAxWTJc2cpaw4+QQN6Nyr64ZTJA81QWZKwiafxtADQQYSEzA9YUAzgVMzg2Jy4eqVZzg/yPgy4/AigjYsBkwDQPgVMy4Pg9Y/yQYgwUEQYQYOJCMpZcZVYCqhGFJHwEAkwc5nQ5ZygkwHw25Hwe5kwu5O5B5R5R5x5O5p525l5u525c5iZpItaLiTJ2MMA7wEAmiK5kwAAhFmYmboNwOYakekWYO4HYMdEIXerwNjBAOqFsH4obBFm0FMW7sUayjrJosflUT0fUefiMTkaIHkcmUQG7gANIwBpkQDwEQXdE1HYWNF353rDEtG5FrCpydGYU0V9EDGEyMWjHjF8yTH8AFEwAoVXqXhfGog/GtCEUkVkWYgUXCFoCMAVmABkBLUecRMIsXIMscEAqSRMIBFnIMfowOpZcUYKOqHncSjJMcwE8S8S0G8brhgZ8dJKSRVOAhSVSTSQInOQydVsyXOeyW3PDD6TyXyYPIKXUcKfPFPBKXPJKZPLPJKavGvD+QqTkGAu6MqcgGGeqRNNGUybGXeasH6UyaaZouaZaWwqGVWHaVWA6dlU6YWXUW6eVR6V6fOayCVXUQGa1UGe1UVYaU1bUZGcMb1TGeqtVSsLVfKRMMmbvKQGmR6ZmVyWvhUu6PmT1kNcWeuZes0pFZWdWbWfWY2c2a2UGO2Z2d2b2f2YOcOaOeOZOdOUhLOT6QNcYQWcuauTtZubQJeXufuYeQeVeRefuSDcDeebeT6SNU+S+RmO+aud+QmRcX+eYRYZ1qmvWPCTim2pBD8muqEOgSVl6L2nuiGpCiHNkuGrCsenlnHLGnKrer0K0DOmoPUvoPCJRUzY2lBPigar4PyngJJb2sKmTVajlvatGnTQVi6q5WAFJIhi3F5GhoSGQPCJMIDloKIHBhWFpjZF0OgnsPUrrSJMbUJl0OspsHsCzXOuyuzdrXrZ0KFToPyesUHFbcoKzfOvIKbXJr5XLWquyj7T7frD7Y2s4HunzdmgLaELLb2ksqLWRNalRNSrlg6vlnGs6vKulTepVttjTgznTtotjkzi1nLkXWjtLvgl1mXfttzgzndrjqdhXUdpVWTlxhToolTkXPnQ9IXZTvYkzmtmXf3QwoLpzjXddiLsXUdnzsPZ3RtBzmopdlYptW1vXf1iNZLgvejtXVNvrJyhmhHVmnuvje/PAL2uagnQOlTSnRLZWvTdWrwHNamemSouPfCErgItNAfRBLzVmhBC2qfc/QtcVr2sGqKuTWmuLRWjKg/ZndmWUrmVohtfVkqhqu4omtbWzfIG0guRAAWfcm6uqn0qytOh7TbX3PoLg/eQ9iIUmsQ5qujeBP8vWEspHUsqfataSkhIRFfVltA8OqcknERRwEFT+ipAfT4EfbiifcaqECI9Qdwz8nw9mgIyekxGUDWkAh7NxMrFopJQJtpu6M+vjKvbJB+gpPsIcL+vCP+hpIBtpK8HUKBvgIZBBlBjxrBtBrJm5HZA5KhviCra5JhtqDht5Hhv5FPcRseNYRDlFExpRiIJ4ZFClPRulJlNqHFIbsVpxntsHQrWSWY+mJmLVLQPVK2E1GYyPd1PSH1FU/jjzv1lSXAAtENkthIoaIIrtJ9NnidF7i04DFdG0w0wzj9C9G9NIvgb02MycQDGAOQWM8M7COjJDLdHDIjPpiLO4jyRTKYw0ITCTJoDjHjDTPk1xjptIczJs/ZisFZkFWZkAvoXczZmszcxaI5hLC5lLFuLLJ5grErKrCrC0P5hrj5trCFruGFvBdvDo17KrAfVBHMpHYlkA5xJ7KlnhLEF6plmmooGo7TWcnA8yjyfEWVorH9nIIc2TKS2DtRvKKkyzuk1S3cDS9k6aCbofngMywwkkKIGwXbgEABFOBuqPpMDy0yLGmfrALbq3dvqMXvgfmblNGAFEc4cq1M6fufpfvgNfofnfkZLfrC4dCSx8QEIwwENoJoVYboVQLE14fYaqzEbwNyzS8k8KCkX4YkUaIEYUfZF7rwBYJIhAHyyEbcZOkyOqBjKUFAJEdEWAC4S66a8wGyzgD4WjREkgI2IoDyglrI4Sm7Ca05QEEozi/WPWPi2nVLRncyq3WQ7Otgxy2bngMEUyK3cAry6ESbXNAG5oNoFoIIatXKzvsaCEW2/ohjKTHcO20yPy4wYnhYGoTFiENyjmzjRw3I2EMThNtw/iio0nWfZKoI6egnFo1UAYwoOQ9g0xVYApZynFi2uw9HWELezummruxAxSgAxW5LWEGABgHe/WEi1muu/m4LVu6Tjuzi3Ht+/fdLXwLLfLWyYrXsIEy5GrRraOPbSbVh2bYQ4KIbeqkHTh3JhbTyHW57bbd7cR52E7f3OFSkO7fW17WcysH7QR4HcR2c9xtZCJHe1m9jbEjmhu7Ha+23ji/u7akOuo1WwzYqVosgLQAHX3Jwj3Y3K63S8gB3Z0Ap9OvUsgBR5Q5wrgYYw7QgopwoIMNIPfkIPpxQzoFwsZ940Y1WDpwoK3bZ2zUZyp056Z65/ID+h5/Ol5yZwhi5+Z/5xgDQHAIF7bcFz56FysH52K1FxBDF4Z4554+6El5F/AEhGl/Z3F5l2F9Osl/APWPl3oIVzx7h2ZyVzl3AP8hVw5950V4l+F6V3AI2E11VzBll+1/VwjN1xl9V3Jtl1Fz4ENy1yN52GN/AFBJNyFzV7N3AM4At/F0t/1yl4oGt6110MtwAzt9N313Vyl3lwZwV8N718VwoB13qod1d21yd/AL/fdz48dzd/VxBF1+d5V5d299dxFyl4Nz9814t6N5t89xNyDz1/949x9yl/N9D39853D4D896t0j1Nw93txD3ADw69yjzj093j6l5j2DzN7j56gT755T+V2T+t+D8T+mtTwl0T/D7l993Z791j7D2z2j3j8D1z6DwzxT0z1D0LzD4T9p5T4jxL8jzT0zxj3Lzz1L7V+z3AE2izxt8T/WKT8r+T+9/zzbFr4zwoJrSb6L2bzILL55/L6z9L9OprYjBb4b5rcz/T7tw71b2gMbx70dwD5rRmi7wHzIP8jb0F3b9r97+3sH6j5rQjI1379j17/IJrT4Gd/ryL679b9t0n7zyn5rWCbH3z5rc4IL7byrwr97zMon5n572r6nzIAAxnxXwbyH2gMhLn3X/73H030hOH7F5H6b43x35jcXwX03/8rX631n+319y3xH5X/bw307wjF3zP/X356vwP+l0v1HyP1kuX4v2373x3zzePyv0384Av4P3v8P274oOv8f7P6fzwzvxd3f5byP7qkf7fyfyXzIE9TT9n+m/cLm7197d9k+l/NAOmif5/8X+AAmAWHwv5b9ABMfPPqrz85UEZAKA8LtgLQDv9ue//FPvgOd4YCq+8gfAe70gH58G++AiARvx75898BQfcgcvywGB9CBwvUAdOnwHoCaBmAvAfH2AHwCeBCgfAen1wG8DC+cA3fsQLoGF8uBkvCgfgLL5SDxBTvRQCILkEICSBTvZCOoMoFO98ebA/fqQP76GDSBY/UwcP1IFT9LBTvblA4Kb5r9nBHfZmG4MP6eDz+Ngr/qQOv5uCeGsgj/vII4GADFASgofn4Ld5kCBBKgt3tQMYFQCwhMAhgSAKYF6DABrAuIewKEFZDIhn/Q3lQP4FJDaBcMZwM4GuaGYqwxQhGHsCK6TIl2mbNfgJ0dh5t/UySUTiLQ/aJ0YOsDODk/UTAv1RsyaJhsuwRhAcEsgDDdsA0WrURRO8dHodfWTqHtpOhLAYatTkBUhBApAKAPcHqSq542kAaoGAEBB3tr+rQ/mkllWQ5ksimLLLJfSWH8Mb6qwgllWngZhst05HIXlR14AfAcusBUgCRC6jnBLcllLIjfmbahsLK4bdtjMCFa8AggkIEiDQFtxitO2fcadgg3WRBAagzxfAFiNbo6lBh7AIijQF4CN4pCw7IwC207bgjjCE7I5v+yaHZpFA8WHGqug3afDrg3DcBpal6Fo1BAsAPAHhUQqSVNEUWUok/TRa6NVY7FSorUWrADFLwuFYJPhR3ipwxqU4aigqKVGMERiZlC9KtQeLSQUG7oCkttR9I/UqyNZOsg2SbJQQWy9YNsh2S7I9k+yA5IciOTHITkpyM5VKmsXwaKpjSH5Ocj9T+r/Uzyp5E8kDWvJg0TyENJGhpQfJRRaiz5V8vDS/KskDYhooBNyKZDWVbKu1RoJeAcpG4iaAQcSp0HFETBZaaVUBFyVmGv1aiy1CYKtWRpXEwKyAT8kKKZBJ5yi6QZwJwlzFVAFGtuQsY6BNgyi4W9lQthWOYBVixA4HNhHIEkrVhW6XJOsWsXSqNihhIDJarSRWq3CuS+YjsUYDApDwuQdgYgkgFABWZK4QgE1AgF0C6AgAA=="}
import { account, walletClient, publicClient } from './client'
import { domain, types } from './data'

const message = {
  from: {
    name: 'Cow',
    wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
  },
  to: {
    name: 'Bob',
    wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
  },
  contents: 'Hello, Bob!',
}

const signature = await walletClient.signTypedData({
  account,
  domain,
  types,
  primaryType: 'Mail',
  message,
})
// [!code focus:99]
const valid = await publicClient.verifyTypedData({
  address: account.address,
  domain,
  types,
  primaryType: 'Mail',
  message,
  signature,
})
// true
```

```ts twoslash [data.ts] filename="data.ts"
// @twoslash-cache: {"v":2,"hash":"88a48a5f95b4e794efd7d7eaf7ad97e378290292199afebbfed3876281b1a766","data":"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"}
// All properties on a domain are optional
export const domain = {
  name: 'Ether Mail',
  version: '1',
  chainId: 1,
  verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
} as const

// The named list of all type definitions
export const types = {
  Person: [
    { name: 'name', type: 'string' },
    { name: 'wallet', type: 'address' },
  ],
  Mail: [
    { name: 'from', type: 'Person' },
    { name: 'to', type: 'Person' },
    { name: 'contents', type: 'string' },
  ],
} as const
```

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

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

export const walletClient = createWalletClient({
  transport: custom(window.ethereum!)
})

// @log: ↓ JSON-RPC Account
export const [account] = await walletClient.getAddresses()

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

:::

## Returns

`boolean`

Whether the signed message is valid for the given address.

## Parameters

### address

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

The Ethereum address that signed the original message.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"6bff6b116b73bae6c541a4c5136258fd73f16468db2f5a68e39c73ab63686532","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266', // [!code focus:1]
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### domain

**Type:** `TypedDataDomain`

The typed data domain.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"968245c2c2f00979e5df643eea62f2bb5e6ed06f1f4542240beb0b305e053d52","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: { // [!code focus:6]
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### types

The type definitions for the typed data.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"25c88a680391be4307c4d52a1fb46f3997f15b94fbaa8dd4d7d4931ea132b09c","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: { // [!code focus:11]
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### primaryType

**Type:** Inferred `string`.

The primary type to extract from `types` and use in `value`.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"5f5efc257824fd904a3bbe7426b1c80172add0cdecbceb045fa93d8a9cec52d0","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: { 
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [ // [!code focus:5]
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail', // [!code focus]
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### message

**Type:** Inferred from `types` & `primaryType`.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"6506173a2c318c63cd7b927af7290a461c19b6b033d4086acc75eb6e5e09993d","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: { // [!code focus:11]
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### signature

* **Type:** `Hex | ByteArray | Signature`

The signature of the typed data.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"65891183d09675b99c753b6c1f734642d7e44c9f1a56105a1055dcc86cadbe38","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...', // [!code focus]
})
```

### blockNumber (optional)

* **Type:** `bigint`

Only used when verifying a typed data that was signed by a Smart Contract Account. The block number to check if the contract was already deployed.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8586e148965b9d5b872ad6d12722c09fd78c9a239f13daee23d46ebba06cb8f1","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  blockNumber: 42069n, // [!code focus]
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```

### blockTag (optional)

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

Only used when verifying a typed data that was signed by a Smart Contract Account. The block tag to check if the contract was already deployed.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8586e148965b9d5b872ad6d12722c09fd78c9a239f13daee23d46ebba06cb8f1","data":"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"}
// [!include ~/snippets/publicClient.ts]
// ---cut---
const valid = await publicClient.verifyTypedData({
  blockNumber: 42069n, // [!code focus]
  address: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  domain: {
    name: 'Ether Mail',
    version: '1',
    chainId: 1,
    verifyingContract: '0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC',
  },
  types: {
    Person: [
      { name: 'name', type: 'string' },
      { name: 'wallet', type: 'address' },
    ],
    Mail: [
      { name: 'from', type: 'Person' },
      { name: 'to', type: 'Person' },
      { name: 'contents', type: 'string' },
    ],
  },
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  signature: '0x...',
})
```
