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

# `accessKey.authorize`

Authorizes an access key by signing a key authorization and sending a transaction.

## Usage

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"088aab431fcd317c53d172388d4674b8011cc4f206415e7d84422f1aeb0e9dfb","data":"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="}
import { Account, Expiry, P256 } from 'viem/tempo'
import { client } from './viem.config'

// 1. Define root account
const account = Account.fromSecp256k1('0x...')

// 2. Define access key attached to the root account
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

// 3. Authorize the access key
const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
})

console.log('Transaction hash:', receipt.transactionHash)
// @log: Transaction hash: 0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef
```

```ts twoslash [viem.config.ts] filename="viem.config.ts"
// @twoslash-cache: {"v":2,"hash":"f5ce74de204b861af6e50e55d4661b69b789937a75a119d1940bc87040694010","data":"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"}
// [!include ~/snippets/tempo/viem.config.ts:setup]
```

:::

:::tip
By deferring a key authorization to a later transaction, you can bundle it with another operation,
which enables an end-user to not pay for the authorization upfront.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"b8f62558d49d10132e78e8ce30b301b3121985ea18530d9acb47a1bf84b0da6d","data":"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"}
import { Account, Expiry, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

// [!code focus:start]
// 1. Sign the key authorization (offline, no transaction sent)
const keyAuthorization = await client.accessKey.signAuthorization({
  accessKey,
})

// 2. Attach keyAuthorization to any write action (can be sent with the access key)
const { receipt } = await client.token.transferSync({
  account: accessKey,
  token: '0x20c0000000000000000000000000000000000001',
  to: '0xcafebabecafebabecafebabecafebabecafebabe',
  amount: 100n,
  keyAuthorization, // [!code hl]
})
// [!code focus:end]
```

:::

### With Expiry and Spending Limits

You can set an expiry and per-token spending limits when authorizing an access key:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"bacb3ed9d5f8681dd7926c149b23697eb6bd38c3f4e6346383a50afc7419202d","data":"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"}
import { Account, Expiry, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
  expiry: Expiry.hours(1), // [!code focus]
  limits: [ // [!code focus]
    { // [!code focus]
      token: '0x20c0000000000000000000000000000000000001', // [!code focus]
      limit: 1000000n, // [!code focus]
    }, // [!code focus]
  ], // [!code focus]
})
```

### With Periodic Spending Limits

Use the `period` field on limits to set a recurring spending cap that resets after the given number of seconds:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"ca05af1e4d36725deb4ea1aba431c8552fce3ff2209d787fa808310863f0381b","data":"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="}
import { parseUnits } from 'viem'
import { Account, Period, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
  limits: [ // [!code focus]
    { // [!code focus]
      token: '0x20c0000000000000000000000000000000000001', // [!code focus]
      limit: parseUnits('1000', 6), // [!code focus]
      period: Period.months(1), // resets every month // [!code focus]
    }, // [!code focus]
  ], // [!code focus]
})
```

### With Call Scopes

Use `scopes` to restrict which contracts and functions the access key can call:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"fbd1dec2933b1d6168766e2cc58e015d7be749d449522f1438d5ed284e9abc92","data":"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"}
import { parseUnits } from 'viem'
import { Account, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
  limits: [
    {
      token: '0x20c0000000000000000000000000000000000001',
      limit: parseUnits('10000', 6),
    },
  ],
  scopes: [ // [!code focus]
    { // [!code focus]
      address: '0x20c0000000000000000000000000000000000001', // [!code focus]
      selector: 'transfer(address,uint256)', // or "0xa9059cbb" // [!code focus]
      recipients: ['0xcafebabecafebabecafebabecafebabecafebabe'], // optional // [!code focus]
    }, // [!code focus]
  ], // [!code focus]
})
```

### With a Witness

Use `witness` to bind a 32-byte value into the authorization's signing hash. This lets you bind a single signature to an arbitrary offchain context (e.g. a server-issued challenge), or use it as a revocation handle that can be burned onchain (via [`accessKey.burnWitness`](/tempo/actions/accessKey.burnWitness)) to invalidate the authorization before it is submitted ([TIP-1053](https://tips.sh/1053)):

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"88eb6180040d659b7c597f412a2dc001d6a2990d83d9d39303f0b22a5c4049f0","data":"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"}
import { Account, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
  witness: '0x...', // [!code focus]
})
```

### Admin Keys

