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

# Wallet Client \[A function to create a Wallet Client.]

A Wallet Client is an interface to interact with [Ethereum Account(s)](https://ethereum.org/en/glossary/#account) and provides the ability to retrieve accounts, execute transactions, sign messages, etc through [Wallet Actions](/docs/actions/wallet/introduction).

The `createWalletClient` function sets up a Wallet Client with a given [Transport](/docs/clients/intro).

The Wallet Client supports signing over:

* [JSON-RPC Accounts](#json-rpc-accounts) (e.g. Browser Extension Wallets, WalletConnect, etc.).
* [Local Accounts](#local-accounts-private-key-mnemonic-etc) (e.g. private key/mnemonic wallets).

## Import

```ts
import { createWalletClient } from 'viem'
```

## JSON-RPC Accounts

A [JSON-RPC Account](/docs/accounts/jsonRpc) **defers** signing of transactions & messages to the target Wallet over JSON-RPC. An example could be sending a transaction via a Browser Extension Wallet (e.g. MetaMask) with the `window.ethereum` Provider.

Below is an example of how you can set up a JSON-RPC Account.

#### 1: Initialize a Wallet Client

Before we set up our Account and start consuming Wallet Actions, we will need to set up our Wallet Client with the [`custom` Transport](/docs/clients/transports/custom), where we will pass in the `window.ethereum` Provider:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2e96f58ea08b621bdf08d70fed1dd1079b7ca2a745f09d65b8310a335569ecb0","data":"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="}
import 'viem/window'
// ---cut---
import { createWalletClient, custom } from 'viem'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: custom(window.ethereum!)
})
```

#### 2: Set up your JSON-RPC Account

We will want to retrieve an address that we can access in our Wallet (e.g. MetaMask).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"144c0e7ef58456f9b66491036e2b6c34ee2feae913132799c8313bd45f1db14b","data":"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"}
import 'viem/window'
// ---cut---
import { createWalletClient, custom } from 'viem'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: custom(window.ethereum!)
})

const [address] = await client.getAddresses() // [!code focus:10]
// or: const [address] = await client.requestAddresses() // [!code focus:10]
```

> Note: Some Wallets (like MetaMask) may require you to request access to Account addresses via [`client.requestAddresses`](/docs/actions/wallet/requestAddresses) first.

#### 3: Consume [Wallet Actions](/docs/actions/wallet/introduction)

Now you can use that address within Wallet Actions that require a signature from the user:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"28b4fe8620958c55a89a2934305c1c90befc7f72d7bfefa88565c1b97ad2bdf8","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvEaRjMaAdTasYaAMIcYYNAB40pZmDhYIpNLzo0wUOLwAqBoybMVp+ZuymWtN3mveevAA+vMKw/J4wULwAvKHWMBFgUa7MIiIQwmgA8qQAglBQsnC23ta2eemZ2sG8BUXwtiFhiZHRcS1JKbykWCIAyiL4MAC2zBb0PrYASn2Dw2O1nW2x8eFtAHyMWMwGI6pkcIi8Sqwq6praapIRAOZ6jsamaK5DHmCpVVm59cVwrr0BkNRswNtxjqdzhp2FpdPpDE8XG53q4AAq7OAwSoZLI6NI47Q/Qp/DYAubAsYbAA6YHYI2c5hkckUylU0NhlBAUAgIgQiBAalk8ngvHGkNUfku5gA7uw0PhRbxbuwSFJkA4EQyALqMfBoNBYI4AeiNRBhIwAdHB8EbubyjSIpXAjZ59BA+BkwHdBLJovxTIrkP53jq9QbjabzVabXbnY6Ydo4wEjNwLTSaQBaXgAER5R14YcNiBNZtG0dteYdTqN0tZaHTYDyJzrkoT5nYtkMvFdZH4aRgvDQEG72jIaRlcoVyAAovKyDBBCM6l9tIweKH9UWTaphrJFxbTLcjVojbdWBASrsMEaAMT46poPiGaJYUjEdiwWxz0UAI3YHEwQdh1kfQYRIUUVzQf4JhgERBBoQdHnHCQjFcOB2FuKR9kvW54FcVQRAtQd8DfQRbincVzEqcRJDgDdw2LSMy2tCt7WQ2iazrF1tDfKBBDEFDUwbOxhmbM4JXZGo4EELAGVsdDMM8W5eGIMhEEzXhkAAKX6bIADkM2mVE1GXAkoPorcmMtFjYyrNtnVrcS0BvAArOBJAzQEM3vLIeF4RgYAtW4iIAITfaVMVIXhp0mIwULE85oMo64wGSMR8LQEQhLALNkAAGR5NhTIfOjdU3CNS2smNK3jWEHLrG9zxENhvMguAM1fFVhQzABrGAMAzEZkhGSR2BEDMCL4AKgqIzqiGFXg+uvIbRlGkReEcxLU05NBmFuPlkGQEAdj2TlPTuXgs2AAABDgwB6hK2SlFK7gAXxALUKCOkCfSMTkm0o1tYSIm67oe5KpXez6jroZh6RUTkTV4HT9MM4ziqyGk6QZXhgGkIUWScySXmkQQ4CHJdXoEN8lwAckq2msfpZ5cd4MZPGScwqf4GneHp80HWTOBGbAGlPXJ6QpVWJlhQhttGGAGleGRTxjnZ1LVAoJXEM1Z5jjg8mIBGRhZWsCBpQtHd50XbgtbAV7uA+r6QFh+HcCoJGCua1gMe0JmcbxmXCahKVXjJineG53n+dGEXsZZvG5uFABpfq7AgbEH0j6mjb5yqjR8xM4+ZsxWfVzns553OY5GQX3mFhtxcZKW4iDmA5dhBXtcLtBjiTmhU4wdPM6yRhaYABloQAyAlp7htbeVW2feTm7eV+EnD1gtN0YW2aQdj7PpAcndgYRAAE4qBUMBbnlJAAEYAA4qF20hcNPkA2477ROTu3BEHHqgbwDBiDIEgM+r0KDoGwH/AgqlyDP0sEwNgnA/JCFEDRKQBsKY6FfO+WAUUyi+FnLuBcIxURvjNPgrYuDKFqV4DQj8ZBXg3AwgAfmOGocORsNQbzMC9DC4I/BcJGDwxE9ZaQl0ZMInae0DpHU/DIdgWAMGckFMyEU4wsG53XmIpUKotCiikNOAAkqiDMd875nwAMzSCNlgDghhzAAANZAAEdBDwDQE40U+pSDsB/PBQKB8qDHzMEgAATBfEAV8b74CQAANmfrsN+eAtEjB/pEJAACP7uGATQcgiBIkQKgTgPAhASDwOoIg/kLAHGoOEAJSQ9CMQwGIWQAKc5SDHHJn46+rhhBynYbwKkIBpQwHYCM2oIzbhjImSAQRf5lR+wkTjE6mI2mVNjHgFKFSoKKh6UpHoMBXzwFhPIeKEB+AWE6UBXgYBFxkDGkVWZaZRY5RzHmY4hYKpRhspWeC/45QwmdGs1pnSZH7SQIdF2tA4b2PdiAeOpdE4tI2ZXaODMGygo2WPAALOE8es8aRI3xePMl5KKWUopWAYJR8X6nysQAdkvloWJ99skvxSfybF4LL6ZP/oA3J45QGICZcU6g0CylwJ2tUkAtSUEelouYcuqhjiKykMrXgP4mo9RivY0whw1Xa01ZqoU3IwCsAwLwcIzBBCsF7rjY1JrnVmskJau5cMYDHBGRsuAzVRYgAANxOudaauQ5r3U+lYN6gg5VGJW1IH6wwFoJAjODRq0NJrXUWqtcwLA7AACqpBo3DNjQxE0eb2CW06UmsAKaIAF3zWmkNmrXrppNW2p12qeQ9TsHSL1vA74ErJe2zVnp4RiHzOqzNRzmARqtVoOABbaQVLgGwaY8AICsAqUajNM7Z3ztFMSRoMbJ4wHPRe89d9cVQEZY/EQ4Sfy4sZVAM+Z9wlWNgMwH8d8rFWIAKwwGvbiy9za90zuze67tIgepqOFFAY4H7x4P3/ahh+o7Q2dvA2GudbqrUjDteIb2rArG7v3Thw9c6GglFPbQZqFifywHHv+s+jLGU/isfEqxFj4mMvHuEh+D94mPpgOE5gd9GVWNY/E+jd8wPkeVpBq10HYMEyiMca9AHOPjzvhh51WGO16cXXYVgNghlKd4Ac6+yAtRLASF0KAemPwab02AT1MaNmkPk5qtz4gSCcNILIUQGAyOZos25/YHnOnedDRZuAGARg/i3R5uwAAJGLLrw14etbBOkbB8yPz0wZzVFpSuDvHmzA1vBSsWj0xU9g/AMCpa4PgIZwZPAADVHmNea9aAAYlIZo9m2jptev7FmKqGAhPpUgO9LLr630QMy6gyTVB4Emxk5I99BW7GFQU8BkCJWlP5OU0BCD6CpKVZLNsoXlY92OMsZIjmu3yCGEM6dmaCP2qeWcIZSWt1yEG7wchqhxCNZ0AAWUIz91gIVXv4GyMolCcANh2fWE9oraPWgY6dc1YEfbIt3MXD+Mgen0hKI3XOoZfZWCYlqB92LMB3GeKGdsXb+x8n5jUCICnTOPHk3RHsA4ia+AxFR+Qo2HYYA6G57z5n5MN1oF+nYaBGxMdDfR1EMnyZbvOpU3q88shE264g1lnNOW+yEZNwp8L7nS2+v9RlhTB7stRpjd8+NNb/X1qdzbs37rK1FpLSMj3Fb83Vt3LW+tja5l6ZncVzDceStlbvvEyrshqulaT8rerPWWtteTF1vxef+tA8e1rp1CfM9ESZengcNWjOxQQ7wHQTdruwgmFYXwDPnUN8r7wAAZNFWFYhBfiDYDoGrGwtj8DAMcRgtVtAcKlJP0rYJYio8X4+DfQNtCr4tGrvenJQmnzvuPZbMTFuJJW6/Nb/It+bb/lYnbeSRXxPFZgY7sCKkyouzU5BXAHoamX8ugnChsIijwDIrgPe+utA+qRuU6Laim/uVqNqVujq2GjOuG5uEWA6PqXuhgvuWBh6bupaoex4BBdaqaQaSBmW2BAe+aQe7ucaYeVaCaUeEgMeRBkcRWemKmBOA6Q65KZOkgE6UE1uyB9BC6Rgy6+iia66m626dCPepuUhR61G+YIyZ6l6F616t696j6z6r676n6cgP6f6gGwGoGNBmBdBh6KmcGNAzeSGKGaG2ePBtBFmX2RGygpGGBzuFmVGfwtGsmjGMAzGrG7GnG3GqefGAmQmImYmEmUmjKMm4mcmNhARKBWqOqjh6mg6uKWm8SOm7hVeVexmpmcA5m2RVmtwNmWODmTmzeumTquBUWJCi4GWvm+iAWQWIgIW/hmafee6VeNW5Wde1edW3WTW+eHChe0xvW+AA2DRI2e8/Sw2T26xmuUA1C7OwuiBe6wxDsuuRx42pcn8dYxMnIWy/IeRnYj05gxMG0k4ioyoqomkoi2oZU5aVk5YtkW+zorob4iqXoGEPoUQAgAY4wQYyYFkPyzE1U9oAJdcngPAryGkuYvIXyLBvxfySJ1Ym0qgDYAMLYTxHYhiI4+SfYIgA4Q4lJY4Ygzx8omknmi4vsaAa43AcJnuHRloh4x4YAp454l4pA14d4kET41g9CFCjCX4ok36gKgEdJIEfiMA4EPc0EdAsEgSOsRg7EqElmGEWEjQe0eE1yhExEpE5EmkgM1EyO3JJYvyiJzo+p9UTk3EbofEjSYA2UNIIkA4gMTx0kskzw8kRphycC6k7y2kukBkRkJkI8iYDpuJzpdkdUnETkrk7kOUXkGpU0gUwUvAYU5skUw+Vg6ETSlESUlxkgaUJMk0ryuUXsRUiZ5k3xlklUfxNUBJDUTULUGpHUfi80NAvU/Ug0w0a0E0mU+ZM00pXUCES0RoK0I0tI60hJUE20SSkKKAR0J0cMZ0LCykV0t0ng4Mlxz0h5UMzsP0pAf0VAJJTku+aAIMJ590DxxMV5MMsKbsiMRoyMsZaMCZkEZx5ggcwB55bYYc4B6K1cmKKyCcS8HMEoUcsFAsC8RgIsYsV2W+0s4FRMUoXcGq6Fasy8ms2sOiDI+swiJsng3IFsCapCu89sjs0MMKcKCMHsf5zZPsrZIFrMFx+FkFpM0FKFdMcFSKoFc5w5MAg8w8kEMFYlAsGpxcAciFGsXMOcilowKJGFjc2FLc+M6iIBhFd2kEfcQ5KcacGckEY8k8M8c8RFOualK85FkBm8hYO8ds+8Woh8J+98qe82bKiAj8SSt+78AlIcbYj+SAz+OSu2ICBSd8/6H+kqJ20q52782wb4OAZgGAHoyYBe7w9OXaOqBuBqxugxxB2WaB9qEhdh2WbR9ulB3BWa2RpBIeOJ7B3u1B7hrVahgexazBPxlaEehw3VDala3BZRfBOqAhGmw648IhPE44Bxqhh6i6shq6Ch7kShXSlV+6gRx6NGpa2hOhQGN6d6D8D6T6L6b6H6X65hAG51IGF6LVFG2WDhamzhViyGqG/66GtBVefVh63hMOfhKhYW2RQRJ6J1dG6RYRERbGHGXGPGcRgmwmJOSRkm0msmb1kh9huRX1GmhR/62mLRth01TqFRZmxwcWoE1mtmGu2OFee6zmg6rmdu+BvJXR5y/mPofRAxEN+NDVnNIAGy3BcWCWSWweYtaWEt2RsAPOYwtOGmANIxemYxZ+ExwxJqueMx1ohVnWCxLWyxTNjRe8KxT21xeY2yyYkJUU34W+Fox+M2wVUmgVi2/6oVXKcVng0ViAuKL+e2ESKVX+p2lSNAf+cqABfkbek2uusB8Bhq+1wN1ViQtqtVKdkNahjVXNY1hBmRfuah7VZalkXVyaPVtBqd5uA1Mt5BI15dVBE1TahdieleM1Pac1g6C1S1Yhq12d61MhK6hw21W6O6WdVVNdR1mhIAp1Ohehl111Rhd1ph36v6T1Vhr1rdB12Rn16i31v1bhgN7hXh0OxG4NVd71U9GhIR8NTGLGSN0RqN/G6NiR4m2NqRuN29a1H1hN+9xNRRJRx97dVNRgJmNNLu5utR9RZtqxrNzRHNhOede4IwPNfmMAvRWg/RdVtuSDYt0W39V97q8WiWyW9ucthDwt5uiteWKtg6athmTqmtFWI0GeOtmqetixhtYAReDW+tSxZeGxLNY28FpcG202J898uK1+l+cSS23td+IA4j0S/KgdcVr++2odMC4dv+mVuCOVmAfAFFm8YBFMnxzw1tvIeA/pvA8ZupYiLtkjwV/6F+rKi2USnKijxjYSfKW2iAXt6jwdhSWjUqP+GVSCdSHowiOgPekgxwOgapHehCtgS0ly0UpiFi1i04qoaAEOeaWwiTS+FgOTrgHA5MWgdCJiqImTVi2TsIeTWAyAhTaAWoouqORAEAH4emsgI0JAeUHYVgdCCTOTneUwi0/UaTVTNTdT2gDTBTOTxwzTpTAzFTe1UzlitTOTDTTTOTrTO+HTXTTqbi/ODq6z1iG68uaAA2OgUzz6uKEOO40AKOo21CMp+CuucTLezToz5Q4zGAkzGTGzMzuT+TAUCzxTsIyz5TyQazgLWTWzeaOzsIezYuvABzz2e6PTqk/T0LQz3zyTfzAL1TQLCLWA8zsIizJTvAZTgzsLxL8L9TiLzTKL7TnTGLrVlzxwZzViFzJz1ztzjK9zjzNgh+9szCoJtwbWwi5jfCh5gipj3CblZgfFaSEKciXI8AiiSOkgqiam9xaS9jOMbxBiXYVT5iGzti8MnANQLifOni3i8goEASNAztPlEjYSwV8ST80Sbjcj1+nj4V0ivjf8ATQCQTv6ITaVYTVSUd80UUpsdFEItF5sg+g40CaTZ4EAP4bAIkHYljfIIANjAAVEW04gm+bE4iW9KRAAY1amk2KMm9KCpD+C5LBOYCYK6F+MON+OW021m624yXKJiKwPwOiWAMgBDtmHpLY4kPOKIDAMmbACQOeDlRaCNAAF7/isDMAHivysTOgKAwA/hGh5CojGJGgKCNs1iNuOzuun6MoBOyMJIKPvy9v+2htCoJURLjyRvf5nYxt6PZVkCGMnCNujUoPvZOqfPDNJNN4pMTNXLcvAtzNgsUsQvaBQu0tctwubOMuNPMttNotsvdOrR9MrMwvxP4tweEuIc4fIegvNOUuQvUvkeVN0ektIvaAstEeHOYt2vkzYf0s8v8dXNgA3MZN3MPPyhPOitUywNW13v3wPzhIe1yPesBt4AMWLjvtB1fuFKMq/s6PhP35XbQ3HVOKTwAAkwAtRr0TijjHrBKajT78jN+PtZnCAwbSA3rYbenBnh2n+2j6VAHl2RgzcN2+192awzN7Lmq2bmUrWdVoNxGf2EAAOXYIQIO+ofDkOZ9ygcOCXiOGCKOltLNHapXsXyseOwwXd9yiWpOuOPOWAlOUA1O+WA4IQQtRylzrOe5HOydsuzXIngunqnOhHEuIwUuMuTXvLniiuyuqu6u0X5te6xFE9ORPaZVCBdV1d7qNVDqXXP9OBotDuBdvVA9rug1ZBnVlBPulDO9/VjBV3HVw14ejd0ek193jDFN7hmtaerD9eWetBnDsxfg8xxe/Dpty3cD33JqYxteAPkxVNTe8TbeOFBLXX7DysVMQ+MU44Y+nArA++0+jAs+8+W+y+bYxPhHW+hHxMxPo2Dnp84S4Sd8qnz7bnijD+XniAPnn7+SESuKhnwXkdgHNbwHeVSoqgvwjQ8A8+43NMU3AA4tL9PfAPN7eSrjgBsPm3gBr0YIqDSypFcj3OoX8CKObE9lqlaj2y2AGE7Q2FmJifmOQZ2XiS6d6W6ecKeKrxofABpCjHGejFJ4QDYMcMgE4juAAPoalOLJlad8l7snhLswAruHD7sx7OhuQeSAi3jR95lqtQrfSqC/SecgA4vmD1vyUecW/ShW8/g2+iTrkqRRRO24yvkPQq9oAy8lDq8l+a/QKflsU/lUASX8V4WRXMcGuiV5zmgqUIWTYKWz/aXoUNxvJo8GURVPTywfZreTaryGubxpI0Vmz0WdKMVeUOVt4amrDMC1hyjt7aBBS+/m9wA7y0p+WFICbs/BUqec/vxvwe+mIMvr/G866cBeoqO+ML2jai9QuEsdwNaGOAWdaA1nWzvZ0U6FJ/02SFzmow04nYWs/tM/OALfzQD/2sAkzmF0f4HcnUUXcvJVy1Tw5IOthZLsoFS7pcgcWXMHBgFy7fZiMBXIYEV2Ryo55OZXVtBVzJxpAau/aY4HVxJykAycM3cNG11pwdd1uxzFnPPj677EOEigy5iN364i4d8E3KboN1m4K5++YALXjAFFblcRB9Atbl10TqG5k6h3IhqgXTroFXBk9d1LnXwaR5HcX3C7ubhLrkF3uldWwkdwYKFpnupdCMA3Vu6cFPu53bHqUV+4p5/uVWLHs6hB4G05i7wXhiXgEbiCQGhxMrAj0yFA890hCVHvpTbA/Nu8tBLITj2Hz48T4hPYnjPjnz+QKeT5anjvlp4756eU+RnhgPCRcYf+/rVbOFSlCEDskvnCAZYlIER1ZUWVcXrlT4CYhrAoifUvEx7yBEzKvAZAagPpq3A7OJHNQkOFozMB/06QKxCIHHhSYz4uKbMCFH/Q/hx4r6PIIBmnBQBswZ+NQN+mYAhRkMv6XjA/DyBqAMsFmeaKwA8THBFkroUbFsRi5bBkk+YfoD4G2Hel9B+xGJiVU25wFnBFVLrhZn247c3BHqPBqdwDTJDIGkaGIaEISEQA8adI3NE9zro4l4h/gius3VjzAN1a+ImDF3SEIjpccohPJP3W8HSEl0w9eQqwA3Q7Vx6Xg1kWbxhpaFaAZ1K9BdQMI3VjC91MwuvUsK4oXq56FkRZj3rwZEMP1Vwv9VSGeFsiLAs4BfQiEUiPOt9BjPfUiLI0YivGF+gkUxrv0UiaRCxGaN3p/1LRBRQBuTXjy8EmGKeXFNrUqG61jauQsHvkJTFFC7BSI6HpsRzHdA9hUNA4UcJs4nCzhRzbIpcNhrXDbh9wx4c8NeHvDPh3w34f8MBHAiH4oIxlOCMhHb1oRbAOEVqgwiIi946+VFsYMxA6AMRWwpCN6X15WCdeVAG4gKD1ZoQjS0EZ8JZjGbjBkgTbHRPqVuTfhOY0oUwD1DHZO9PkW8H4m71TKukMy3vTYVACxEYINIePN2C7xxLHwYM2qOUOuwtAZBa4yoeUIIGPZjIiAtcfOPoHPRLl3gx4b8vCmdB7jPeUfB8UpAzCITiuAfACnYxD5PMoyysLMIH0Arsl8wEfaPg+KfEoQ4+7ZCMAn13ZHhk+iTNPomgz6Vos+2ZTyH0Dz7yhkJPgdCYJG1hZhuKxE8PpH24kPjpgd/CiZIComMjeSdEgUraEYlrDnQtkViUaGz45lOJN4MiT4AMDSg+JkgW9itm3LQo+unINEZdHb5gxeAU4x8TOIwQ4jOcQ/G8neULaiR1Q9klCMmWvEZ9M2Ipa8PkhGBwAbwBkn0gWBawvlrJtkqSWADnGD8nYX5digijH5gUjKEFKfsIiX41x5+yKZyshU0rL9a4q/TCqIFqEd5W4E/bfp3F35OV9+rlXWGYCorgET+dFcDhfz3hX8rsCAhUHEDv4eBwuwMciZ5MkAmUIIZkY4BPFoB5Bx4agfgIyjPiCZU82YXFD+DPirShM8SH8KTR+rThpwzAaRuJgfhWJlO/AcJP+jvgwBaYB/SsZNL4xvp5pfGEQOdI7HhIoAIgKxMwB0zjwRAL6HTFtPHjhEoAEmN6fNJEAPwrp2sGEQOLPxUpYZ1KS/glOH7wpfy7JXgKlk6bkwlIfFVKbLHSkYdLxWALKeJUkSsx+4MlKyq2SJlKU2oOUySovxn41wdKa/LCpQJwoVS0pglaqd3AOFkzZK1lMyLZWnizwD+e/Uii8Hqm8IHUHlJig7BZnwCWst/e/gNKf5DSEQ+pUaTdMnh3TWMrGb6c9KHRvSPpX0n6VAD+lYDAZwMn6WfDBkQyNUUMwQnDMdnjwPgHUj/q7XCR8Yf+SVF9ngFVl6lvSsw4gQUjGFLDdGTAfRhLyfBFirOJY3pKcO8RD5GAxYtAbUEpkhB7kZwIyZ/24zYDfWs2H2fyB7iEC2egTPTuElDnGcP4pnaekgJjloCmeMVSxD/2Wx4CQAHnYuUHP8oVyQuNSCOesKAhXCbh702sW+nrFvCPhZ8L4a0hbEzS2xIIzjF2IhEjIG5oqH6j/z/6tyhwhAv/vMJFTlyAuqVP9ssKjqrDa2fAe2fCKHHfwMBx0v/i5wCatz7ZhA2KrvODndzyB0dSJs0kTRgpdwHSXcN0hOHrFBkMaWZJMhCDTIwF8yS+UsnERj8eUu4XXrcUkC7J7itRI5Cck2G7QMExva5LuFuR1dHk3sDaOMjPEfIsSBM+ElVAz4AoAIwKI0AgrIGyIi+SMjioihJkoof5aKBmXBRpCMLSAeKAlESkFJ/lSUTsuGTSjdZ0onGx0qJC5yIH/88A/C5+Z3PPivRD4GQWAHgBSmGVcZnM/GWklcD8KqZscbGXlI0pVwtKRUoWCVI351D2ZeiyfquBqnvASKSFcWRqm8YOpj+vbNqYuAACEDlWWevyuzIAPOtmXqUrKoHP9u+avN/g5TlnmBupis/qdEr9lrpvSCsXgEjGQD+LNFA4f0AbGCrjwtQ3M8aaqJKDXSIAE0yeNWOHkPDR5Lw8eU2Onl/DZ52bdsZ2O7G2yc8/YgdPwtsoWgyUd8YRfvCoAc5mASAUAGUArI0p+QUEEAK9FehAA=="}
import 'viem/window'
// ---cut---
import { createWalletClient, custom, parseEther } from 'viem'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: custom(window.ethereum!)
})

