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

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

A Bundler Client is an interface to interact with **ERC-4337 Bundlers** and provides the ability to send and retrieve **User Operations** through **Bundler Actions**.

## Import

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"a6343fe7e109b0dbffa4dff029ace6c74c210136d48f602c96b777ae6da46d4a","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvEaRjMaAIWFRWZAMIcYYNAB40pZmDhYIpNLzo0wUOLwAqBoybMVp+ZuymWtN3mveevAA+vMow/J4wULwAvKHW4ZFQrswiIhDC5t7WtgDKALbMZgCCaRnawfGwEWBRsVWJtcnSmhXZvhrsWuYhYTV1cX1JrqRYIrki+DCFFvQ+tgBKYxNTM70J/dGDG0kAfIxYRcz5MDSkcIi8StaqpJ3dapIRAOZ6jsamaK6THmApZZlvq0vrxRuNJtNmLtuJdrip1MC3oYPi43L9/ulAS0utoRssIYVdgAdMDsfLOcwyOSKZS3e7aSggKAQEQIRAgNSyeTwXjMK60sh+YG8ADu7DQ+F5vGe7BIUmQDmRFIAuox8Gg0FgLgB6bVELr5AB0cHw2uZrO1ImBcG1nn0ED46TAL0Esmi/FMUuQ/l+qvVmp1eoNxtN5ptVpxaHDASM3ENJJJAFpeAARFkXXj+rWIXX66Yh7WpTHaRPMABGcH0qXEkkt1u1ZYF5CoaGYzzZyGQIEOBnyjKdL14yeAAAEOGAANb8m4IyOPZ3sZ4AXxAyooXdkaFdRkZxWn8NIQsjht4o/HU7hdOBK7XXboxywqkZZIpp+kXJoAAVBGWOCJ6SCWa8EuAikBA+S8AA5Hm+SQSSL6fG+VLcpes7dMBoHgVBMGFgCJblpWBhiBIYBwaS5KIcAvCFJ4tTmCB/BgRB0EGpaMZwGRJJOpW2LoXEyFfj+f4AYwwAkrwaKeJcNFgHRFDibwVZOJ8lxZow3DyWAS7cAmoiSDxjYzncwr8R+MCocZkaiQpEbdJpElKSiaCqRqWCMJBWaBlgQnsCIhpYGSf4QIaEh6gATNqACM2pgpBGkktpq5riAlZFAwiAAJxUKoYDPBKSCRVl1BFM8px4AJ5lNgBjLjrgiAAAxUD8RFnEgGVLsl6SwHgCFmEhZkWQBGGMVhLHTLhxZoKWFZVsRkiQYyJytkgoDZHAJF4FGIBLkuQA=="}
import { createBundlerClient } from 'viem/account-abstraction'
```

## Usage

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2cea18d8f9747f3b7c60ab1290c96be157880a5835278c1bb72f52b5f5a8056e","data":"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="}
import { createPublicClient, http } from 'viem'
import { createBundlerClient } from 'viem/account-abstraction' // [!code focus]
import { mainnet } from 'viem/chains' // [!code focus]

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

const bundlerClient = createBundlerClient({ // [!code focus]
  client, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc') // [!code focus]
}) // [!code focus]
```

:::info
The Bundler URL above is a public endpoint. Please do not use it in production as you will likely be rate-limited. Consider using [Pimlico's Bundler](https://www.pimlico.io), [Biconomy's Bundler](https://www.biconomy.io), or another Bundler service.
:::

## Parameters

### account (optional)

* **Type:** `SmartAccount`

The [Smart Account](/account-abstraction/accounts/smart) to use for the Bundler Client. This will be used for Actions that require an `account` as an argument.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"309e20ad33fdb8b1652e957ec2c287c3b0ee47a04ae30b9213877b10e79a37ec","data":"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"}
import { createPublicClient, http } from 'viem' 
import { createBundlerClient } from 'viem/account-abstraction'
import { mainnet } from 'viem/chains' 

const client = createPublicClient({
  chain: mainnet,
  transport: http()
})
// ---cut---
import { toCoinbaseSmartAccount } from 'viem/account-abstraction' // [!code focus]
import { privateKeyToAccount } from 'viem/accounts'

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

const account = await toCoinbaseSmartAccount({ // [!code focus]
  client, // [!code focus]
  owners: [owner], // [!code focus]
  version: '1.1', // [!code focus]
}) // [!code focus]

