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

# signTypedData

Signs [EIP-712](https://eips.ethereum.org/EIPS/eip-712) typed data via [ERC-7739 `TypedDataSign` format](https://eips.ethereum.org/EIPS/eip-7739).

This Action is suitable to sign messages for contracts (e.g. ERC-4337 Smart Accounts) that implement (or conform to) [ERC-7739](https://eips.ethereum.org/EIPS/eip-7739) (e.g. Solady's [ERC1271.sol](https://github.com/Vectorized/solady/blob/main/src/accounts/ERC1271.sol)).

With the calculated signature, you can use [`verifyTypedData`](/docs/actions/public/verifyTypedData) to verify the signature

## Usage

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"99e061510cdc7e0b6de611680e3a794ccf8482593a4cc1816d6167f83c613ad3","data":"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="}
import { account, walletClient } from './config'
import { domain, types } from './data'
 
const signature = await walletClient.signTypedData({ // [!code focus:99]
  // Account used for signing.
  account,
  domain,
  types,
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
  // Verifying contract address (e.g. ERC-4337 Smart Account).
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})
```

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

export const walletClient = createWalletClient({
  chain: mainnet,
  transport: http(),
}).extend(erc7739Actions())

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

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

:::

## Account and/or Verifier Hoisting

If you do not wish to pass an `account` and/or `verifier` to every `signTypedData`, you can also hoist the Account and/or Verifier on the Wallet Client (see `config.ts`).

[Learn more](/docs/clients/wallet#withaccount).

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"fc20ee5c5cd7d02ca6881e5fc272a97d8b86a51cdc34e380c4161539f5c7ef64","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeAdzasYaAMIcYYNIl5z2CtAB4AEmjRYAKqWbCsEUpoCuYWADN2YGFAq8bbODAB8zq7fuPnwAA6YLyhvMxQUKTwcMoAgpHRcHAA3MFhvJBg/DAAssbMAOZkAPzKAHJCOflgRWS8AD68PjB2DlBpIWFw7IVgyoxYzEYAttJksbxBXRmh+Fz4yloLnRkAvnwAvB68AAqkECPs7tp0HqvdvWBxFmiEpOwAXsxo7EIDQ6PjpJM3d2ZPF5vMAAJRgAEcLPA0FsdvtDscYBoAMpXP73QGvIRgtAWUhgfTYTwXUI9Pq5GJ1AbAXhjZJ1XhrZTTWZhOlwKm8VF9ZgAIykFPpxRJjNhewORxOWjOIoAdPLeAAWWlmGC8eWykWYHDKQIgVgQfhsPWdNbOADqkmkIKw/GR/HwMBGzAC6TCGtNvAAZLxLawpGg4vwscINBqPB5guwRqZzOIrbJ5IpKCARMMGIgAJxUKRgQp3JAARgATFQ0MNihmQBJ/dJVOoUxwHEgAAxUB3DZjBshITNm9BEvCEEjkMt0KssDhcPiCYSiKCHZj2Zlu0LRCJCVgYTLMMa6kAAUTu9Xy7FYJtXvHXC7AW94I56714esLF5mV5gG9v2479gAklAyiFiK16btuI7sDYGD2IUMhCGgRjBvuLa0DI/AyGh/BYRhGHoThuFoZhhEEVhpHYW+axRjGZjzou9gpmm5hIIq2b6go+b4EgABsZYVtIeALs69E5n4RbtvMiE0OQWb9tQg6IAQxA9mO9BMGwnA8AIQgiLw2rwCu76gd+ewTE+Rl3qgl4ZOZ261Huz7gLuMBvqya6fjed56fuIgPHmLlhGaUxWWENk7vZeo1gG/msqFXkOREUQxNFjIALoge5YG8KerDKKFlnvtZGXGXZMD7jYErJYVX6eUS+67KZYDJYFLKuaFJX7mgECVSFRU1TqDn1T8QhNa6BU9dVtlOfus40IocDdW5E26bVDk+TBTVpcElFgNGsaiHpCBUIxGYAKwAOw5uxBaICdvGkJWeAHY2omIIW4mdt20mFmdsl6UOSmjtQ454LOOlkrUuLRMoAAGKEACTAGteZrNDDHlkxiAABwXWxebXax6MPQp4MvHiuAic2iAAMzvZJPaIFxv3yYpI4pjQqkKZOGkztpoiRXWSZKCogvaLoBhGCYNEaC0bT+C4bieN41itH4ThBe+CVJL8iQxCKWTVAUxSkGUvCVNkeSG/UTQy6rIrgx8nZjFJkwtay8xwIsvDLB7IobLw2zigiUoype4PogCzwhg7XzO/EtwYpHwJgpC0JivCkpIty1zxxHQLYtIeIEkS5yh1cgocsU1K0pSxSMgZrnV0KpVclcfICjXMC+2nEqIqctAl++GpKiq0TqvKWorXqBpGueICmhaCY2naDpOi66sZB6W3er6CZBiGcBhvKEZUXt8a1omajJkd6MZoWLa3bjHFFqW1B8VW/MXw2FO4NTtNdlJSBiyKiZjgf6rMVITiwAcHA5gMB8HBoSHAUAAAiLxmDKA0K7D8S1BpwDMr1bc+UG5tSmg5EqC1sEeW3HFPUSNCgjXXq1AhYVm4RQTBQ2Kk8QCaySnPS8axNqGWYdlXKzCiFMKWu1By5VDgcOYTQkAuDhp8PfM1YKi0qEsI6l1FRxD5FcKUY1XRAVRp6MkaQvUM11DzWMTFfR/VaEIXWrY1K88HLZT1ErXw7QPCDEdt8SYWdEGOFQeWXY/jnaYMvKFQxoilriLseY8KjkxhyKWgouhDCsFVU0VIth580maIUTw5IG10pLREZQzKCTZgkOSTIkYhTMoKMMVk9RVTioWOoDokUOTmkGIam0saGjMp5JAFYuaTTjIZKcX5FxAi3F6g8ZQRhoRN5gECjbHx3cg6ZyuMElBaCcSF2CTsRgABqQsvAAYGgiNwNG6YiyFkxpdPGnFXo01fvdfixN9lEkOeWZ6lNPkdjptJKmP0KADlAQpYcykgYcxAIMaBZBMB8EEkuMAJssG/jAABE2YALAjF5FbXgvJej2FENbZWssoCNGaDS22l4SomzofSrZjh2WMvaHbNgaATaw1oAjOhKMuXeMcCKCCUEYJwUUJJAV8NEazMKKK6l4qOiXgfMCVlyqxUq3aHq2lno1X6scA8jGhYTo8Uftda1hMfkgAxcJfUL1FR/0+oAkBP8WbwvZpAlFsC+AHXruNTRsSOkWWyaG0ZXTyEuL6dMrhmT5mmIkbkrpH8pl9VYdwnWpT5mCITXeSpeUo0jM6fUiq8bo2JocYowZKbVm1OYWMzqWbqEDKGkY32qbEnpuSRMtANjek1uzd5ZVZStrmtvlxa1uYn43TukTOSOBDouspg/UF/96bFi9WA31wNOZQIgDAtFvAoHRmGBgYJdUG30qWUuWe06ixnQfvO66hY3pfOXRe50pBr2Dm/txd1ADEC7qhSu71cLAZ+qYMe09cDG4V2blghpIbWRSLoSO0IH8YaKpFdDX2WoIDodmJh5V2Gz4Bjw0KpVvkVWEf4SKQdkwsNTuvo816mYXk2veTje1VZ2R1CBT/HGW6PVgb3bCgGbND1Ivg6ixDaGm3kfoyKXDvBBXCuVSjU0z6wOFk+e+95brv0OoaSJpAPHxOgeARBv60nwEIv9SexTfBVMwX08WYsONjPMSXQ6kqlmswgfpozezzNoOycRci1zgaqPSBo9p+jKMvOKjnVdd5dq354A/sFu+oXpLhehVBmTEC4MBrPZ1UjHm8zqYTElujMFdPsdTDfJAVNP2vIXS/ATj0ID5ZfjZ+mdmSv7pg3J2LCH3OkLofpqmxYjOZf82ZqsQWgMfMK9xKTPqJsxYU/FjTWmmvI1RhxjGVNFQvz8wzAL78Ez5dM8NorO2ovlaPZVxDLHlBzfOxmRULZfPLaxndkG8FrH5etc95iAj2zQG9btGiUwEuf0UIyFwEpeAAHJZQAHpZx2EKFjk+SOaROrAM4A66OGnY7x1ANBxOQjBFBqIEmkM1SbHCBIdgfMEz1kULKBB/zQnMEYDSXHuPeDIAAISCFgC4Q0FhYiZkzClN05OKBugOprrov6r03ux9lLHOvQhCcrk25TUapFY7gmIY3wUNNY5QjIZBxZmBUygJmAAYpmKmmMDyGZd5mRUZ0Dz8HvnEXkMgzpe4PGdS7yCbCY2QcgzGxYuL29USbsI1Wm2hGtwAIQgLyTPrJHcoV5AXyvBea+8mr1XuvDeG+N6r83yv7fq+V9LyYy833sfSn9BAZwRfeTS+72aLa9yqBO2YEgUA44FCPjAI9BAaw1hAA==="}
import { walletClient } from './config'
import { domain, types } from './data'
 
const signature = await walletClient.signTypedData({ // [!code focus:99]
  domain,
  types,
  primaryType: 'Mail',
  message: {
    from: {
      name: 'Cow',
      wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
    },
    to: {
      name: 'Bob',
      wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
    },
    contents: 'Hello, Bob!',
  },
})
```

```ts twoslash [data.ts]
// @twoslash-cache: {"v":2,"hash":"290294ee97e88d2ffbd01abe9a40e29b11b8417686d0c579c19072568f3993bb","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 [config.ts (JSON-RPC Account)]
import { createWalletClient, custom } from 'viem'
import { erc7739Actions } from 'viem/experimental'

// Retrieve Account from an EIP-1193 Provider.
const [account] = await window.ethereum.request({ 
  method: 'eth_requestAccounts' 
})

export const walletClient = createWalletClient({
  account,
  transport: custom(window.ethereum!)
}).extend(erc7739Actions({ 
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2' 
}))
```

```ts twoslash [config.ts (Local Account)] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"3c236fb27d59b9fa173a71f717ae18e3208c5a32ce0080d6c3d28eb1501cb2be","data":"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"}
import { createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { erc7739Actions } from 'viem/experimental'

export const walletClient = createWalletClient({
  account: privateKeyToAccount('0x...'),
  transport: http()
}).extend(erc7739Actions({ 
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2' 
}))
```

:::

## Returns

[`Hex`](/docs/glossary/types#hex)

The signed data.

## Parameters

### account

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

Account to used to sign the typed data.

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":"f63dba1eaa2436ab0af7db5797abf14e922185f117c3747cc0bbf9a56299faf8","data":"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"}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})
```

### domain

**Type:** `TypedDataDomain`

The typed data domain.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"86a1e8fcc4b07dd0b861a2f37b94984d0ee0e68cbae43e8caf6faa24949e0c3f","data":"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"}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})
```

### types

The type definitions for the typed data.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"0fc429f683d4dbd254c990b28ffb1b4c870ae03ea29fa151d98522bffb306bb8","data":"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"}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
})
```

### primaryType

**Type:** Inferred `string`.

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

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"91c649fe535ca2a35dee31061741ec5829f03145ba2ff39e3ad7c27dee739621","data":"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="}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
})
```

### message

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

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"c83ae478c752abdb0158d0e48634e166361227d96e08dec70960604204dac1f4","data":"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"}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})
```

### verifier

* **Type:** `Address`

The address of the verifying contract (e.g. a ERC-4337 Smart Account). Required if `verifierDomain` is not passed.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"7be1e1599fbe4d5a9e66249d99c3eaca08ed9638d0e4396380842e4dc1e7e83d","data":"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="}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2' // [!code focus]
})
```

### verifierDomain

* **Type:** `TypedDataDomain`

Account domain separator. Required if `verifier` is not passed.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"ff15b183961224df587d9beff02c7101dbff9f06875d0d562e258f3158d78dc4","data":"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"}
import { walletClient } from './config'

const signature = await walletClient.signTypedData({
  account: '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!',
  },
  verifierDomain: { // [!code focus]
    name: 'SoladyAccount', // [!code focus]
    version: '1', // [!code focus]
    chainId: 1, // [!code focus]
    verifyingContract: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2' // [!code focus]
  }, // [!code focus]
})
```