const [address] = await client.getAddresses()

const hash = await client.sendTransaction({ // [!code focus:10]
  account: address,
  to: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC',
  value: parseEther('0.001')
})
```

#### Optional: Hoist the Account

If you do not wish to pass an account around to every Action that requires an `account`, you can also hoist the account into the Wallet Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"f95b6644ba96f97af47918e35f79cf0422baaefbca02d376a6058cbfcbaebc3c","data":"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="}
import 'viem/window'
// ---cut---
import { createWalletClient, http, parseEther } from 'viem'
import { mainnet } from 'viem/chains'

const [account] = await window.ethereum!.request({ method: 'eth_requestAccounts' })

const client = createWalletClient({ // [!code focus:99]
  account, // [!code ++]
  chain: mainnet,
  transport: http()
})

const hash = await client.sendTransaction({
  account, // [!code --]
  to: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC',
  value: parseEther('0.001')
})
```

## Local Accounts (Private Key, Mnemonic, etc)

A Local Account performs signing of transactions & messages with a private key **before** executing a method over JSON-RPC.

There are three types of Local Accounts in viem:

* [Private Key Account](/docs/accounts/local/privateKeyToAccount)
* [Mnemonic Account](/docs/accounts/local/mnemonicToAccount)
* [Hierarchical Deterministic (HD) Account](/docs/accounts/local/hdKeyToAccount)

