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

# Integrating USDC into Your Application

## Overview

:::info
This guide is maintained by [Circle](https://www.circle.com).
:::

This guide walks you through how to integrate **USDC** into your application using [Viem](https://viem.sh).

We'll demonstrate how to interact with the USDC token contract to enable key functionality such as reading balances, transferring funds, approving third-party spenders, monitoring transfer events, and optimizing contract reads.

You'll be using the [Public Client](/docs/clients/public) to read blockchain state and [Wallet Client](/docs/clients/wallet) to sign and send transactions.

We'll be working on the **Sepolia testnet**, but the steps apply to any USDC-supported EVM-compatible network.

By the end of this guide, you'll know how to:

* Set up Viem clients and securely manage accounts
* Read and display USDC balances
* Send USDC between wallets
* Approve contracts (e.g., Uniswap) to spend USDC on your behalf
* Monitor on-chain Transfer events in real-time
* Optimize data loading with batched readContract calls

Each step is self-contained and modular — designed to be easily copied into your own project, whether you're building a wallet, a dashboard, a DeFi tool, or anything else powered by stable digital dollars.

Let's get started.

## Steps

::::steps

### Set up Clients

In this step, we'll configure a **Public Client** for reading blockchain data, and a **Wallet Client** for signing and sending transactions with USDC. You'll also set up your account using a private key.

We'll be using the Sepolia testnet, but you can easily swap this for any EVM-compatible chain.

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

### Initialize the USDC Contract

Now we'll define the **USDC token contract** by providing its address and ABI. This allows us to interact with functions like balanceOf, transfer, and approve.

You can use any USDC address from [Circle's official registry](https://developers.circle.com/stablecoins/usdc-contract-addresses), but for this guide, we're using the Sepolia testnet version.

```ts twoslash [contract.ts]
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

### Check a Wallet's USDC Balance

Let's check the USDC balance of your account. This is useful for verifying holdings before transfers, or displaying token balances in a wallet UI.

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"fde8fb8d4720b6d53136b11648f27f92cd5bbd8f9ec20a95b3e3ac28864c4f65","data":"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"}
import { formatUnits } from 'viem'
import { publicClient, account } from './config'
import { usdcAddress, usdcAbi } from './contract'

const balance = await publicClient.readContract({
  address: usdcAddress,
  abi: usdcAbi,
  functionName: 'balanceOf',
  args: [account.address],
})

console.log(`Your USDC balance: ${formatUnits(balance, 6)} USDC`)
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

```ts twoslash [contract.ts] filename="contract.ts"
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

:::

Note: USDC uses 6 decimals — unlike ETH which uses 18. Always remember to format your values accordingly.

### Transfer USDC

Now we'll transfer USDC from your wallet to another address. This is the most common action in USDC-based apps — whether it's sending payments, tipping, or moving funds between accounts.

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"330699fefa0117940c83550aa99b05b396c1c1534ed7367c0fd93c1871df034b","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvLM1JwYAVTDs0cRkTaCYiXnDSl2YAOYVesEewC2bODrCDLAIzLcdj9kcNoAOsstYIUjRpWXklFQQqKAgRBEQQAFlBVnEsDnheZl19QyNeUhgsAvkwNGZxSV4IfkzeeycyXkcMWs8SKToAsBhSqprHLhheAEYABl5GMc7JHrRuADpfXwBaXgARGNtefDQ0LFsAegOidhhLebh8A+jYg8FxDnF4A5k5RWVVSmpmIzjkZBAdGY/lYuCoVgCQV4wBCb3Cql4AF8BKQIJZeAByE5nDFLMCvMIfNQYgAsACZRhjTABObi+I68cmjZks1lgEAAXQ5VD0sgYiGpVFBxjQ+CQYyoZVIRhg/JABPeES+HG6SFGVBE+FkzDEZCQ1MRFHQ2Fw8UIJHIkrocpYHC4fBEkj0vAA7mxQWgAMLpUo6YC+XiBzIiR3CNB+gNBqPMKBQYpbACCsfjAG5I1HA5BRDAEswwD8yAB+HQAOUkIhzeYLpF4AB9eMJYPxDDAoGmpBnA3APGAdIxXsDZWQtv6O52o1rLjoABJcfDt8dIvgAXgAfLwAAqoyzseQAHmndFXC/H3aMYAT90IBgAXuUJL2JgPLEO5DpL6LAuw7xUwAAlGAAEctD0Fd1y3NFdxgPcAGUew/a9v3vSQALQQRSDAAAVE1j3TDMzzABJ4DgAs+xhF84BImUkQjMdF14CiqO0Xg4PPZhHFBIjKILE9O0RMDN23KCDyPXj8J7TDSDzEixAfHQ93kAw2G/RprR6KA4BYshOA4G8YEk6SdV/AAxMA9wMsAZN/GDtOUu8OJgddly0pTdP0qTLKMh9TPMjyrIfGzXKQhzV1MfRDNkyo1LADTN21F8aDkBTbLc0hV2QUYOV4ZyN3i184GSoK9LSjKOVXRhws8yLH0q/zJFMCAsF/OBi2hPDF0UnSVNIVrOrsxp60bGBm26Nt2qDZFBpi4aWygASIJ3fdD1oXC6KjAjsJwKA1nKZh5MdSzgkwLadrKXhotizbW1OrJ6wAx1SCgBScmMUxhAAa0gF0wFC6QDGsUgMCu876HUzT3pgDBql4Y7rt2uteG8EAAFEAEkNwAdmGMkNmsQwkey3gIahmpYe23byuffKdCu8myjWGaPgfPcyZu0wiisWQgZw+ahKW0TxsDLBBA49gRAAaUhmc6DE9aIHQisdCRjmNBoSWMCR2Wg1hpWQFYGI2E1vDETE+YzcZYYGMCIYzfmMSLv2p1ghEH1gguzTR0XW2xORAAyXhkdoIzcqCHS91t1dyv4R9GBd05fV4b147QcOzdXAS49mASk9mVP5lWxFfAhQJgjdVgPRz0ovl5IIkBJABmIUeiMUVxTJSVZBlOUy4r13lRbcUNS1KTdXIAVDWNHA8HNPUrXoJhlPtXgDudQQ4CgEQkzjYjddGWhhhEDG1hJAAhYZqQANk9RxRk9DGT9GYYoAxhvjMcEQL+GYYL+YalRjJeuGNqR3wAQADiRkXfwJcGzr03smYi1cpT8lAY3PWzdW6IC/h3aUso8Brw3lveM/dVSIHbiATU2pR76gntQE009iCz2oNaBedoeDLydjAgh7gdAFBjJIVgLRUB4V4dEMAAiYYml1jAdoPgQBiREfwlo+YXy6wTFgIoxBDZyOETAPhYiWiGGFqoHhujRHiKEWtIMCj9G8EMLAWgrYdD6C0FrQM1jxHKOYkjCA30yBG0sW40xiiJE4F1jGbelF/FRkNG1AJ+Qgk2LsXQRxMNSAuMFvEvRHjBy6zgDgaapAonjncS0HWiMQDhPjEUwMMTPbFISeIpJDioA6H4DYGArjMlmKUTk8pGhWBaGqRmEpISvEgEEF4MkABWC+QzEQcnbLUnRWTSmSPKdI2YQyRmeN1hZOA/A/HaLoiMwx9wtgjIsYuE501mlOLSR0jJ2zelI34NuIZUYRllKRpU4iczTB1M7Nc+xKTnEPLiU8lR5S0AQHeVYhpqzQnlJ+ZEo50T/mPPhbYm5KS2msHkJ0iFYz+mDNRfUlZozdYTNKNM2ZpKakLN8DE22vBQFWwKLwW26K6Le0ZRySBkJgj4M3u4RBfJ9QXybiKMUiAMbYK7ng2BCYRVCgHqQoelDEpIDJGSGhsN6EWi+DQee8QV7BAKBYLAydd60FtkjUVtdMH12GJKlu0rBTfBwXKc17BLWzGIaaEk6qR6asQBfXVdCzQMMtEw415COGTnwDoAABnvAAJMAPQBhjCIiTfa/kwwpmgJdRgwNHr5VmjnP6pAEryHDyMnqUN4ap6RoNXPG0i82GmtdO6WUldwyxOjCGeWCcAUZmRYmeBlFOlZgrLmfMMoeqlnLJWedA0GzTRGq2TpBE+xU0SiODJE45wzjnJ0/i2VwJ82gstVaHV4JXi/D+OST48r7vfA+28yF/xARAnMC9glIL7lYheD9SFfyoXQlhHC26excSYmRBixECw0QHfRQMjFSIsR7OxTiSGZRnt5oB69As4kbT8l5SQ8k+qpRBjQGKmlApdT0nsijYAfIseqoxuyOHHKEy425DjJkzKCYCilYKoJfq1VY7RsGcUpIJWHIVJjZB0qZUJiHQc+6lP9RKplcqUnqp3Iir+BqTUHwtVomhrsYniq9Rs2uoam6xpxMmuupss1COLWIytGD55aY3UdodUZdMsju14P5+Gd0YAPSepm3Ib0wCfR8T9dm/0ubAzC8TaGrNIvlLRpjbGuNmD4xAITLLpMTQhcpq+4cNNKs3QZiNFQzMctlFS5zQGV107/oWsJG9nThaiwllLXgy1t3y1IIrcpKtygwHVrCwMXy9YG1YHM025sSSW0sNbDlZt7agxioF50mdehhdHVGHldE/YByDmIEO4g2B50jowaOfYTv9r7U9jOrts6uye4s/l0Ce69r7jyJB4osbFuldjOVuD4jA69KDvWqqa0UODQ28+TbTQECjYa5h8R+yohwEEDAfAXQGBoJ6SQ4UxDyQuaOz5aykYbNKFszFOzylqI0f0tn5LTnGK6cEy5ZLulYuBS01J6TwXs+eSAZLhyCWYqW+Ov5qHAWYqaSC+5ivyUc6Rnk9SCuMXkuV5OuAqvztwr59iiXuL8XG9F3rkAxKYALcFzYpbVK0A0rmQysASzjlK6Z4CGRvPHey72QcwpdL3eNPxGckx5Lhfq+t+Lu5Uurky8hS8t5MePlB8Rd8s3FuHfBM1xL0FOvw/Z+oDCvPVvRem4iebmPAfM+p+Sbb9pVfglO5d27xnhfxmTJmb7xZphmWsu2+yzlavdt215aYJGtUo9I1MBc71vqE6225G5xmrZyqdy2AAdQpzAKnpRg0aYU0lCOnnhKn5UOf6nwaIMYS618G4cQUYOJEPcDIWQ5OT+Agwg1UVQUgWQB0NOaAiwYAKw6wmwOgOwewhwxwpw5wlw1wmwBwUBwaBwQBlOL+Rk8BgcwIaQ8ASBuw+wiARwvIIg70osaAN48wjolgBwngooIs+B0ibB2IbB+gMAMABweMYABwQIIIzwuBRkcAAA+gQbkMsNCssFIWIObnAReOUgQa7qVkIKIL+OAbUDBBABwFACoC0CocENtqYc2BkKKEMLyDQH0DDPgEMBxDEO9BQoYPMOFi4fIKMppNDLodVJpAUMBOwOykYFwDDBAE0EMMkn/jQFAKYHmFANsD0BWLUMgCJpIByIwMgdQUcHwRcFcF/uwfrNxIDAcIlJYGwruHUIIbAKkdCrEU0KiDGCIFwMEIYFUI9I0M0RQsYEMHYdkLNrAb4KjKUGQPmOXBgG9PIJpFkMgMfj2sEH2rkfkagUUZgaUe9nAPgSsXwP0e6M4UMMgEmiUFANkWAEmsGL+OsVQZsegcUVgbcKxnsQjgcBcVcWTioPgLwMgAmCfKjMsOkdAK2LwEmlALtEmvcSgTQWgWcM8TsUQWIGIaIGCcZKAb+DdAsHiDITIcsRhLkDTC4RCVoTcV4FMe6C0BcQsaksZg+LwIAMgEtiwQ0QGQkAwQ/S7AUJjh7ApMpJFhroZ+ro7A5cugggIYDREwwxQp1gpS+AqILomQHQpAqIpACwvAqMXRmk+AHg+A4i5qaIL400TRMRyA3YlgyQs2Jx7Cl+RkwpwBLovxEJFhFwVg1pNAMJeRDx8JWxJR2BFh+BZ+F+0BAAxGvAWHwM4PwDtlDIICDNFv/qyfMPiYaj8H8ACM+F8EfrwKsMAAAAIqjvS8CP6EH2l3Y1ZyCIicgUAAgFBoQYSRAgAJj/FXGjZziwkFEIkYEBm3BGDlEkSVHVFwBhkJqamFnFmlkhkoloBv5QY4A1ncgAjiHkFfDFxQgwgiC8I0DLHlwg7JymB/56BojsyhAwBKrsBIgohoiYh8G4h+ACrQgMTFZgDdDBDIivK3lYjoE4FaiGBwAPm+BdrvaEzbm6K7krF9qMB1KeGPgiHvkUCRi1QCo6DHnQqWCMDOkxQ+LzCyguEFAODcBIX+50jolBYJqEzMBugqDLyuzzBaGhnBowWRjjo6AYh7zGQnwJj1zUjYyejMCjAkixgkiFoiCgINwwBkjIzIyjCgKXwYz8CehCX8D1xTJAIiBkhUisXcKwjyCXmMDIAYhBH6E7ilCMBe71xkjREQxgCoxzR1CSAyAYA8YYgcjEWRgmUPgli9IYhmVoDaUdhH46DIAXzUhMjciMrcC1krlBwSFfAMjH4ukABqykvJD4gOm5y8O5MAe5vch5y8a8GFZ5bwl515X56IP5OImVwQ5Er5755V24d5v5cFgFeIIFrsYFOVeVB5swLFHYcFOgCFsoJFi2fkqFhVJ5mF2F0QLoeFdhhFlgHlpFwFHCMIoRv615zk1FxWzs9Flpnpz+FZaA/VgYbFmInF3FvF/FglwlUAoloC4lkl0lsl8lF8ilylJIql6l1ImlgVZ1ulCoBlRlXllQ/lFlXgVlNlPQ9lfAWYzlrl7lo1IBeh3lvl/l/1mQ0oWwoV4VFIkV/uq1FFc4VFNFe1ycDFM5x1jAG18AcwnI3IIANc+aElUO4oqCUo5aIAjFs5VaoaQa9aY8VlWO+qjCRqNoGixOmAfA51KatA6acW2auaYOYqpC/8bNMqsOco46fNsqtaGqDaOqRotCzaOOraMa7arCDoHCQqhCO85Se8B8R8p858V8N8d8D8T8L89cb8H8X8P8f8ACQCIC9c4CIANVnCcCzeeaWqWCaCUq4ozqZacO4yiqZuutAtVCmCwwItLaYt+OIAhOjUZA0tmQul9OyyjeweLOsi8iWeYyXOqIPOMe1yRi5ymKyewyGuNu6eYK7e1eYy8u0ePeHuweKureXK/dZePdkufdIuvesuBuBSA+BeYy49Psk989iSM9duc9KeA9us/e9egSJuweXuPurefubeDewSS2NdYeC9NekeRuge1ubdieound+eHetys9I92SNeFVK9p9Q+69xsm9+909aef9peNiTu0KwDVdoDxeE9c+39ou5erS3esDADRKmg2h/9CKYy59o+l94+8+LKbKNsZsED8+iyHIMdpCZINaworqSAHNncKd7E7AfNRa+t6OY8Rtk82OM80a4tLCnAnaNtiq5dHdDOq9UioeLd9dqi6iTdWiddb9CesegiluJ9GDM9leODPSNeQ9iDt9Y9KDG9aDN9290DRj0uuui9+SsAw9xjFKSKVj4DNj+jUDneWDeKe9XdTjNeR9hDHjSMJDtKPsV9tDg+Yy99yjITYyz9bjr9Bj79Oj/xejWTmDMDjjB95SQDx9WTTeVSqDOTQK/j+TU9cDsuCDJT8TYSXjV2tD6Dfjv9u94Tfe+D5jo9Q+UTY+jKE+5sU+O2s+o6l28yEdttyqTN4OpCTqGtetnNKdszPDKqJCfDaOgtSAGMudZt+dsaRdUtpOKN1UPlNezAajDCBM9Yy+fkq+pW9z1AjzZAxkuejDZI5IGtMOydcooNYAlzYIyOJC7qOzWdQjJtIjuObaTAktJdZzwVWTyAm+VqEJaaGaL0RgOayR22YYbgHgXgDDKtDqZIGM6o8dbDiApaqz2t2NfNEo/DuzpCBzojeOsaXaaLsw1qtqIAXzoCZCrDGC7qdLeA3LVcmzpocdELIaJIbLsLFtEjS8Co8IagLuOgitJgZg0WnMeKdgDgzgGphLngrOj50CqrRIn+mweASQKQPq6QdJWr8SRQ8AswX6ThWQ9QRrTQLQWQbQPQIMXQswThAwfhYwEwUwtAwbpQuJ6hqwGwsQlBcJhRTx2x2B9wYpzWzwlrSoHcvwSA/wgIcVa54IUCWVubCIn5TVVVlgQF+I55arjApIFIVIvAtI9IBwjIFIrIvb7IXIpL/IZI1Ietwr0OlLYr8QlbzZKo0rZCsrDa8rxteqedYjBdnieSOoQwK8xhruYAGgNYO7oIOgF+cAu71rsQeAmEpJSaR7MANxVhyQQw3OPJABugEIoIOrjgggRgpreQd7zh5QtimklpYpsg0RJxvgAAUswBoDBNuT6s7E6Lu4hgMbuOiC+40b666DAI4K0T4opHAGMVhKSY+5+9MEEJpGgC6DEQbhYM2CIOwlAt0KULYHiAAFS8CtlJqnu7s3EuxcCaTOmiiIafixRwCSl/FRG3vIegjzD6xGCMDcBJqmAyeWS7t4VqmBBKc3EpGumycwAMWyBgA6eAfOx5gtFrzgnNFaEQd5gtBliwDzAABWIHAhwIsBnHrZA5EAAwrA+n6noIFJh0eYGRB0zYRg6E1nMRtnzRZxGiFYlEFwaA0Q9w3pGx8JkAsArn8wgQRgLxexrAs2egywRA3z8wtABw1z7ALwqIiXRHOwlgrAYZCXxEegqXf6KRvg8XdXxEyXrjpA6XvpRwWXMAOXeXBXBwRXNAJXZXJIFXVXlqtXMQfXjXzXrXlE7XZAGp3h17QwPnfnAXZ7QXy8FnzgMC4JwnhA9wti5b4gxgtpSao3iAd7D70AT7xHMh7H7HhJygxg33MhJJ+3+sh3AHvnzn0WAVmkCUhAsUsgQw3QvxjQK8u4dGaAAivgcAGAogipkg8smkHAEMtpjgSpikXHG4qMVHLhLQxQZwDkpgkANY8PJx5hToqPswGP+YWPOPqIkAa8vAhPQwxxEAC1vAjnhnrn2QvCNR3hNkQxpJZxnJQwlQG3mkqMBwAA8kNymwcKN+N9KJN9N3TaV+V5V9V8t/V/MGt2GcwMsEr8sJIMsKr8sBIHwLGYUmANPkMIYO79YL+MR6QRITArkLaQd2wEd3x4gHiEmjH650Tcd4Zwp82y4eXDF4EKwFABiNwO2AyFuF4FsCn/rK6On0kRB+1/LD4ORQn/JxAIpxiIXzEQAKSAWmAYg0ekAZ9Z859dt5+sdIEwCp/F8d+l/NHl/3Dx8afbfafdDKnIxaekDNvH6ECNRwCmBnsw8h8DCpFajqI9CthZ/Z+duCT5/nTz+IbcTUR6d0Elk05DG0cpfbdR+iFduBhz/qk6BL8QAr9r9oj4Wb8xjbBrm+SVsEf2jDBBkA0iNgByEQBTJMEUyUAUGCA7wcDATUeYGkjsokddwoZa0BMGe5EBLAjqMkJglARkUGQYA3gBr0cAQ8xAaA4QBMWvZYDqcOAxgHgIIH1xRg1IRAKHVIEv9EBwQZ7pSQwhsALexEMQr/kzaUYMYGMTBNSAQFnVwBkA1gByGWDk4gBZAUNEwzkGZA3Y/SZAYh1wFglEAgg6YiIMohiCkyv4GVBfFDSjAeBY6fgYYOMHCCRCYhfpDIS1aLMuB7VDhJ4kJgYgkq4pP8L5wAqSAMQ7YO9kZwwiMAk0O0QYjWHTSeJEQAAQnWB5gF0SQpNIf2f7H8++qQuIaWTFL+cgh7gdTmABSGxD0hYUe/gN18Ax8k0eIQPuQWD4PdhiPHAzvxyK6UQn+tQ2PmoS7QV9CYXcGCO50sBGEXwhAF0Ep3CEcJtugw2UMMOl5jCYAEwqYfH0sIYBeOn7ZyDPztLV9NhMARgBX1MDbcshvgSwBsIM4186+DfIfp3yyG58s0AuG4e3wz5VCqg4/T3hcMC6J9a+yfAfkX2b5ts2+JfLvkf175PD/hafYfm8Ir5nCvh1fKfgvx2Fv9tO/g5fvsB/4b8HuW/QAbv1GgH9u+OQgXMgBRGkAP+6I1froF/6ih/+2/NQaNF3zNFtu3goLL4Ocj+DChvAYoSELABhC4R+wyISZxiFpDGgCQwcMkLyHpDMhhI8EVsAqGNAAhRQ4IaUPKEijSASQt4cyOuIx90yBbFAACHkAgsLSE2CsF2VQIcF8AIsFgmiF15glXOto2AAcDcKOBjgpvKbuwBdERDXO0VAdvM1Vr1wSQlLMdnsy1p4A72jLVHHWizqjAFW5tcRgThh7QA+AAopPhhhlCtR7OIzXLmZkkBsBr8WwezsgHco6AiAEAHkhMAADUlsKNPrBjDRUogNreILKIg7nEUuFfG4ld3qIuhZ23hO1qkE/adwHAswTSB0SkDncZAlEVsKYE7F2FfAzYOQIKnkCpEoiwxDmADBaBpiheMUTIOKXCTNZcx/nKzsuJA4iw9AKgCQeoRdwgcrAYHGsHFyTQcxSg/ARgPXGU5dl4S1gMABjFy4G8VQggSrp+Kd4Fg9in4+uLVy8D8B5g9cK3mgCa5kUKopJQcSaQRDM9jiE4pcRBzOKZtWA8wX3uUB05mjMudoojhN1KJG9Zubo83thJglNcIyDwPCWgAYnLAj83AONj0KTRx8q+SHMMITCmTTDvhVw5tqGATiN9M+R5YdHMBlGPCtgwk/tFMjeFj9K+EQpPhiFkmIA22sk+4T32kloUJJOgeSWXzbEfC6heIOXv8STTUSGJBEn0jrz14kSDeZE4rmgBN7zczeS3aidb2wkMSmJLEgQIECoZYoGJD4eYLqMzJM1DAFYL4EQFGDzBhgsU5kAzUHbsMSQfDYMVwNDHxAFOEYzOiGlASxijmcoLtAmmTSYstWOaRhoAndRpTaWnDOUAmmynMss6vFeZBqDBJ4ANytVPSoqCrY3lKq95COjCARx9pGq35eYDgUkARcHyHU58rbTNxzEuEV5atqNPGnHV62XLXVlvmCDsi94tsNafGhJrbUya3afcojgpo81qadSc6rNObzI1uGOgdZsjUBbAt2KK+MgJjWRbIAdEFqQ8nhGnbNsxglIUwBfGIq8AGQAM3gAoBghrBPQkYAmvxBZHV8k+SaGyL0HBmQzoZu3WgB2SnC8B00CaHNPWJAAJRmASAUANFG7CSA8AnwREIiCAA==="}
import { parseUnits } from 'viem'
import { walletClient } from './config'
import { usdcAddress, usdcAbi } from './contract'

const recipient = '0x...'

const hash = await walletClient.writeContract({
  address: usdcAddress,
  abi: usdcAbi,
  functionName: 'transfer',
  args: [
    recipient,
    parseUnits('100', 6), // 100 USDC
  ],
})

console.log(`Sent 100 USDC. Tx Hash: ${hash}`)
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

```ts twoslash [contract.ts] filename="contract.ts"
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

:::

### Approve a Contract to Spend USDC

To interact with DeFi protocols like Uniswap, Compound, or payment processors, you'll often need to **approve a contract** to spend tokens on your behalf.

In this step, we'll approve the Uniswap Router to spend up to 1000 USDC from your wallet.

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"a6be470e2372ec1412f1dc88ac1e663ff6f7462fbb6b0101146c9b02a2123946","data":"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"}
import { parseUnits } from 'viem'
import { walletClient } from './config'
import { usdcAddress, usdcAbi } from './contract'

const hash = await walletClient.writeContract({
  address: usdcAddress,
  abi: usdcAbi,
  functionName: 'approve',
  args: [
    '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D',
    parseUnits('1000', 6),
  ],
})

console.log(`Approved 1000 USDC for Uniswap. Tx Hash: ${hash}`)
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

```ts twoslash [contract.ts] filename="contract.ts"
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

:::

### Check the Allowance for a Spender

Once you've approved a spender (like Uniswap), you may want to verify how much USDC they're allowed to use.

Let's fetch the allowance for the Uniswap Router.

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"3833e748e16ed69467a9ba60216f3d49dd99a673b0264013f9b04e01f10886f2","data":"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"}
import { formatUnits } from 'viem'
import { publicClient, account } from './config'
import { usdcAddress, usdcAbi } from './contract'

const allowance = await publicClient.readContract({
  address: usdcAddress,
  abi: usdcAbi,
  functionName: 'allowance',
  args: [
    account.address,
    '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D',
  ],
})

console.log(`Remaining allowance: ${formatUnits(allowance, 6)} USDC`)
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

```ts twoslash [contract.ts] filename="contract.ts"
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

:::

### Watch for USDC Transfers

Let's subscribe to real-time "Transfer events" emitted by the USDC contract. This is useful for building wallet UIs, dashboards, or backend listeners.

:::code-group

```ts twoslash [example.ts]
// @twoslash-cache: {"v":2,"hash":"ce84c5af88b0465ac70c41f3dbd78d0d56c93f9bf16ecf8102b6c3579cfe0138","data":"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="}
import { formatUnits } from 'viem'
import { publicClient } from './config'
import { usdcAddress, usdcAbi } from './contract'

const unwatch = publicClient.watchContractEvent({
  address: usdcAddress,
  abi: usdcAbi,
  eventName: 'Transfer',
  onLogs: (logs) => {
    logs.forEach((log) => {
      const { from, to, value } = log.args
      console.log(`Transfer: ${from} → ${to} (${formatUnits(value, 6)} USDC)`)
    })
  },
})
```

```ts twoslash [config.ts] filename="config.ts"
// @twoslash-cache: {"v":2,"hash":"ff4fbb59bd23681ab5dce0eb544dcddcbb42820cb25c67ac23ce9adbb74eee29","data":"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"}
import { createPublicClient, createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { sepolia } from 'viem/chains'

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

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

export const walletClient = createWalletClient({
  account,
  chain: sepolia,
  transport: http(),
})
```

```ts twoslash [contract.ts] filename="contract.ts"
// @twoslash-cache: {"v":2,"hash":"08590fd571a3046fe44ccaaf79079e55375b08a0abd3e1f1bd36499de960a132","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIBjCGDhpeZfgCYADAEEARu0S9SMZlCGsMvVAB0wvA8tXqwm3phxKdIGCTBprAbj2GjajVrDMAtjCsgZLCxSYjYnF0MVd1MtdjAsAFc0OCUokzNdfVdI4w9eONhaGCglNFIEmGcs7Ld0zx8/XmsIAHcwMnDq7LS8i0brNSgVODhO1wBfCl5gCJqemPywQuLS8srZ7tyFr19/OBwljpAqmoN5sz7/QeHR443J6Y3Xc9jDopLeADM2OHWu562Zh2/RARDYFTGpxe5mwIIScTQEgArAA2SEGcYAXSqDxmXWhlyaNjsDju+MB9V2RIAKqRmMJPkcTjlomY4olkqkKdo8adankCnQVuY1sy5tzgf5PiFvOjNqytISBlAhvBbmLeLiniy6otlh8yhUNQCFbxJUS0BA5SbdUqQNc1XKtf8dQK3sLvqxfsbXdsGv4wawIWS+QTYf54fZkWiQ4YsTipgA6ZO8AAcvG8EBUvGTiamvMMuZxmL07G8WCzonE0nk7EoIHU/AQiBAyAAogAlADCAFppLxqRAANYwfQAZTQ9KgzFIUExjHwaDQWBSAHpVzA0PgyDAEt5E1mAOYbsCr2AkVgQHCkOBniBN1ciKczqC3y0j4Qb0j8PtSbj1p9SAYRAAE4qFYUdDy3JBUyoSdSEPTc8GrWQFHrDh2iQKQqH4fAZ2YfgaHIUDJnQWE8EIEhyDguhgJAQRhFEBI4Cgfhay5U1MhtXpwyJWxR1JDVoXNaxAmCUJWDlaF2SSFJ+QWLioW5QV3lWI1tTOCV/SJVp2lIa1fQuXjlVVEYnXzDT5LZd0DVFSzhO06x9lHWB9NjcVTTtB0zPczULJdTTTRUj0fj+UMtKpaxA2DH1AttYyQEjRFUSdbE9GdbiFjtfj7CkiKQVpek4EZNyhOU+JZI43VFI83Vgts9SAqsykQWlCBZV8zKjMsIlvPVe5/PCoKbLUsKlNNETqCtTrDMVBK+vMx4mukkavlC2LmrNRzQXBGADLinieusJLo1ShMcxTdNM2zXNBsLZNiwA+DgIAFhRcDIOgxAAHY4JnRC6OY1ja3QuJcEQCQcLwulCLIJAAEYAGZSOociW0ouGaPoJg2E4HgBCEEQxG/GsFCqvIas27KSTyibtrEkJA1puqKs5TbKa6159VGjaHMikBdKZezuS8lUbkWgtardbmRUaobdUm5zDlK4XPPmsXHV8jLxpZmXPW9VWFe26K9pmg6soSk6Uq1tKwG183upBHLBI2PmCrpBkhfJYaOTk6EOdmvUhQasapb9fm2o63mRfV0z+q6e35V14OecNvJJstfaqdj8WtbusPrL19a0/DkETazsMjsShFTpt87czTDMsxgC68yW1wi3SkswDLCsgOJyRULrKhG2bVtO17ftBw/XgJ2fWd50XZc1w3Lcdz3A8EJPM9+Mva9b1Hx9JyWF832HUdb3EX9/yoQDgNRD6wCg/AYL+hCkJbFCQfAsGkEh+joYESIn/ZGFAyI4AosQTG1BaJ4AYkTIGbENYjH8FIWg8N+DfQACIvQAELwxAiiLscgpBdm+rgqQ8MoDfReojAAYnIfgKJ4bwxRMwECUgJCI2+iBMhXDUzWCejOYC31YIgAgk/L6LC34AzwIgmQyCEA/0wogRGUN8Kw2IkjLEOFoDgxAL3Ss0wB6k3YJqL4MpeAAHIiDsBgN4Kxeg9B0D7qIeBTEWJsQULwAAvCYoezjaCuIJoxXg8jFG+OsWgjB2C8EEKISQshFCqE0PoYw5hrD2GcO4bw76/CrH1l8JOJAoBaIX3YEIPAyQQDjHGEAA"}
import { erc20Abi } from 'viem'

export const usdcAbi = erc20Abi
export const usdcAddress = '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238'
```

:::

::::
