Check out the full explainer on OP Stack transaction fees for more information on how OP Mainnet charges fees under the hood.
Supported networks
Viem supports any of the Superchain networks. The OP Stack networks are included in Viem by default. If you want to use a network that isn’t included by default, you can add it to Viem’s chain configurations.Dependencies
Create a demo project
You’re going to use Viem for this tutorial. Since Viem is a Node.js library, you’ll need to create a Node.js project to use it.1
Make a project folder
2
Initialize the project
3
Install viem
Want to create a new wallet for this tutorial?
If you have
cast
installed you can run cast wallet new
in your terminal to create a new wallet and get the private key.Get ETH on Sepolia
This tutorial explains how to bridge ETH from Sepolia to OP Sepolia. You will need to get some ETH on Sepolia to follow along.You can use this faucet to get ETH on Sepolia.
Get ETH on OP Sepolia
This tutorial explains how estimate transaction costs on OP Sepolia. You will need to get some ETH on OP Sepolia in order to run the code in this tutorial.You can use the Superchain faucet to get ETH on OP Sepolia.
Add a private key to your environment
You need a private key in order to sign transactions. Set your private key as an environment variable with theexport
command.
Make sure this private key corresponds to an address that has ETH on Sepolia.
Start the Node REPL
You’re going to use the Node REPL to interact with Viem. To start the Node REPL run the following command in your terminal:Set session variables
You’ll need a few variables throughout this tutorial. Let’s set those up now.1
Import viem and other necessary modules
2
Set up the account
3
Create the public client
4
Create the wallet client
Estimate transaction costs
You’re now going to use the Viem to estimate the cost of a transaction on OP Mainnet. Here you’ll estimate the cost of a simple transaction that sends a small amount of ETH from your address to the address0x1000000000000000000000000000000000000000
.
1
Create the unsigned transaction
Viem makes it easy to create unsigned transactions so you can estimate the cost of a transaction before you a user to sign it.
Here you’ll create an unsigned transaction that sends a small amount of ETH from your address to the address
0x1000000000000000000000000000000000000000
.2
Estimate the total cost
With Viem you can estimate the total cost of a transaction using the estimateTotalFee method.
3
Send the transaction
Now that you’ve estimated the total cost of the transaction, go ahead and send it to the network.
This will make it possible to see the actual cost of the transaction to compare to your estimate.
4
Check the actual execution gas fee
Once you get back the transaction receipt, check the actual execution gas fee.
You can do so by accessing the
gasUsed
and effectiveGasPrice
from the transaction receipt.
You can then multiply these values to get the actual L2 cost of the transaction5
Check the actual L1 data fee
You can also check the actual L1 data fee.
6
Check the actual total cost
Sum these two together to get the actual total cost of the transaction.
7
Check the difference
Finally, check the difference between the estimated total cost and the actual total cost.
This will give you a sense of how accurate your estimate was.
Estimates will never be entirely accurate, but they should be close!
Estimates will never be entirely accurate due to network conditions and gas price fluctuation, but they should be close to the actual costs.
Next steps
- Always estimate before sending: Estimating costs before sending a transaction helps prevent unexpected fees and failed transactions.
- Account for gas price volatility: Gas prices can change rapidly. Consider adding a buffer to your estimates or implementing a gas price oracle for more accurate pricing.
- Optimize transaction data: Minimize the amount of data in your transactions to reduce L1 data fees.
- Monitor network conditions: Keep an eye on network congestion and adjust your estimates accordingly.
- Use appropriate gas limits: Setting too low a gas limit can cause transactions to fail, while setting it too high can result in unnecessary costs.
- Implement retry mechanisms: If a transaction fails due to underestimated gas, implement a retry mechanism with adjusted gas parameters.