Below are the steps to integrate a **Private Key Account**, but the same steps can be applied to **Mnemonic & HD Accounts**.

#### 1: Initialize a Wallet Client

Before we set up our Account and start consuming Wallet Actions, we will need to set up our Wallet Client with the [`http` Transport](/docs/clients/transports/http):

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"db98ce1529c0c220e2c1aef80ee9e0e5fedad2c0a4b38d94dde8879e6bb8c5cd","data":"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="}
import { createWalletClient, http } from 'viem'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: http()
})
```

#### 2: Set up your Local Account

Next, we will instantiate a Private Key Account using `privateKeyToAccount`:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"a9b6841f3e5d17276d9c2e9cd840a5635a564a7114abd87914aea2521440bdd0","data":"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"}
import { createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts' // [!code focus]
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: http()
})

const account = privateKeyToAccount('0x...') // [!code focus:1]
```

#### 3: Consume [Wallet Actions](/docs/actions/wallet/introduction)

Now you can use that Account within Wallet Actions that need a signature from the user:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2146cbb5c2bdb198dbdfbdc343d33b64c777b807fff21b85fe03f9cb2984a5c2","data":"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"}
import { createWalletClient, http, parseEther } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  chain: mainnet,
  transport: http()
})

const account = privateKeyToAccount('0x...')

