Verify contract using truffle#

The recommended way to verify a smart contract is using plugin. It is easier to read, imports are maintained, licenses are maintained.

truffle verification#

truffle has an OKLink plugin: truffle-plugin-verify

You need to deploy with truffle to verify with the truffle verify plugin.

  • Install the plugin

npm install -D truffle-plugin-verify

  • Configure the plugin in truffle-config.js
const HDWalletProvider = require("@truffle/hdwallet-provider");

// const infuraKey = "fj4jll3k.....";
//
const { mnemonic, OKLinkPIKEY} = require('./env.json');

module.exports = {

  plugins: [
    'truffle-plugin-verify'
  ],
  api_keys: {
    OKLink: OKLinkPIKEY
  },
  networks: {

    mainnet: {
        provider: () => new HDWalletProvider(mnemonic, `https://exchainrpc.okex.org`),
        network_id: 66,
        timeoutBlocks: 200,
        confirmations: 5,
        production: true    // Treats this network as if it was a public net. (default: false)
    }
  },

  // Set default mocha options here, use special reporters etc.
  mocha: {
    timeout: 100000
  },

  // Configure your compilers
  compilers: {
    solc: {
       version: "0.5.16",    // Fetch exact version from solc-bin (default: truffle’s version)
      // docker: true,        // Use "0.5.1" you’ve installed locally with docker (default: false)
      settings: {          // See the solidity docs for advice about optimization and evmVersion
       optimizer: {
         enabled: false,
         runs: 200
       },
       evmVersion: "byzantium"
      }
    },
  },
};
  • Verify
truffle run verify KIP20Tokens@{contract-address} --network mainnet

You should see the following output: