2024-03-06 16:50:59 -06:00
|
|
|
const { ethers } = require('hardhat');
|
2024-03-17 11:48:05 -05:00
|
|
|
const fs = require('fs');
|
|
|
|
|
2024-03-17 12:30:12 -05:00
|
|
|
const contractAddresses = require('contract-config/addresses.json');
|
2024-03-17 12:06:06 -05:00
|
|
|
|
2024-03-17 12:30:12 -05:00
|
|
|
const contractAddressesWritePath = '../contract-config/addresses.json';
|
2024-03-17 11:48:05 -05:00
|
|
|
const network = process.env.HARDHAT_NETWORK;
|
2024-03-04 19:33:06 -06:00
|
|
|
|
|
|
|
async function main() {
|
2024-03-06 16:50:59 -06:00
|
|
|
const dao = await ethers.deployContract('DAO');
|
|
|
|
await dao.waitForDeployment();
|
2024-03-04 19:33:06 -06:00
|
|
|
|
2024-03-06 16:50:59 -06:00
|
|
|
console.log(`DAO deployed to ${dao.target}`);
|
2024-03-17 11:48:05 -05:00
|
|
|
contractAddresses[network].DAO = dao.target;
|
2024-03-04 19:33:06 -06:00
|
|
|
|
2024-03-06 16:50:59 -06:00
|
|
|
const WORK1_PRICE = ethers.parseEther('0.001');
|
|
|
|
const work1 = await ethers.deployContract('Work1', [dao.target, WORK1_PRICE]);
|
|
|
|
await work1.waitForDeployment();
|
2024-03-04 19:33:06 -06:00
|
|
|
|
2024-03-06 16:50:59 -06:00
|
|
|
console.log(`Work1 deployed to ${work1.target}`);
|
2024-03-17 11:48:05 -05:00
|
|
|
contractAddresses[network].Work1 = work1.target;
|
|
|
|
|
2024-03-17 12:06:06 -05:00
|
|
|
fs.writeFileSync(contractAddressesWritePath, JSON.stringify(contractAddresses, null, 2));
|
|
|
|
console.log('Wrote file', fs.realpathSync(contractAddressesWritePath));
|
2024-03-17 12:30:12 -05:00
|
|
|
|
|
|
|
fs.copyFileSync('./artifacts/contracts/DAO.sol/DAO.json', '../contract-config/DAO.json');
|
|
|
|
fs.copyFileSync('./artifacts/contracts/Work1.sol/Work1.json', '../contract-config/Work1.json');
|
2024-03-04 19:33:06 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// We recommend this pattern to be able to use async/await everywhere
|
|
|
|
// and properly handle errors.
|
|
|
|
main().catch((error) => {
|
|
|
|
console.error(error);
|
|
|
|
process.exitCode = 1;
|
|
|
|
});
|