const hash = await client.sendTransaction({ // [!code focus:5]
  account,
  to: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC',
  value: parseEther('0.001')
})
```

#### Optional: Hoist the Account

If you do not wish to pass an account around to every Action that requires an `account`, you can also hoist the account into the Wallet Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8cf880a72b8cf5d4c694803cf14c2f1dd1d64c0dc3b41064e2506dfad65465cd","data":"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"}
import { createWalletClient, http, parseEther } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { mainnet } from 'viem/chains'

const account = privateKeyToAccount('0x...')

const client = createWalletClient({ // [!code focus:99]
  account, // [!code ++]
  chain: mainnet,
  transport: http()
})

const hash = await client.sendTransaction({
  account, // [!code --]
  to: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC',
  value: parseEther('0.001')
})
```

#### Optional: Extend with Public Actions

When using a Local Account, you may be finding yourself using a [Public Client](/docs/clients/public) instantiated with the same parameters (`transport`, `chain`, etc) as your Wallet Client.

In this case, you can extend your Wallet Client with [Public Actions](/docs/actions/public/introduction) to avoid having to handle multiple Clients.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"b87547a2fb8f0e8c1a0ca288cdbbbfb36cdc830c974e93894e97394cab6f58ea","data":"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"}
// @noErrors
import { createWalletClient, http, publicActions } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { mainnet } from 'viem/chains'