Set `admin: true` to authorize an unrestricted admin key. Admin keys can manage the account's other access keys and cannot carry `expiry`, `limits`, or `scopes` (they are ignored). Requires the T6 hardfork ([TIP-1049](https://tips.sh/1049)):

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"4ac8324d563e6a8c0dc793e168331bbe0dfaafa317bff1c13e9135e89effa9e8","data":"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"}
import { Account, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  accessKey,
  admin: true, // [!code focus]
})
```

Once authorized, an admin key can authorize (and manage) other keys on behalf of the account. Pass the admin key as the `account`: viem binds the authorization to the parent account and signs it with the admin key directly.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8a00d178db746db2e057ce4cd998a7d37e3de64bfe1e3efe3b5731a41cb40363","data":"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="}
import { Account, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')

// Admin key (previously authorized with `admin: true`)
const adminKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

// New key to authorize on behalf of the account
const childKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const { receipt } = await client.accessKey.authorizeSync({
  account: adminKey, // [!code focus]
  accessKey: childKey,
})
```

### Authorize Public Keys

Instead of passing an `AccessKeyAccount`, you can authorize a key by its public key or address directly:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"d22c34b9373748d9ba1bcf761c4ef3f4a10c9e0838048d35f575c7b792a73a9a","data":"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"}
import { Account, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')

// Authorize by public key // [!code focus]
const { receipt } = await client.accessKey.authorizeSync({ // [!code focus]
  accessKey: { // [!code focus]
    publicKey: '0x...', // [!code focus]
    type: 'p256', // [!code focus]
  }, // [!code focus]
}) // [!code focus]
```

You can also authorize by address:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"2036cf83c9f2be13cc41b359583189edf7e5419fb1e92bca9a14fc62771539b3","data":"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="}
import { Account } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')

// Authorize by address // [!code focus]
const { receipt } = await client.accessKey.authorizeSync({ // [!code focus]
  accessKey: { // [!code focus]
    address: '0x...', // [!code focus]
    type: 'p256', // [!code focus]
  }, // [!code focus]
}) // [!code focus]
```

### Asynchronous Usage

The example above uses a `*Sync` variant of the action, that will wait for the transaction to be included before returning.

If you are optimizing for performance, you should use the non-sync `accessKey.authorize` action and wait for inclusion manually:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"d4d1340606d7ea0e609d86893fd8c45e059bc0b328ab7276eb9a6c934173c7cf","data":"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="}
import { Actions, Account, Expiry, P256 } from 'viem/tempo'
import { client } from './viem.config'

const account = Account.fromSecp256k1('0x...')
const accessKey = Account.fromP256(P256.randomPrivateKey(), {
  access: account,
})

const hash = await client.accessKey.authorize({
  accessKey,
  expiry: Expiry.hours(1),
})
const receipt = await client.waitForTransactionReceipt({ hash })

const { args }
  = Actions.accessKey.authorize.extractEvent(receipt.logs)
```

## Return Type

```ts
type ReturnType = {
  /** The account that authorized the key. */
  account: Address
  /** The public key that was authorized. */
  publicKey: Address
  /** The signature type. */
  signatureType: number
  /** The expiry timestamp. */
  expiry: bigint
  /** Transaction receipt */
  receipt: TransactionReceipt
}
```

## Parameters

### accessKey

* **Type:** `{ accessKeyAddress: Address; keyType: string } | { address: Address; type: string } | { publicKey: Hex; type: string }`

The access key to authorize. Accepts an `AccessKeyAccount`, or an object with `{ address, type }` or `{ publicKey, type }`.

### admin (optional)

* **Type:** `boolean`

Whether to authorize the key as an admin key. Admin keys are unrestricted and can manage the account's other access keys; `expiry`, `limits`, and `scopes` are ignored. Requires the T6 hardfork ([TIP-1049](https://tips.sh/1049)).

### expiry (optional)

* **Type:** `number`

Unix timestamp when the key expires.

### limits (optional)

* **Type:** `{ token: Address; limit: bigint; period?: number }[]`

Spending limits per token. Optionally include `period` (in seconds) to make the limit periodic — it resets after each period. Use `Period.months(1)`, `Period.seconds(n)`, etc. from `ox/tempo` for convenience.

### scopes (optional)

* **Type:** `{ address: Address; selector?: Hex | string; recipients?: Address[] }[]`

Call scopes restricting which contracts/selectors this key can call. Each scope entry specifies a contract address, an optional 4-byte function selector, and optional recipient addresses (for transfer-like functions). If `scopes` is set to `[]` (empty array), the key cannot make any calls.

### witness (optional)

* **Type:** `Hex`

Optional 32-byte witness bound into the authorization's signing hash. Can be burned onchain via [`accessKey.burnWitness`](/tempo/actions/accessKey.burnWitness) to invalidate the authorization before it is submitted ([TIP-1053](https://tips.sh/1053)).

<WriteParameters />
