Time to read: 1 min
Verify Smart Contracts on Rootstock CLI
To verify a smart contract on the Rootstock CLI, the rsk-cli verify command allows developers to submit their contract source code and other information to the Rootstock Explorer API.
The rsk-cli verify command enables the verification of a smart contract on Rootstock's mainnet or testnet by providing the contract code, address, and other metadata through a JSON file.
Verification on Rootstock's blockchain allows users to confirm that the compiled bytecode on the blockchain matches the source code.
- Mainnet
- Testnet
  rsk-cli verify --json <path_to_json> --address <address> --name <contract_name> --decodedArgs <arg1> <arg2> ...
rsk-cli verify --testnet --json <path_to_json> --address <address> --name <contract_name> --decodedArgs <arg1> <arg2> ...
info
- --json \<path\_to\_json\>
- This specifies the path to the JSON file that contains all necessary information for verifying the contract. The JSON file should typically contain:
- Source code of the contract.
- Compiler version and settings.
- ABI (Application Binary Interface) data for interacting with the contract.
- Metadata for libraries if the contract has dependencies.
 
- Example: If your JSON file is named fb7b3667b850d874bffe750e005d2477.jsonand it is usually in thebuild-infofolder under theartifacts folder, you would use--json .artifacts/build-info/fb7b3667b850d874bffe750e005d2477.json.
βββ artifacts
β   βββ build-info
β       βββ fb7b3667b850d874bffe750e00...
βββ contracts
β   βββ ContactInfo.sol
βββ cache
βββ files
βββ ignition
βββ node_modules
βββ test
βββ typechain-types
βββ .gitignore
βββ hardhat.config.ts
βββ package-lock.json
βββ package.json
βββ README.md
βββ rootstock-wallet.json
βββ tsconfig.json
- --address \<address\>- This is the address of the deployed contract on Rootstock's blockchain (either on mainnet or testnet).
- The address helps the Rootstock Explorer locate the specific instance of the contract you want to verify.
 
- Example: --address 0x1234567890abcdef1234567890abcdef12345678.
- --name \<contract\_name\>- This is the name of the smart contract as defined in the source code.
- This helps the verification system know which contract from the JSON file corresponds to the one deployed at the given address.
 
- Example: If the contract is named ContactInfo, use --name ContactInfo.
- --decodedArgs \<arg1\> \<arg2\> ...(Optional)- decodedArgs is used when the contractβs constructor requires arguments for deployment.
- These arguments must match the constructor parameters in the source code and are provided in a decoded format.
 
- Example: If the constructor takes an address and a number, you might provide --decodedArgs 0xabcdef1234567890abcdef1234567890abcdef12 1000.
- --testnet(Optional)- This flag specifies that the contract verification should be performed on Rootstockβs testnet instead of mainnet.
- Testnet is used for testing purposes, so developers often use it to verify contracts in a non-production environment before deploying them on the mainnet.
 
- Example: If verifying on testnet, use --testnet.
To verify the same contract on the testnet:
rsk-cli verify --testnet --json artifacts/build-info/fb7b3667b850d874bffe750e005d2477.json --address 0x4edd891c2e988e6145fe3e418c652ee33ebab9ae --name ContactInfo    
With constructor arguments:
rsk-cli verify --testnet --json ./contract.json --address 0x1234567890abcdef1234567890abcdef12345678 --name MyToken --decodedArgs 0xabcdef1234567890abcdef1234567890abcdef12 1000
The response below was obtained from the command without a constructor.
π§ Initializing verification on testnet...
π Reading JSON Standard Input from artifacts/build-info/fb7b3667b850d874bffe750e005d2477.json...
π Verifying contract ContactInfo deployed at 0x4edd891c2e988e6145fe3e418c652ee33ebab9ae..
β π Contract verification request sent!
β π Contract verified successfully!
π View on Explorer: https://explorer.testnet.rootstock.io/address/0x4edd891c2e988e6145fe3e418c652ee33ebab9ae