const account = privateKeyToAccount('0x...')

const client = createWalletClient({ // [!code focus]
  account,
  chain: mainnet,
  transport: http()
}).extend(publicActions) // [!code ++] // [!code focus]

const { request } = await client.simulateContract({ ... }) // Public Action // [!code focus]
const hash = await client.writeContract(request) // Wallet Action // [!code focus]
```

## Parameters

### account (optional)

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

The Account to use for the Wallet Client. This will be used for Actions that require an `account` as an argument.

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

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"c8c277f1f98862deb22eccbc73b26276a04159bd1c832ea5fe38971fd9741b81","data":"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"}
import 'viem/window'
// ---cut---
import { createWalletClient, custom, parseEther } from 'viem'
import { mainnet } from 'viem/chains'

const client = createWalletClient({
  account: '0x...', // [!code focus]
  chain: mainnet,
  transport: custom(window.ethereum!)
})

const hash = await client.sendTransaction({
  to: '0xa5cc3c03994DB5b0d9A5eEdD10CabaB0813678AC',
  value: parseEther('0.001')
})
```

### chain (optional)

* **Type:** [Chain](/docs/glossary/types#chain)

The [Chain](/docs/chains/introduction) of the Wallet Client.

Used in the [`sendTransaction`](/docs/actions/wallet/sendTransaction) & [`writeContract`](/docs/contract/writeContract) Actions to assert that the chain matches the wallet's active chain.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"af3c39eb9a37abf1afd13ff2b95f90bbd33fb77f6398d70dfe16c7cd1c602871","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const client = createWalletClient({
  chain: mainnet, // [!code focus]
  transport: custom(window.ethereum!)
})
```

### cacheTime (optional)

* **Type:** `number`
* **Default:** `client.pollingInterval`

Time (in ms) that cached data will remain in memory.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"a0d4ad6120d760338604ca36fee45dce5d92e8e815bc888b992b3826fefb3ec2","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const client = createWalletClient({
  cacheTime: 10_000, // [!code focus]
  chain: mainnet,
  transport: custom(window.ethereum!)
})
```

