Verify a smart contract
Verification uploads your contract's source code to the block explorer and proves it compiles to the deployed bytecode. Once verified, users can read state, call functions, and audit the source on Stablescan without re-hosting your code. This guide walks through verifying a Foundry-deployed contract on Stable.
Prerequisites
- A contract already deployed on Stable testnet or mainnet. If you haven't deployed yet, see Deploy a smart contract.
- Foundry installed (
forgeavailable in your PATH). - The deployed contract address from your
forge createoutput.
1. Confirm the deployed address
Make sure you have the Deployed to address from your earlier deployment. From the Deploy a smart contract flow, this was the value printed after forge create.
cast code 0xDeployedContractAddress --rpc-url https://rpc.testnet.stable.xyz | head -c 200x6080604052600436...A non-empty bytecode confirms the contract is deployed at that address.
2. Run forge verify-contract
Foundry's verification flow submits your source to the Stablescan verifier.
forge verify-contract \
0xDeployedContractAddress \
src/Counter.sol:Counter \
--chain-id 2201 \
--verifier blockscout \
--verifier-url https://testnet.stablescan.xyz/api \
--watchStart verifying contract `0xDeployedContractAddress` deployed on 2201
Submitting verification of contract: Counter
Submitted contract for verification:
Response: `OK`
GUID: `abc123...`
URL: https://testnet.stablescan.xyz/address/0xDeployedContractAddress
Contract verification status:
Response: `OK`
Details: `Pass - Verified`
Contract successfully verified--watch blocks until verification finishes so you don't have to poll. On mainnet, swap the chain ID to 988 and the verifier URL to https://stablescan.xyz/api.
3. Confirm verification on Stablescan
Open the contract page on the explorer.
https://testnet.stablescan.xyz/address/0xDeployedContractAddressThe Contract tab should now show source code, a green "Verified" badge, and the full ABI. Users can read state under Read Contract and send transactions under Write Contract.
Troubleshooting
- "Bytecode does not match": your source compiles to different bytecode than what's deployed. Most often caused by mismatched Solidity version or optimizer settings. Pass
--compiler-versionand--optimizer-runsexplicitly to match yourfoundry.toml. - "GUID not found": the verifier hasn't registered your submission yet. Re-run with
--watchor manually check the URL printed in the response. - Contract uses libraries: add
--libraries src/Lib.sol:Lib:0xDeployedLibAddressfor each linked library.
Next recommended
- Index contract events — Subscribe to on-chain events with ethers.js and build a live event stream.
- Deploy a smart contract — Scaffold a fresh Foundry project and deploy to Stable testnet.
- JSON-RPC reference — See which
eth_*methods Stable supports for on-chain interactions.