const bundlerClient = createBundlerClient({
  account, // [!code focus]
  client,
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

### chain (optional)

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

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

### dataSuffix (optional)

* **Type:** `Hex`

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

The bundler client will also inherit `dataSuffix` from the underlying client (e.g., wallet client) if not explicitly set.

Applies to `prepareUserOperation` and `sendUserOperation` actions.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"d941f39d9a90a759fb16345c7c48ba5553bcb3542b224153098fab49bc25834c","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAgCMBXMKAGzIBhfgEsYYNInYAhXgOFiJaADwAJNGiwAVUgENWWCKVXyYAM1FgYUCu3N7+cGAD47Zy9dvsPVm+74LP29fLxdKEDY9EyQANipBMABzNHwkAEYAZio0aKSYBkQQHj5BUhFxSQixayQABipGfGi9RhpyRFiAXwp0bFwiwhJyHLpCkAAKR1E9OABKdkZSGD0aOVLFStUNLV0DOCMTFVD/e0dnNx9Az1OTkOvggNgbqBcJrBaAWwKyOGl1hTlJSSIQsSxJdSaHT6QzGUwPLx2BxOVxPIKIq7PR6Y9G3BE2Fxzf7yMoVZSQ3Ywg5w4747zIi5ol5M7F3FlhAA6YFEn0OHCWKzWJM2ygiUAgjAQRSEy1W8HYelkwtI7DJknYAHdRKkFewkqISGB2Mg9rCTABdCb4KF/AD0tqI4k+ADo4PhbeLJbbGMC0HBbVY0KQIAtmGBwdxllB7MZdcghM0rJbrVo7Q6na73Z7/T6tjnE6w5s6uVyALTsAAiEr+7BTWDTjpgLrdttazF4aFLek4bH0bVELG9vv9JUBEVySSlyGQIA++k+ETD4PY5eAAAEagBrJUbIFbUHh0RJLogc0UGfLNCR1gRACCO8Bqt9zvY663D9JvpPZ5ndD0vMECIeT5V9FllGgAAVuE4MRGDVNA7DrdgunsYNPnYAByRtPgwrlgLhUCBTlAFPy2ZDUIgdCsKdVtGHbSQux7INWjQAcwFw7leQI4B2E+PQrGsDgUPMNDMOw70CzgDiuTDNhFl9dgAF4wMFGAoJg0Q4N9CZgC5dhFgLaQ+IEgoKD09hmLNKRayhCY5jMsAujmEswFkjhR1I5QlJU4jlXgnTzNzZQHP0yzqRMaQ6wmDC6zTLBoNg50sB5WCIGdAcHQAJltdJbVILBGAw+yuSc08z0iXIYkQTLMoSCQUjSRB0gAThyPICiYcCYBIkUqgSPx6kaZo+3aJAap6PocDwIYyHHMY8HeYMcBMDAFigVY9AAZW4cxLFoAB+aQAAM6loAASYBeysY8jvYAAfHEXjFas8ArDaLIgBUsBwPgPos/AYHYCRowgcx2AAVWcFUAHlltWNjFkcfh1tyZ0IiiKqABZ4hARIGoyBpqHa8YUa2na9uqAamqGlo2lm6qJuofppuIWbRnoBasCWshMAWMK+WkHZoX2PlaSxDEGVcZ7JTwbQAfYAAlCChAsqk+XRyrCma9I6uSVIkFaonSHycZ+bhSnamqmmRvpzLGcwKbBlZkZqHmoopjEWYFjrMXcXpc5XAmSN+EO9gruSe7HuxJcj1DoXTXCtAD3BX3mTOFFCUFqEE9Ftl04uPCuJMGytHHPRJyQacQFgOAllELBWJYCIZVUuBdTUbRtAg1WRYI1JVkWFhrDaNu0E+xUAClNuhgA5UslZV28IIASTR81yoxwp0jqWrcfq/XEExtrjY6wYoQtgZd6aWnRqazIunK5hYCYFg5I83qOGUoihV3fzdKNdgpNtq7VELQaQGFTqwD0FATgMALAYTsPaY0ABCJ+gNzASm4HAc05kzYRRLlgaKsVED2nihpRgSUUqaTShlIg2Vcr5UKs5RycwIjfFyEgUAYwJBwDYngP0IAuhdCAA=="}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
// ---cut---
const bundlerClient = createBundlerClient({
  dataSuffix: '0xdeadbeef', // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"948145ead72269ec206283cd1a414af7b0c43d8d653ab49515cb0bb1a580308a","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeAW2bswYGGkS9gAHTC9VvAEasI/ANYBRWli2kyceUpVqrJ5lCGsMvWADNmAV1ZyFyq77U27MAdeMGYxGHlFED00fFN+ZjAogG4fP18A+0c3UlZIgjQ0LDMAehLZONI4BLAAOnYIFLT0/xhbLN5mLHYAVVz8/ELixDKu9lqK+MT6iBKxpss/AF9Uxd4V5o0tXQAVdnD5AEYAJgAGc9WrQTA0UmZ+NDNvNes2wOCYYR6wdhIqtgASvAIKw/uZNi1MkFHLYoCY4E8oqdaDBUWjUYcACxQADshwAHPxjupMTioABOcnHADMsGY6kO1OpAFYYFjMeiFi1Xu1oVttDoAMI2GhQeQ00745nS/GXdIbF6tXnBMQeNDsBKsVjU8GKvxQ4Kw+GIkDIhKHQ7qWCnZnknE49TUgBs1ItTpxp2O+PxTuJMGOzEOOOpdqd5sOXO5qgNjk0AuFbVFR0xLOdp0OcuWmfW2c+cB2rCgcAA/PIY7wRKQpABzZAAXV4AB9eG4wC4pDAoNn2GLeBnNqEDrwojFKjA3GJI6pQuqSIKciYwPwMLrIW8OoOIsPorEyFOMuu+XAMGJ1CD8nodgAJfc896OWD8fZsJ4E7MKqy1L9907iCAmXgv1qbM/nYZwMCvLh8FLXhBXwSQwAANTIMCIKggAxFRm1bdsZC7ZQlmUfYsH/UQJCkGQGCoERmFIBhEHJKhWE+atYiQHEqDQWjq1kPByOkXimI7JBTiofh4LuB4yCQcklgodBsFwRACGIaTOLoeiQGuEQNBw5jSEFDhPi8AAhPSyEM9hjIAHivIYdjuYQSLo6ycJgZwOygCheFcVg4BgAA+byLCsONdAMIx/1MVd0nLFx3E8GKo3LTcL13KoalvWLD2CHI8m3QYilKcp0uqaYGiy/Ucphbo+nyqJCuGUZugmUqahmOZukqnNNg/NQwp0PYhxOc5Tmza5bnuR4koPZVHDzb5flMQFgVBMgZrXObOigOF4BNZF0XRLFcQJIkSTJSkaTpBkmVZdlORAbNNvvfldATZgk14CUpRlJ61D6qqttVTwNTYbUNuyrajT2/IzUDS1rVte1HRdN0PS9H0/QDIMQxxMN4e6u8OgG97PqxVMnXTP7VABnq1jzAsixg8tKxresmxbNt3M87te37NZUu3UcyHHSdHoHD6lvnUhF2XCHo2qkIwi3Ed0u6lmTzPeromvdXFcfZ8/KOWVeuzICfz/ACgJAlDwMguBoPkOCEOQqs7YwrDOdwztVjkr3ubw7y3I8wP/ZDzsAsoEAaLopBMSdJiWLYxBGU47jeOU9RzIMoybijjgZCQY4xIkqbpMQJ05IUnA8EIP4o5oegmDYTgeAEEUYDMtt9Msmy7KKBzEjgZy0Fcrnw68nyX0C4LNgGiLjGi55no6eK1Xl2aXsF1XKjKpJxb1TeOjygYhmKyYMvKxoD6jBWodq/oCrPkZOvGC+946+Yb/ld9swGoatwjQuJsCaklprL0hi9BaPw/hwBWnAEEYIIHJUVtDBEsMUSHQxNiPEhJiSkgpFSWkbQbosjZJiDkaJCZKheiTDuvZvrSmZCbQ+tMiZ8mBuqTU4NkHcnLGg/atBwxWhgDaO0DpnSukOO6T03pfTqH9IGYMoZwzULvrQ7YQp6HJgplTCE/1f6bAZoWEsZZFaszALWBs2Fx4802D2I42Zt47jHBOfcM4pYLk+HLXhn4vyGLWObQ4v4xBRUAv4zYoF3YOxgs7KQrtUL23wJhDmwc7FgD9mk0OWTOxB1sXhAKjAsC0WVjQKo8gu5QB7rnNAgohAeWrNZICAVuAVOzr3G4TSvwBSImIEe7dEyd3aTUqOdh+AIGUqTeAnReCVP0rBGpvAADu7BYgzOrEtFQyBB5OVInWRgjVipECsmIWoDsShjLgCUfgNSrlSFuBAPg1wGk5E7D5f8MzkBxLAPsw5L9jkwFOecy51zbnXPglIHgtRlDKAALS8AACLaCeH8soAKgX4DmPwQQrY0CwvpJWKaDQwCgqsjcK5Wdu5qWoMwasEzkDIBAMUu4Ygo7PPYNWXg8LgAAAEC46FmcMsltT6kcqWCAOsFBGUmDQDkYQUcACCgqqWkAWcK2oCg+VSAFXMiyNTxWSsZXQMIRhcBUGIqRBQAyPowAAApuE0BqDpaBvKNXWD5UgEAxC8AAOTop9b0/pwBrU0F1TnYV7rnCeu9X6k5WKcU3HxeoQlDxiUBp+H0y1wb+KUUjdG316LwUITgOm5Q2lRA3IjQAXhDXah1HB+DOsYCFAQEKwDyBzbICgaRJq7LovIRqjBuDdoydwGFS4hA6UpVUvV1ba1hqbS2ytxkR2qF7cPUiA6hiMB9aikoWB60alqN0MQDaIAdSIMcEohwSikCwPwH1w6CLcAlZK6OXFY4V2LiAZiljk6HEYjS0gPFNL8A7gukZQlC6IG/eJEpUlyAweOFXagila6qXIOpJuykimepwHRDATy22xLbRzFtqh56GEXuU3xNDV7uQSl4cjfDFbOOFpffe1Mj58hPk/IqL937tQqt/FB99eiPwas/Zqb82pX1ft1WmtN/77EAWcYBaxQFTSeMx9hHwvgwOWqwIECC1qkA3rpmEO1jQYKwdgk6eDzqEKuiQxkZD7pUJEyxradDBkMOpJKJhLCWhsLoxwtUoMtQ6lo4DF6AiMHCMRuIlGUiZEY3kYonGKiCaeZXnyHzNq+YpmZGmfmwWAlWGMUzMxW0LFWNSfkn29i+ZOOVmlVxYsWuzhgNLWWK5ou8BSq1oWascuheCMeU854ha61G+o+jT4JBGz7EFgxmwgkhLCdbSJts0IxKdm2hJ0TkmexyfhDJ9XvZQFGcivA3z3mqt3AIGptQo4x3oj6ROf78BIGZGnYDGctJtvzsJRA1IS7wbKUXFDmAa7KTrtSxumkWAcC4E8ydZEEKURmpRyKJgaM6bGw+Bj69+sWaVkOHeUxOP6Ji8fCTBR+NlEE1fNRA3UEP21nusYrVd5CdmF/Ljim/6aIAUcNTY0QFCEmg8bTNO2dbWgUtf4RnVpIIJ7TvkcXtwHVs8dXBZ0CGXWIfSVzd0KEPS42T/Ln1GG/TlyFubYWQbcKi+r7jhorMw210I+GIixHI0kWjWRmMFHY2UXjVRs33exk0VMwrujSs/1NkY4QjNTHy5erV9mNjLu80cRLCnLiRZuM8x4ucXilx9bd4Nwv7G9Y1c1lNkcM2uNxRgAtl8xtytqHW5bGA4TgLbbdrtx2sEDs7aSSknPAdGsZMDZaztVF320XouSMHP6k7fcQBxIDIG+KY8Ej+kH6+4NgPLrJeSqHYcqXrlhpHWA8NkEwHwddI95D9ywDsjdLlTveV8v5SOKgS5PAHYOIXgAEW1QUXgV/UiV7D9eiE4Q4T7ViLfQDD9PfZSGA2OKDJSTEcHM/RDZDS/GHJSG/BHDSZuFHNuRqMeS7P/aeQpPKGCWrC7GfSedlasGCD/L/EeOpMABpWgtg+gvyQKVpXgbgxyb/UeX/KeEQnpDNfpRqBuWlelRlWAaoKsLAdUIQKOKZOAGZK8HYHYW1aAyQ/pWID6AQIQGQGXaAiAGZAAKQAGUAB5AAOVhQgKgIVVtQAEkXs6w303skBGRv1f0UC44/sMCGcsBgdoM8DAcIdy5GQlg31BBYA8ALU6IrVF880vUC0404NIUfVhwkgJ1hBRBp1qk50wNBkINhVm00gij21xAD8XVeAyheBkAABCdI/vZwbQNwOAOsHtMwzdXgQdXdKTfdQ9fgY9fYM9C9K9G9O9B9MdUdKOcILiJAUADSPMYlPAR4EAJYJYIAA="}
import { createPublicClient, http } from 'viem' 
import { createBundlerClient } from 'viem/account-abstraction'

const client = createPublicClient({
  chain: mainnet,
  transport: http()
})
// ---cut---
import { mainnet } from 'viem/chains' 

const bundlerClient = createBundlerClient({
  chain: mainnet, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

### client (optional)

* **Type:** `Client`

The [Client](/docs/clients/public) (pointing to execution RPC) of the Bundler Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"68516e5120dffb97bcaf1240e8c5af9a20f5711f5a1571c8c46ecac633a5897e","data":"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"}
import { createBundlerClient } from 'viem/account-abstraction'
// ---cut---
import { createPublicClient, http } from 'viem' 
import { mainnet } from 'viem/chains'

const client = createPublicClient({ // [!code focus]
  chain: mainnet, // [!code focus]
  transport: http() // [!code focus]
}) // [!code focus]

const bundlerClient = createBundlerClient({
  client, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

### key (optional)

* **Type:** `string`
* **Default:** `"bundler"`

A key for the Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"68b909fcd0e7d4d70898371a7e7404b46d1f46cdb35b687bd8d128c5eb3f758d","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInYAhAK5goXMgGFe/NAB4AEmjRYAKqQCGrLBFKLxsAGY8wMKBXbGtXODAB8VozFPnL7F24vOJrsz6eft5QDpQgbFoGSABsVFJgAOZo+LFUaFGJMAyIINx8AuG85kgADFSM+FFajDTkiDEAvhTo2Li5hCTk6XQ5IAAUtjxacACUnKQwWjRiElKksgWKKmqaOnB6BgpeAR42do6+JrtH/u6nIRe7Dv1Y1QC22WRwQrOSMnIC0iymicqqGm0un0hmCJ2stnsTiCx3OMLOgR2cKRFgco1eRnmi3k/1WQI2IO2YLh+yhV2RxMRlI8KNCAB0wDx7psOIxJtMYG8sZ8GFQoBBGAhctJ2TQ4OwtCJMWR2NiBOwAO48FIS9iJHgkMDsZBrYEGAC6/XwAJeAHpTUQ+PcAHRwfCm/mC035eRwU1mNCkCDjZhgX6iSZQaz6VXIaRVMyG41qM0Wq22+2Ot0ugTJiOsUbWhkMgC07AAIgKXuxo1hY5aYDa7aaasxxGgc1oAEZsbS1HgsZ08t1N6XdahaRJC5DIEB3bT3cK+37sPPAAACxQA1lK5h8lt8/TxEo0QPqKKPJmgA6xwgBBVfvUiynnW9gL5eX7lLXf70d0LTMqThJks+8TKYaAABVEJteEYOU0CsUt2EaawvXudgAHIK3uJCGV/EF/zZQDOT7SDYPgiBEJQq0a0YOsBEbFtPRqNAOzAdDGWZLDgHYe4tDMcwODg4wEOQ1DnXTOAmIZX02E4Hl2AAXgAjkQLAngIJ5fpgAZdhOHTIQOK47IKHU9haL1QQSwBfpRn0sBGlGbMwHEjhezXBYpNknCOS5dd5FUgyUyggyjIJAwhFLfokNLWMsFA8DrSwJlwIga0OwtAAmU0AEZTVILBGCQiyGWsvd9wiDJokQNKAFZ4n4ZJUjKgBOdJMmyJhRTwpzIKKAIygqKo2zqJAKuaVocDwToyHCGh6DwW4vRwAwMHGJcYAwAB+IRWzMRJ2AAH3hEJwiTPALyWjBg2vFIYEkpZrXCSJSoAZgakAEhqpB7sa0gsj6E7OpKMqeuqWpxsQZKhuoNpRuIcaeim3IZogObMHGAKWSEFZAXWFkiVhQJSUcA6izwdR8EugAlIDpEM/EWVukqcgAdnKZ7qpSJAnpKr68BRkFfvaZKAb64HQZacGRo6KH+0mvpBl4EZxlLbGET2SFHH6AMuDW9gNqSHa9vBadt019HdUCtBN1+RXLghA40TRgETax2krDxhwMJYgxTLUCbB2HUdYDgNkeCweiWHCEVcPFSUlHUdQgKpzGsJSaZOBYcxanFNAIFVAApABlAB5AA5HNycps8gIASRu/UirunIAA40qqpJWcQAAWD7OY6AFeaQfm8l6ujgbS+7GiK5hYCYFgJN8mS5JmfCVLUrV2BOoQkOMCAICQqxzW1ABCCfLs3xhRDgfV/OpkFgrMsKTUQc1IsUxgYripSEqSohUoyrKcpsqzRjhEeBkJAoBej8DgAxLmCBGiNCAA"}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
// ---cut---
const client = createBundlerClient({
  key: 'foo', // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

### name (optional)

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

A name for the Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"ae67666fc0a40868f686a924fcbd7dd8c6fa99c42d1efc67c6569e5e232679f5","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInYAhAK5goXMgGFe/NAB4AEmjRYAKqQCGrLBFKLxsAGY8wMKBXbGtXODAB8VozFPnL7F24vOJrsz6eft5QDpQgbFoGSABsVFJgAOZo+LFUaFGJMAyIINx8AuG85kgADFSM+FFajDTkiDEAvhTo2Li5hCTk6XQ5IAAUtjxacACUnKQwWjRiElKksgWKKmqaOnB6BgpeAR42do6+JrtH/u6nIRe7Dv1Y1QC22WRwQrOSMnIC0iymicqqGm0un0hmCJ2stnsTiCx3OMLOgR2cKRFgco1eRnmi3k/1WQI2IO2YLh+yhV2RxMRlI8KNCAB0wDx7psOIxJtMYG8sZ8GFQoBBGAhctJ2TQ4OwtCJMWR2NiBOwAO48FIS9iJHgkMDsZBrYEGAC6/XwAJeAHpTUQ+PcAHRwfCm/mC035eRwU1mNCkCDjZhgX6iSZQaz6VXIaRVMyG41qM0Wq22+2Ot0ugTJiOsUbWhkMgC07AAIgKXuxo1hY5aYDa7aaasxxGgc1oAEZsbS1HgsZ08t1N6XdahaRJC5DIEB3bT3cK+37sPPAAACxQA1lK5h8lt8/TxEo0QPqKKPJmgA6xwgBBVfvUiynnW9gL5eX7lLXf70d0LTMqThJks+8TKYaAABVEJteEYOU0CsUt2EaawvXudgAHIK3uJCGV/EF/zZQDOT7SDYPgiBEJQq0a0YOsBEbFtPRqNAOzAdDGWZLDgHYe4tDMcwODg4wEOQ1DnXTOAmIZX02E4Hl2AAXgAjkQLAngIJ5fpgAZdhOHTIQOK47IKHU9haL1QQSwBfpRn0sBGlGbMwHEjhezXBYpNknCOS5dd5FUgyUyggyjIJAwhFLfokNLWMsFA8DrSwJlwIga0OwtAAmU0AEZTVILBGCQiyGWsvd9wiDJokQNKAFZ4n4ZJUjKgBOdJMmyJhRTwpzIKKAIygqKo2zqJAKuaVocDwToyHCGh6DwW4vRwAwMHGMBPxgAB+IRWzMRJ2AAH3hEJwiTPALyWx5g2vFIYEkpZrXCSJSoAZgakAEhqpAABZGtILI+hO3B4i6sqeuqWpxsQZKhuoNpRuIcaeim3IZogObMHGAKWSEFZAXWFkiVhQJSUcA6izwdR8EugAlIDpEM/EWVukqcgADjiZ7qpSJAnpK768DRkFOpKMGgb60HwZaSGRo6GH+0mvpBl4EZxlLXGET2SFHH6AMuDW9gNqSHa9vBadt21zHdUCtBN1+ZXLghA40QxgEzZx2krAJhwMJYgxTLUCbB2HUdYDgNkeCweiWHCEVcPFSUlHUdQgJp7GsJSaZOBYcxanFNAIFVAApABlAB5AA5HNKeps8gIASRu/UirunI6oAdiqpJ2cQD6By+5qOgBfn2mSoW6NBtL7saIrmFgJgWAk3yZLkmZ8JUtStXYX6hCQgAxCAc4869IKQqxzW1ABCSfLuMAVRDgfV/NpkFgrMsKTUQc1IsUxgYripSEqSohUoyllHKNkrKjHCI8DISBQC9H4HABiPMECNEaEAA==="}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
// ---cut---
const client = createBundlerClient({
  name: 'Foo Bundler Client', // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

### paymaster (optional)

* **Type:** `true | PaymasterClient | { getPaymasterData: typeof getPaymasterData, getPaymasterStubData: typeof getPaymasterStubData }`

Sets Paymaster configuration for the Bundler Client to be utilized on User Operations.

* If `paymaster: PaymasterClient`, it will use the provided [Paymaster Client](/account-abstraction/clients/paymaster) for User Operation sponsorship.
* If `paymaster: true`, it will be assumed that the Bundler Client also supports Paymaster RPC methods (e.g. `pm_getPaymasterData`), and use them for User Operation sponsorship.
* If [custom functions](#paymastergetpaymasterdata-optional) are provided to `paymaster`, it will use them for User Operation sponsorship.

#### Using a Paymaster Client

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"cb7ff1560aee19a572b3bb06be4d0954f42f7f8e8d1724acd7434fff4d6b74fc","data":"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"}
// @noErrors
import { createPaymasterClient, createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
import { client } from './config'
// ---cut---
const paymasterClient = createPaymasterClient({ // [!code focus]
  transport: http('https://public.pimlico.io/v2/11155111/rpc') // [!code focus]
}) // [!code focus]

const bundlerClient = createBundlerClient({
  chain: mainnet,
  paymaster: paymasterClient, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

#### Using the Bundler Client as Paymaster

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2dff245d20d1dc70afc6cd0a9dc8e86a057f28a8c667ce965fd27c8936d561ba","data":"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"}
// @noErrors
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const bundlerClient = createBundlerClient({
  chain: mainnet,
  paymaster: true, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

#### Using Custom Paymaster Functions

See the [properties below](#paymastergetpaymasterdata-optional) for more information on how to use custom Paymaster functions.

### paymaster.getPaymasterData (optional)

* **Type:** `(userOperation: UserOperation) => Promise<GetPaymasterDataReturnType>`

Retrieves paymaster-related User Operation properties to be used for sending the User Operation.

[Read more](https://github.com/ethereum/ERCs/blob/master/ERCS/erc-7677.md#pm_getpaymasterdata)

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"67f1c96a91b6ee98ec8ed77db91ef9e3c98959efc2ea284dbf0317d2f32f347b","data":"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"}
// @noErrors
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const bundlerClient = createBundlerClient({
  chain: mainnet,
  paymaster: { // [!code focus]
    async getPaymasterData(userOperation) { // [!code focus]
      // Retrieve paymaster properties for the User Operation. // [!code focus]
      return { // [!code focus]
        paymaster: '0x...', // [!code focus]
        paymasterData: '0x...', // [!code focus]
        paymasterVerificationGasLimit: 69420n, // [!code focus]
        paymasterPostOpGasLimit: 69420n, // [!code focus]
      } // [!code focus]
    } // [!code focus]
  } // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

### paymaster.getPaymasterStubData (optional)

* **Type:** `(userOperation: UserOperation) => Promise<GetPaymasterStubDataReturnType>`

Retrieves paymaster-related User Operation properties to be used for gas estimation.

[Read more](https://github.com/ethereum/ERCs/blob/master/ERCS/erc-7677.md#pm_getpaymasterstubdata)

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"61c7da1487c91e47acfe3b4edebf209d8b1fb35d98e5c90182e10ec3f845fb3f","data":"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="}
// @noErrors
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const bundlerClient = createBundlerClient({
  chain: mainnet,
  paymaster: { 
    async getPaymasterStubData(userOperation) { // [!code focus]
      // Retrieve paymaster properties for the User Operation. // [!code focus]
      return { // [!code focus]
        paymaster: '0x...', // [!code focus]
        paymasterData: '0x...', // [!code focus]
        paymasterVerificationGasLimit: 69420n, // [!code focus]
        paymasterPostOpGasLimit: 69420n, // [!code focus]
      } // [!code focus]
    } // [!code focus]
    async getPaymasterData(userOperation) { /* ... */ }
  } 
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

### paymasterContext (optional)

* **Type:** `unknown`

Paymaster specific fields.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"d307d6fd59d1b7bff8fab662eab57e4571f301b3c688ef1f3cf8b0fae5c7af3f","data":"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"}
// @noErrors
import { createPaymasterClient, createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
import { client } from './config'
// ---cut---
const paymasterClient = createPaymasterClient({
  transport: http('https://public.pimlico.io/v2/1/rpc')
})

const bundlerClient = createBundlerClient({
  chain: mainnet,
  paymaster: paymasterClient,
  paymasterContext: { // [!code focus]
    policyId: 'abc123' // [!code focus]
  }, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc'),
})
```

### pollingInterval (optional)

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

Frequency (in ms) for polling enabled Actions.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"de520073edad1e9045ed9655d3fc0932d6da4da4cbbb8495c19040e9ced2f2ac","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInYAhAK5goXMgGFe/NAB4AEmjRYAKqQCGrLBFKLxsAGY8wMKBXbGtXODAB8VozFPnL7F24vOJrsz6eft5QDpQgbFoGSABsVFJgAOZo+LFUaFGJMAyIINx8AuG85kgADFSM+FFajDTkiDEAvhTo2Li5hCTk6XQ5IAAUtjxacACUnKQwWjRiElKksgWKKmqaOnB6BgpeAR42do6+JrtH/u6nIRe7Dv1Y1QC22WRwQrOSMnIC0iymicqqGm0un0hmCJ2stnsTiCx3OMLOgR2cKRFgco1eRnmi3k/1WQI2IO2YLh+yhV2RxMRlI8KNCAB0wDx7psOIxJtMYG8sZ8GFQoBBGAhctJ2TQ4OwtCJMWR2NiBOwAO48FIS9iJHgkMDsZBrYEGAC6/XwAJeAHpTUQ+PcAHRwfCm/mC035eRwU1mNCkCDjZhgX6iSZQaz6VXIaRVMyG41qM0Wq22+2Ot0ugTJiOsUbWhkMgC07AAIgKXuxo1hY5aYDa7aaasxxGgc1oAEZsbS1HgsZ08t1N6XdahaRJC5DIEB3bT3cK+37sPPAAACxQA1lK5h8lt8/TxEo0QPqKKPJmgA6xwgBBVfvUiynnW9gL5eX7lLXf70d0LTMqThJks+8TKYaAABVEJteEYOU0CsUt2EaawvXudgAHIK3uJCGV/EF/zZQDOT7SDYPgiBEJQq0a0YOsBEbFtPRqNAOzAdDGWZLDgHYe4tDMcwODg4wEOQ1DnXTOAmIZX02E4Hl2AAXgAjkQLAngIJ5fpgAZdhOHTIQOK47IKHU9haL1QQSwBfpRn0sBGlGbMwHEjhezXBYpNknCOS5dd5FUgyUyggyjIJAwhFLfokNLWMsFA8DrSwJlwIga0OwtAAmU0AEZTVILBGCQiyGWsvd9wiDJokQNKAFZ4n4ZJUjKgBOdJMmyJhRTwpzIKKAIygqKo2zqJAKuaVocDwToyHCGh6DwW4vRwAwMHGPQuGKRIAEkBDIIhbAAfiEMBRHuJsZQAH3hEJwiTPAADFJgAR1EfhGAwdh+jMdixmDa8lpW9h+GbKQgzohjxQAMl+zU0Dga0JsHYdRxMLRRC4Xk8nTa0wIFJd1CZGB2FNdgAGZCqoSJSoJhqQASGqBsqgdSCyPpvrMNaNtILauE6koyp66panGxBkqG6g2lG4hxp6KbchmiA5swcYApZIQVkBdYWSJWFAlJRwLqLPB1HwXGACUgOkQz8RZcJSZyAAOAmqqSFIkApkqGbwBWQU59pkp5vr+cFlphZGjoxf7Sa+kGXgRnGUt1YRPZIUcfoAy4Xb2FbZn2FO2krGnbdU+V3VArQTdfljy4IQONElYBQu1eziuoQwliDFMtQYaHJARxAWA4DZHgsHolhwhFXDxUlJR1HUICzdVrCUmmTgWHMWpxTQCBVQAKQAZQAeQAORzY3TbPIDVuh/Uiqtp2ABZ7epxBb7p12OgBT2kG91Hef6sqCcaIrmFgEwFgElfIyTkjMfCKk1JanYEzJI606jsyEGlUoAB9UoGCrDmm1AAQgAbjYwApRBwH1P5c2IJgpmTCiaRA5pIqKUYDFOKSkEpJSIKlDKWUco2SsqMcIjwMhIFAL0fgcAGJuwQI0RoQA=="}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
// ---cut---
const client = createBundlerClient({
  pollingInterval: 10_000, // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})
```

### rpcSchema (optional)

* **Type:** `RpcSchema`
* **Default:** `BundlerRpcSchema`

Typed JSON-RPC schema for the client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"f3fc28aee033bb531e0ab096c93c066981fbe28710badd725cb994141485d1ed","data":"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="}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } 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 = createBundlerClient({
  rpcSchema: rpcSchema<CustomRpcSchema>(), // [!code focus]
  transport: http('https://public.pimlico.io/v2/1/rpc')
})

const result = await client.request({ // [!code focus]
  method: 'eth_wa // [!code focus] 
//               ^|

  params: ['hello'], // [!code focus]
}) // [!code focus]
```

### transport

* **Type:** `Transport`

The Transport of the Bundler Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2b1f6f3eff7a6dc77763b0289093d2047b7f1ad313c9e3be1df4cdbdf736fce8","data":"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"}
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const bundlerClient = createBundlerClient({
  chain: mainnet,
  transport: http('https://public.pimlico.io/v2/1/rpc'), // [!code focus]
})
```

### userOperation (optional)

Configuration for User Operations.

#### userOperation.estimateFeesPerGas

* **Type:** `({ account: Account, bundlerClient: Client, userOperation: UserOperationRequest }) => Promise<{ maxFeePerGas: bigint, maxPriorityFeePerGas: bigint }>`

Prepares fee properties for the User Operation request.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"ed084cfe1ff9d0f1896ff0a8f43421a5395058a35cd79d4a1395ba853e832672","data":"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="}
// @noErrors
import { createBundlerClient } from 'viem/account-abstraction'
import { http } from 'viem'
import { mainnet } from 'viem/chains'
// ---cut---
const bundlerClient = createBundlerClient({
  chain: mainnet,
  transport: http('https://public.pimlico.io/v2/1/rpc'),
  userOperation: { // [!code focus]
    async estimateFeesPerGas({ account, bundlerClient, userOperation }) { // [!code focus]
      // Estimate fees per gas for the User Operation. // [!code focus]
      return { // [!code focus]
        maxFeePerGas: /* ... */, // [!code focus]
        maxPriorityFeePerGas: /* ... */, // [!code focus]
      } // [!code focus]
    } // [!code focus]
  } // [!code focus]
})
```