### ccipRead (optional)

* **Type:** `(parameters: CcipRequestParameters) => Promise<CcipRequestReturnType> | false`
* **Default:** `true`

[CCIP Read](https://eips.ethereum.org/EIPS/eip-3668) configuration.

CCIP Read is enabled by default, but if set to `false`, the client will not support offchain CCIP lookups.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"52ea0fa257a78a951b439ef395de997e411c885efd6d46426fea85ab9d515ffb","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInbAAOmHYT2AQ0bMArgKELYAMx5gYUANxjJ7AEZS0jfAH4ho8XskBbOVzQ9GUrl3MGIELjCniAPuwACqQwaI4qGAA8ALL2js6uAEJGJgDyWI4scAB87AHKMGoa2rqSAL557AVFmjpWEs4mMAAqPDYwQmByNvpkdXqyPFgASj5Q7ioucDCVltaSIQCOcvBo7gAUWFKkUu00pHBCAMKMQ6PLq4Hbu6FkcACU7AC8ucEQNjzTkSdnMBdsozQclIYGa2Bg2X65Uq1XUtVKDXwUnUSjAqjhJXq7CgRikAGU5Co1LR3AARXEEok8WgwtGFDFQiR0HCkNr8NAuAD6+i4EEYAGtmlIAObuRK8gVC4W09HFRnsAB0SvYAGYAKzsGwQEKKpXyug0NFCSLMVgcbh8ATsA38KBwYQI6xKhXyioAMnYAFFaDI0FdSI4XJFndlsusVGAhOsLezjrx2cGldlHi9OPGBCnckd02hEwrIWIypQQGxtgxEAA2KjeMDCtD4JBV6jbYWhJg54u8DRIAAMVBM10Y+0bZQo6HBeEIJHIVBo9Dw6xcPCkD04ISMMAA6i5vGhs5bc0c5Gx3s0dqwsNq0BQqnSalAb7Dio+7xiw1sdns7hZHTJ5AJ3AAAx7WgABJgDYVlazKQDKgAQVkCAFA4fJXzlR1GnwFo2XcLoejIGV6WKQj73lQYRjGdw5nmdglhWNgNg/G59kOdgfgo/4/WuL8DkzIJSHeT4YG+U4OPotBAWBUFwQLLEKgCSYuGmEiMRU9CsWddgK01bUZmdeU0HPOBLwDY5jzQU8jJMtA6jKe4fw0vVCzENprLXHwaG3VxQn3dliygPkEEQEAjnXGh7SkdgvN3Nic3YAB3Hh62kdhhR4EhxGQM9fGMq8AF11nwMIsEOAB6UqiD4GwFTgfBSoCxg4FKmMBCa9RDIgR5TTUYVgU0dgVG1FLkCOJF1AKoq0BKxBysqmBqtq+rAuanMmoHdQHgVMQxAAWnYUlAqESbptmqqarqhq1tW0r4p3UJtrAOCorujhfKtT5pHEdqyEmRgZgs9hvp2IcEqS/B2GQT16zIGBunYBD/zQdYHgm4qytK0IsJCboFW1YUMbAUrhV5OA4G2DBSoAYj/JCM0+qB2CwATKtge1oekfQeF4TB2ABkJDL4EhpEQ5C4BvOgYEYOQaF5ozfR4LIbzgHhhXEdpSZFeBxeMBVefwAS5GFcHkGi0J4aHBXWFRqb0bmhaLuW+Wshul7SvagSoDkC2WHuLawDEZosOe7zXriuA5Cwaz7WV1X1GlYgyEQXaIYAKTxVIADkduGQIjnNxG4Gtk6KrOxbLpWg8mtukPKYAKzgFgdtILBGB2mnRcedYYAVYVdcSAT4umUgvXofhlZYYPdzFyefJYDQh21xhfeT5AABk+RcfPabQQvCrRmaS/m86lsaiv2Srl7KYlFw25F1qdqZ9KNx2/kYAwHabA0LUwCcHbQiX9gXce660fkQDc7BX4U0/vNFgTgEovU2sWDkwogrIGQCAJiNhizdRVuwPawAAACXZ+Qzz3DmI4LAepFjyhQdB/MpIICoE9U2ocDy60IcQ0hb00DUNoSAOguwsDeGLOVdgadM7Z1zlvZCLkbBuWAO5DcLDuE3ilieGw7AKgqAEhogA5HbXRsj5GamRGADQHAtE6PYPoqqzUxqsEMf7MApo2BpgPM8RRnkXrcPWNRdakYTHqHMRQUohkcrWSEGoiyNh1iJTRBAeKCpMYw26PcEJYA7IgBoeggRcjhFUFEevBI0iBBGKvMITxW5vE5lUeZd4miBpWJsfNRxrlykKNARuAA0m/ZoEAEbbwado+pzSbClXbq1Vpcj2mBLMWbSxIy7Z2NMXARxYgXHmjik8Spyicy+NKBMwQjNWRgJoD0jAfSBnIXWLokCgAyAl0fcUo/ihA2FMcE0JVkrxHWKusNJhZ7hZJoSWDkAYkAAEY1TVn4HWBsiBwUAA5ZwtjbMFRgYUqkh24Z2OEvZ+xImBsOeFapRzjhwJOBOM5qAGgXEzCALJMBdVEqMKQ4whCKWUgEaiEg6KrEYtxW4BxjjMr+OJf0zE7h8TeB8L47FzjiUkiCMEOBZLyVvLKTQ/lAp4BGkcAAkoEdgLKoBF3RjAIYcAknQ2xtVPGpVPQGrxBjIYO0VQVgrAirqlCVbAiMJbP2eqVDsEAhymAgEbzsxahwRKrh2CQA4OHSO5SIBEn8WxfVhreQQH5BHS1xZSxgsQCqJFIAaywqQCW0FrZywgHIsanF3Z4X4sHESgATKS6gE5gpTjIEgmlwVNgCQZRgR4YSLzfLYnUmw2Vx1gqoJdPAgcZg5zzmO3Kc6QVliQAAdgACzQtrPWJAABOZFpBq14DXdZBtuBECtubYS3td6O2YHJd2ylfb5wDqXCuLqU7IjcvYCwY0MAMocBtGie0kCU1egNeC8Fx6VSejA9EKQWAwygdjNaMDN5eBsH4InWDgR4OIeQ+yVDWBkCYYEHlPiRAIA8ExHoEIWoSCr0+IaQjkRqPgdHpBiBb8YMOuIwhpDKG0MYbA0IHjuGOMEdIEIYTJGxPkbQ1RsDtHni5Ho4x+UvK2CKbg6J+VqwABiYBIhKd3Xu6ImNoA5Fsu+ZmjHCOAeA+wbjYHrR8btAJjAQmjOkfE+hruUnsPslk/hjQCmiPKbIwICj6n2SadTDppjCwYFsbk9FkDXmIO+eg0GpTon4toAo5JrDMn2B4c4zF4rQXVOUZ4yl7TDH0s8tFasQzInEMmbYOZyzcHrO7ts/WezqrVHetFGZdRM7117im/ZSds2vkBjKQGTgU6kEilQeg1m6KhiZDAMWUKHl4ApSifUq95S0oZU+kRnaynODvCEcuK0gF9NoFgkYAW+hpbdyBVQAt5YEVQtLTCo9lYz0XrRVt6suK70Pt9E+8FKoX1doIB+2c/aQBgOHnEgK8UhCbnUIT9gHpX0wBg8TCAhguCB0+Fqxqi6g4ACpWeAQJwkwC7Pjn0rIDzGDkUSfxPikB/QtdJYcEvO1NmEA9YzC52L2nkuQZJWmFwFQfsxDIGiKSDORrCgw2cTAU1B9YAkF5CyBUWoABeXMuBSFxuek+TVNwwH0KVOCgQ9WlRF4Tm6pOEmAqB6C8sx773g8PXCpsVbUUgCVzepAkeByPvIHens6O32Y+nJ+mtg7+cBhHVFIPiTkk2qoo6dznn2TecNAVwTRXAsqYSxJ0LlWcPVey4R+rLeytqea3RtrenMswHY1FrjPG6+2ig432LJXgsVcUOFgQkXavdbi8FpLNGh+6cdJ9jfxnOv9Ys1Zmzdm7SqrUpq0PW7EDHtPVH8tiBK0opreX2GWD4eNpTwS5H6fW1t0yhgVmBYAmAshNl3Ftl0UztdkDx9krA60xh2UpgYAbxRFkAABCUAmYQaNRPKT5cJCdS7GJJXK1LGT/TAp5DJEPEAPYKQJAUACDceY7YKHeEAMoMoIAA"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  ccipRead: false, // [!code focus]
  transport: custom(window.ethereum!)
})
```

### ccipRead.request (optional)

* **Type:** `(parameters: CcipRequestParameters) => Promise<CcipRequestReturnType>`

A function that will be called to make the [offchain CCIP lookup request](https://eips.ethereum.org/EIPS/eip-3668#client-lookup-protocol).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"31b722eaa5a83a9c8e2b1ceb112986deb093573a000066ee6c38cdc98b1892a3","data":"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"}
// @noErrors
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  ccipRead: { // [!code focus]
    async request({ data, sender, urls }) { // [!code focus]
      // ... // [!code focus]
    } // [!code focus]
  }, // [!code focus]
  transport: custom(window.ethereum!)
})
```

