This repository has been archived by the owner on Jul 13, 2022. It is now read-only.
generated from NomicFoundation/hardhat-ts-plugin-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhardhat.config.ts
76 lines (67 loc) · 1.93 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
import '@nomiclabs/hardhat-etherscan';
import '@nomiclabs/hardhat-waffle';
import '@typechain/hardhat';
import 'hardhat-gas-reporter';
import 'solidity-coverage';
import '@nomiclabs/hardhat-ethers';
import 'hardhat-interact';
import '../hardhat-cannon/src/index';
import 'hardhat-interact';
import * as dotenv from 'dotenv';
import { HardhatUserConfig, task } from 'hardhat/config';
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);
}
});
const config: HardhatUserConfig = {
solidity: '0.8.4',
networks: {
hardhat: {
chainId: 31337,
},
local: {
url: 'http://127.0.0.1:8545/',
chainId: 31337,
},
ropsten: {
url: process.env.PROVIDER_URL || `https://ropsten.infura.io/v3/${process.env.INFURA_KEY}`,
chainId: 3,
accounts: process.env.PRIVATE_KEY?.split(','),
},
rinkeby: {
url: process.env.PROVIDER_URL || `https://rinkeby.infura.io/v3/${process.env.INFURA_KEY}`,
chainId: 4,
accounts: process.env.PRIVATE_KEY?.split(','),
},
mainnet: {
url: process.env.PROVIDER_URL || `https://mainnet.infura.io/v3/${process.env.INFURA_KEY}`,
chainId: 1,
},
},
gasReporter: {
enabled: process.env.REPORT_GAS !== undefined,
currency: 'USD',
},
etherscan: {
apiKey: process.env.ETHERSCAN_API_KEY,
},
cannon: {
publisherPrivateKey: process.env.PRIVATE_KEY,
ipfsConnection: {
protocol: 'https',
host: 'ipfs.infura.io',
port: 5001,
headers: {
authorization: `Basic ${Buffer.from(process.env.INFURA_IPFS_ID + ':' + process.env.INFURA_IPFS_SECRET).toString(
'base64'
)}`,
},
},
},
};
export default config;