viem@2.45.0 adds dataSuffix for wallet and bundler clients, streamlining custom calldata in Web3 development.

The latest release of viem, version 2.45.0, dropped on January 25, 2026, and introduces subtle but powerful updates that Web3 developers should note. As reported by viem Releases, the standout additions are the dataSuffix parameters for createWalletClient and createBundlerClient. These features enable finer control over transaction calldata, which can be a game-changer for dApp development workflows involving custom transaction payloads.
This minor release focuses on enhancing transaction flexibility with the following key updates:
dataSuffix parameter when initializing a wallet client. This automatically appends additional calldata to every transaction action submitted by the client. It’s a small tweak with big implications for automating custom transaction behaviors in dApps.dataSuffix functionality to bundler clients, specifically for prepareUserOperation and sendUserOperation actions. This is particularly useful for account abstraction workflows where additional calldata needs to be attached to user operations.SignTransactionRequest, and missing OP Stack actions, round out the release. These are detailed in commits like 08e1bb6.From a code perspective, these changes mean developers can now bake custom data directly into transaction flows without manual intervention per call. Compared to libraries like ethers.js, viem’s approach here offers a more native integration for calldata manipulation, reducing the need for middleware or custom wrappers.
Good news: viem@2.45.0 introduces no breaking changes. If you’re upgrading from a prior version, there’s no immediate need to refactor existing code. The dataSuffix parameters are optional, so your current wallet and bundler client setups will continue to function as-is.
The dataSuffix feature is a quiet powerhouse. For dApp developers working on DeFi or account abstraction projects, this allows seamless integration of custom calldata—think protocol-specific metadata or encoded instructions—directly into transactions. This can reduce complexity in transaction batching or user operation pipelines. For instance, if you’re building with account abstraction on Ethereum, as outlined in the Ethereum.org documentation, this feature aligns perfectly with custom user operation needs.
While viem doesn’t publish specific gas benchmarks for this release, appending calldata via dataSuffix will naturally increase transaction size. Developers should profile gas costs for their use case, especially if the suffix includes large payloads. Gas optimization remains a critical concern, and tools like Hardhat can help simulate transaction costs during development. As a rule of thumb, keep suffixes lean to avoid unnecessary gas overhead.
Let’s dive into how to leverage these new features. Below are practical steps and code snippets to get you started with dataSuffix in your Web3 development stack.
Ensure your project is using the latest version. Update via npm or yarn:
bash1npm install viem@2.45.0
Here’s a basic example of initializing a wallet client with a dataSuffix. This snippet assumes you’re working with an Ethereum-compatible chain:
javascript1import { createWalletClient, http } from 'viem'; 2import { mainnet } from 'viem/chains'; 3 4const client = createWalletClient({ 5 chain: mainnet, 6 transport: http(), 7 dataSuffix: '0x12345678', // Custom calldata suffix 8}); 9 10// Submit a transaction with the suffix automatically appended 11const tx = await client.sendTransaction({ 12 to: '0xRecipientAddress', 13 value: BigInt(1e18), 14}); 15console.log('Transaction Hash:', tx);
In this case, 0x12345678 is appended to the transaction’s calldata. Adjust this based on your protocol’s requirements.
For account abstraction use cases, here’s how to apply dataSuffix to user operations:
javascript1import { createBundlerClient, http } from 'viem'; 2 3const bundlerClient = createBundlerClient({ 4 transport: http('your-bundler-endpoint'), 5 dataSuffix: '0xabcdef', // Custom suffix for user operations 6}); 7 8// Prepare and send a user operation with the suffix 9const userOp = await bundlerClient.prepareUserOperation({ 10 sender: '0xSenderAddress', 11 callData: '0xSomeCallData', 12}); 13const userOpHash = await bundlerClient.sendUserOperation(userOp); 14console.log('User Operation Hash:', userOpHash);
dataSuffix values can bloat transactions, spiking gas costs. Test with small payloads first.dataSuffix content—ensure it’s properly hex-encoded to avoid runtime errors.For deeper dives into viem’s API or troubleshooting, refer to the official viem documentation or explore related Web3 development resources in our Developer Hub.
The dataSuffix addition in viem@2.45.0 may seem niche, but it addresses a real pain point for developers building complex dApps or DeFi protocols. Manual calldata manipulation is error-prone and cumbersome, especially at scale. By baking this into the client initialization, viem reduces friction and aligns with the needs of modern blockchain development.
If you’re working on smart contract integrations, consider pairing this with security best practices from OpenZeppelin to ensure your calldata payloads are safe and audited. For contract templates or further inspiration, check out our smart contract codebase.
This release also signals viem’s continued focus on developer ergonomics, setting it apart from bulkier alternatives. Whether you’re optimizing gas or streamlining user operations, viem@2.45.0 offers tools worth exploring. Have you run into gas spikes with custom calldata? Drop a comment or share your setup—I’m curious to see how the community adapts this feature.

Alex is a blockchain developer with 8+ years of experience building decentralized applications. He has contributed to go-ethereum and web3.js, specializing in Ethereum, Layer 2 solutions, and DeFi protocol architecture. His technical deep-dives help developers understand complex blockchain concepts.