viem@2.45.0: New Data Suffix Features for Web3 Development
viem@2.45.0 adds dataSuffix for wallet and bundler clients, streamlining custom calldata in Web3 development.

viem@2.45.0: Unpacking Data Suffix Features for Web3 Developers
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.
What's New in viem@2.45.0
This minor release focuses on enhancing transaction flexibility with the following key updates:
- dataSuffix in createWalletClient (Commit 0e1d62d): Thanks to contributor @dgca, developers can now pass a
dataSuffixparameter 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 in createBundlerClient (Commit dc4c100): Also contributed by @dgca, this extends the
dataSuffixfunctionality to bundler clients, specifically forprepareUserOperationandsendUserOperationactions. This is particularly useful for account abstraction workflows where additional calldata needs to be attached to user operations. - Patch Updates: Several smaller patches, including updated chain definitions for MegaETH and RISE Mainnet, exported types like
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.
Developer Impact
Migration Requirements
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.
New Capabilities Unlocked
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.
Performance Considerations
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.
Getting Started with dataSuffix in viem@2.45.0
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.
Step 1: Update to viem@2.45.0
Ensure your project is using the latest version. Update via npm or yarn:
bash1npm install viem@2.45.0
Step 2: Implement dataSuffix with createWalletClient
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.
Step 3: Use dataSuffix with createBundlerClient
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);
Common Gotchas
- Data Size: Large
dataSuffixvalues can bloat transactions, spiking gas costs. Test with small payloads first. - Compatibility: Ensure your target chain or bundler supports custom calldata suffixes. Some older bundler implementations may ignore or reject them.
- Validation: viem doesn’t validate the
dataSuffixcontent—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.
Why This Matters for Web3 Development
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.