### key (optional)

* **Type:** `string`
* **Default:** `"wallet"`

A key for the Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"3d680b084311beb33a9008373dae1ad09e3c8d5dfba1a171a35752ee41c13a6b","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  key: 'foo', // [!code focus]
  transport: custom(window.ethereum!)
})
```

### name (optional)

* **Type:** `string`
* **Default:** `"Wallet Client"`

A name for the Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"c850912849080383c39af57c7f4205fb4cf4f29db38dfe6a070ef98c79f1fc86","data":"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="}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  name: 'Foo Wallet Client', // [!code focus]
  transport: custom(window.ethereum!)
})
```

### pollingInterval (optional)

* **Type:** `number`
* **Default:** `4_000`

Frequency (in ms) for polling enabled Actions.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"a6ce21b7e5ee7ce5249e7734350d828cb99a890a439d26b81153fd47c59617ae","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  pollingInterval: 10_000, // [!code focus]
  transport: custom(window.ethereum!)
})
```

### rpcSchema (optional)

* **Type:** `RpcSchema`
* **Default:** `WalletRpcSchema`

Typed JSON-RPC schema for the client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"828478686a72956f8fbbcc2980c834a9637540744c39d42768c83c1f0147d89f","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// @noErrors
// ---cut---
import { rpcSchema } from 'viem'

type CustomRpcSchema = [{ // [!code focus]
  Method: 'eth_wagmi', // [!code focus]
  Parameters: [string] // [!code focus]
  ReturnType: string // [!code focus]
}] // [!code focus]

const client = createWalletClient({
  rpcSchema: rpcSchema<CustomRpcSchema>(), // [!code focus]
  transport: custom(window.ethereum!)
})

const result = await client.request({ // [!code focus]
  method: 'eth_wa // [!code focus] 
//               ^|
  params: ['hello'], // [!code focus]
}) // [!code focus]
```

### dataSuffix (optional)

* **Type:** `Hex | { value: Hex; required?: boolean }`

Data to append to the end of transaction calldata. Useful for adding [transaction attribution](https://oxlib.sh/ercs/erc8021/Attribution).

When a simple hex string is provided, the suffix is appended on a best-effort basis. When using the object form with `required: true`, transactions will fail if the suffix cannot be appended.

Applies to `sendTransaction`, `sendTransactionSync`, `sendCalls`, `simulateContract`, and `estimateContractGas` actions.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"83c116e988c7e651d0f2f5abc1eabe8cae1a5920c57b1b84b4860ef8e0130182","data":"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"}
import 'viem/window'
import { createWalletClient, custom } from 'viem'
// ---cut---
const client = createWalletClient({
  dataSuffix: '0xdeadbeef', // [!code focus]
  transport: custom(window.ethereum!)
})
```
