forked from kcc-community/kcc-genesis-contracts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhardhat.config.ts
139 lines (108 loc) · 3.54 KB
/
hardhat.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
import * as dotenv from "dotenv";
import { HardhatUserConfig, task } from "hardhat/config";
import "@nomiclabs/hardhat-etherscan";
import "@nomiclabs/hardhat-waffle";
import "@typechain/hardhat";
import "hardhat-gas-reporter";
import "solidity-coverage";
import { BigNumber, utils} from "ethers"
import { fstatSync, mkdirSync, writeFileSync } from "fs";
import {join} from "path";
import keyethereum from "keythereum";
import {readFileSync} from 'fs';
import 'hardhat-storage-layout';
import {Md5} from 'ts-md5/dist/md5';
import fs from "fs";
dotenv.config();
// This is a sample Hardhat task. To learn how to create your own go to
// https://hardhat.org/guides/create-task.html
task("accounts", "Prints the list of accounts", async (taskArgs, hre) => {
const accounts = await hre.ethers.getSigners();
for (const account of accounts) {
console.log(account.address);
}
});
// Calculate md5sum of byte codes
task("md5sum", "Calculate the md5sum of byte codes", async(taskArgs,hre) => {
const files = [
"bin/proposal_deployed_code",
"bin/punish_deployed_code",
"bin/reservePool_deployed_code",
"bin/validators_deployed_code",
]
for(let i =0; i < files.length; ++i){
const bytes = utils.arrayify(fs.readFileSync(files[i],"utf8"));
const hex = (new Md5()).appendByteArray(bytes).end(false);
console.log(`${files[i]}: ${hex}`);
}
})
// task for generating abi.json
task("abi-gen", "Generate abi.json", async (taskArgs, hre) => {
// run compile task first
await hre.run("compile");
// create a directory called abi
const abiRootPath = join(hre.config.paths.root,"abi");
mkdirSync(abiRootPath,{recursive:true});
const exportedContracts =[ "Proposal", "Punish", "Validators", "ReservePool"];
for(let i = 0; i < exportedContracts.length; ++i){
const jsonFile = `${exportedContracts[i]}.json`;
console.log(`\x1b[33m generating ${jsonFile} \x1b[0m`);
writeFileSync(
join(abiRootPath,jsonFile),
JSON.stringify((await hre.artifacts.readArtifact(exportedContracts[i])).abi,null,2)
);
}
});
// helper function
// import a privatekey from a keystore json file
// FIXME: Looks like there are some bugs in the key derive fuction
function importKeyFromJsonFile(filePath:string, password:string): string{
const keyObject = JSON.parse(readFileSync(filePath).toString());
return (keyethereum as any).recover(password,keyObject).toString('hex');
}
// You need to export an object to set up your config
// Go to https://hardhat.org/config/ to learn more
const config: HardhatUserConfig = {
solidity: {
version: "0.6.12",
settings: {
optimizer: {
enabled: true,
runs: 200
},
outputSelection: {
"*": {
"*": ["storageLayout"],
},
},
}
},
networks: {
ropsten: {
url: process.env.ROPSTEN_URL || "",
accounts:
process.env.PRIVATE_KEY !== undefined ? [process.env.PRIVATE_KEY] : [],
},
hardhat:{
allowUnlimitedContractSize: true,
accounts:{
count: 100,
accountsBalance: BigNumber.from(10).pow(25).toString()
},
hardfork: "berlin", // kcc
chainId: 1337
},
devnet:{
url: process.env.DEVNET_RPC || "",
accounts : (process.env.DENET_PRIVATE_KEYS || "0xa3f5fbad1692c5b72802300aefb5b760364018018ddb5fe7589a2203d0d10e60").split(','),
},
},
gasReporter: {
enabled: process.env.REPORT_GAS !== undefined,
currency: "USD",
},
etherscan: {
apiKey: process.env.ETHERSCAN_API_KEY,
},
};
export default config;