Logo

dev-resources.site

for different kinds of informations.

Solution to the ConnectTimeoutError Encountered When Verifying Smart Contracts with Hardhat

Published at
8/5/2023
Categories
solidity
hardhat
ethereum
smartcontract
Author
codingjourneyfromunemployment
Author
29 person written this
codingjourneyfromunemployment
open
Solution to the ConnectTimeoutError Encountered When Verifying Smart Contracts with Hardhat

In the process of learning blockchain programming, whether it's the most popular video tutorial on YouTube or the Alchemy's solidity bootcamp, content related to Hardhat is inevitable. This is not surprising as in the field of Web3 development, Hardhat is undoubtedly one of the most mainstream frameworks. However, I encountered the same pitfall in the process of learning these two courses, that is, after using Hardhat to deploy smart contracts, I could never succeed in the verification. The same error always occurred:

An unexpected error occurred:
ConnectTimeoutError: Connect Timeout Error
......
Enter fullscreen mode Exit fullscreen mode

I searched on Google for a long time but didn't find a complete solution. Then I tried to ask GPT-4 but still failed to solve it. Eventually, I found some insights in this post on GitHub. Now, in combination with the actual process of solving this problem myself, I will record the process of analysis and verification, hoping to help those who also encounter this problem.

Firstly, I want to analyze the causes of this problem๏ผš

  1. I'm using the WSL2 system. The proxy is set in the Windows environment, and the WSL2 system shares the proxy from the Windows environment. Therefore, the solution idea in the aforementioned post did not initially catch my attention. I originally thought that my WSL2 system had set up to share the proxy from the Windows environment, and that I could connect normally using the curl http://google.com command, so the inability to use Hardhat's verify function should not be a problem with the proxy settings.

  2. Moreover, my error message and the content in the aforementioned post were quite different, aside from the ConnectTimeoutError. Given that Hardhat itself frequently updates, I thought it was an issue with the Hardhat version or a problem with one of its dependencies. What's more, GPT-4 analyzed the situation in the same way at the time, which somewhat misled my thinking.

  3. I tried to upgrade and downgrade and adjust the versions of libraries and dependencies like Hardhat, @nomicfoundation/hardhat-verify, @nomicfoundation/hardhat-toolbox several times, and even tried to apply for multiple API keys on Etherscan, only to find it didn't help. In the end, I realized that although I globally shared the proxy from the Windows environment in WSL2, the verify plugin might not use the global proxy under the WSL2 environment when Hardhat is running due to some reason.

Problem Solution and Contract Verification Process

  1. Environment configuration: I have a simple example project here, which deploys an upgradeable contract. You can refer to my package.json file. Many answers online are quite outdated, but my libraries are all up to date. Of particular note is the need to install the Undici library, which will be used to set the proxy for verification.

  2. Writing the contract and deployment script: This is a standard step and not the focus of this article. But if you are a beginner like me, you can also refer to the simple contract and deployment script in my aforementioned repository. After the writing is done, we can deploy the contract under the Hardhat localhost environment or on the testnet. However, only when deployed on the testnet or mainnet can we use Hardhat's verify plugin.

  3. Apply for an API key on the Etherscan website, which is free. After application, create a new .env file in the root directory of the Hardhat project and paste ETHERSCAN_KEY=yourApiKey into it. Then set it in the hardhat.config.js configuration file. You can also refer to the configuration method in this file in my repository.

  4. Use the ip route | grep default | awk '{print $3}' command to view your IP address, assuming it's http://xxx.xx.xxx.x, then check the "LAN" corresponding HTTP port through the VPN client in your Windows environment, assuming it's yyyyy. Add the following content to your hardhat.config.js file:

    const { ProxyAgent, setGlobalDispatcher } = require("undici");
    const proxyAgent = new ProxyAgent("http://xxx.xx.xxx.x:yyyyy");
    setGlobalDispatcher(proxyAgent);
    
  5. Please note that you should not use the IP address and port in the aforementioned GitHub post, because everyone's VPN client and IP are different. The post also mentioned looking at the DNS server IP using cat /etc/resolv.conf and adding it to the configuration. But if you, like me, share the Windows proxy in the WSL2 environment, then your DNS is likely set by yourself, such as 8.8.8.8. So using the method I mentioned in the fourth point above is the safest. Also, don't forget to turn on options like "Allow LAN connections" in your VPN client. If your client doesn't have this option, you may need to switch to another one.

  6. Use the npx hardhat verify --network yourNetWork CONTRACT_ADDRESS command to verify the contract, or you can write an additional verification function in the deployment script, which will complete the verification immediately after deployment.

solidity #hardhat #ETH #etherscan #SmartContracts

hardhat Article's
30 articles in total
Favicon
How to deploy smart contracts using Foundry
Favicon
Node modules confusion??
Favicon
Simple Smart Contract and Hardhat
Favicon
Building Mystic Vault: A Step-by-Step Guide to Creating a Simple Ethereum DApp from Scratch ๐Ÿ”ฎโœจ ( 30 min )
Favicon
Building a Blockchain-Based Blog dApp with Hardhat: A Step-by-Step Guide
Favicon
Building a Decentralized Voting System with Solidity and Hardhat
Favicon
Ethereum Development: Foundry or Hardhat
Favicon
Full Stack Ethereum and Dapp Development. A comprehensive guide: 2024
Favicon
Roadmap to Blockchain Development: 2024
Favicon
A task vs a script in Hardhat
Favicon
Testing a solidity house-swap contract using HardHat and Typescript
Favicon
How to Change the Bytecode of an Already Deployed Smart Contract
Favicon
How to Fork Mainnet for Testing
Favicon
How to Add a New Pool to Uniswap V3
Favicon
Creating a house swap contract using Solidity and Hardhat
Favicon
Solution to the ConnectTimeoutError Encountered When Verifying Smart Contracts with Hardhat
Favicon
Verified Mainnet Polygon Contract
Favicon
Verify Your Smart Contract Code
Favicon
Programmatically Verifying Solidity Smart Contract Code with Hardhat
Favicon
Getting Started with Hardhat for Smart Contracts
Favicon
How Hardhat Simplifies Smart Contract Verification on Ethereum
Favicon
Hardhat vs Truffle: Which One Is the Best for Developing Ethereum dApps?
Favicon
Fix : TokenService Error: ChainId 0x539 is not supported :(
Favicon
How to mint tokens from the backend using Nest.js on Celo Alfajores network
Favicon
My first Solidity Smart Contract
Favicon
"Deploying a Blockchain Application Nextjs / Hardhat on Netlify: A Comprehensive Guide"
Favicon
How to convert Solidity JSON ABI to Human Readable ABI in Hardhat
Favicon
Optimize Your Gas Costs with eth-gas-reporter for Hardhat
Favicon
Introduction to EVM Smart Contract development
Favicon
Top Tools for Solidity Smart Contract Developers

Featured ones: