This hardhat template comes with some setup scripts, tasks and an example docker compose service to get contract development into your app quickly.
The idea is that it can be dropped into any frontend project using docker compose easily. Allowing you to quickly iterate on contract development and integration with your frontend.
Clone the repo into your project directory:
git clone https://github.com/abhishekpatel946/Hardhat-Crash-Course.git hardhatDeployed Token Address:
- TestToken
0x973Dc12Bd0496A4063A2b81EcE6A0979Ceb08e54- CrowdFunding
0x5FbDB2315678afecb367f032d93F642f64180aa3- SimpleAuction
0x5FbDB2315678afecb367f032d93F642f64180aa3Etherscan Contract Creation Hash:
- TestToken
https://ropsten.etherscan.io/tx/0x22efa4f6f758432fc1a4dd759f495fed4fbc73792e7f4f0b99204b542be591bf- CrowdFunding
https://ropsten.etherscan.io/tx/0xbaface72ab0d9b896f25b6471977210e46ff7ac0e136e7a4d8e3d88208eaf010- SimpleAuction
https://ropsten.etherscan.io/address/0x797c09A52D0Fb5412C207FF4D07E525d10692877Install all the dependencies
npm iRun the test for all contracts
npx hardhat testDeploy the contract in locally using hardhat network
npx hardhat run scripts/deploy.jsNote: Change the scripts/deploy.js and run the below command to deploy the specific contract.
Deploy the contract in testnet like: ropsten
npx hardhat run scripts/deploy.js --network ropstenAdd the following service to your docker-compose.yml:
hardhat:
build:
context: ./hardhat
dockerfile: Dockerfile.dev
restart: always
command: yarn run dev
volumes:
- ./hardhat:/app
- /app/node_modules
- ./<PATH_TO_FRONTEND_DIR>/contracts:/app/tmp/contracts
ports:
- 8545:8545Once the service has been started with docker-compose up you contracts will be deployed to the localhost:8545 RPC. When you save the contract files they will be redeployed.
When contracts are compiled and deployed the output files are saved to /deployments/<network> in the hardhat container. Mounting this folder to a volume in the service as we did above with - ./<PATH_TO_FRONTEND_DIR>/contracts:/app/deployments means that these contracts will then be available in your frontend directory under /contracts.
First add your credentials to the .env.example file and rename to .env.
To deploy to networks other than localhost you can run commands like:
docker-compose run hardhat mainnet:deployFor a full list of deployment commands for different networks see package.json.
There are a default tasks for interacting with the localhost network when it's up and running.
docker-compose exec hardhat accounts # fetch list of default network accounts
docker-compose exec hardhat balance <address> # Get balance for an address
docker-compose exec hardhat send --from <address> --to <address> --amount 10 # Send ETH from one address to another
docker-compose exec hardhat blockNumber # Get the current blocknumber