-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdeploy-AdvancedERC20_Impl.js
72 lines (63 loc) · 2.93 KB
/
deploy-AdvancedERC20_Impl.js
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
// deploy: npx hardhat deploy --network sepolia --tags AdvancedERC20_Impl
// verify: npx hardhat etherscan-verify --network sepolia --api-key $ETHERSCAN_KEY
// script is built for hardhat-deploy plugin:
// A Hardhat Plugin For Replicable Deployments And Easy Testing
// https://www.npmjs.com/package/hardhat-deploy
// Zeppelin test helpers
const {
BN,
constants,
expectEvent,
expectRevert,
} = require("@lazy-sol/zeppelin-test-helpers");
const {
ZERO_ADDRESS,
ZERO_BYTES32,
MAX_UINT256,
} = constants;
// deployment utils (contract state printers)
const {
print_amt,
print_contract_details,
} = require("@lazy-sol/a-missing-gem");
// to be picked up and executed by hardhat-deploy plugin
module.exports = async function({deployments, getChainId, getNamedAccounts, getUnnamedAccounts}) {
// print some useful info on the account we're using for the deployment
const chainId = await getChainId();
const accounts = await web3.eth.getAccounts();
// do not use the default account for tests
const A0 = network.name === "hardhat"? accounts[1]: accounts[0];
const nonce = await web3.eth.getTransactionCount(A0);
const balance = await web3.eth.getBalance(A0);
// print initial debug information
console.log("script: %o", require("path").basename(__filename));
console.log("network %o %o", chainId, network.name);
console.log("accounts: %o, service account %o, nonce: %o, balance: %o ETH", accounts.length, A0, nonce, print_amt(balance));
// AdvancedERC20_Impl – to be used in Token Factory as impl contract
{
// deploy if required
await deployments.deploy("AdvancedERC20_Impl", {
// address (or private key) that will perform the transaction.
// you can use `getNamedAccounts` to retrieve the address you want by name.
from: A0,
contract: "AdvancedERC20",
// the list of argument for the constructor (or the upgrade function in case of proxy)
args: [ZERO_ADDRESS, "implementation contract, not for use", "N/A", ZERO_ADDRESS, 0, 0],
// if set it to true, will not attempt to deploy even if the contract deployed under the same name is different
skipIfAlreadyDeployed: true,
// if true, it will log the result of the deployment (tx hash, address and gas used)
log: true,
});
// get deployment details
const deployment = await deployments.get("AdvancedERC20_Impl");
const contract = new web3.eth.Contract(deployment.abi, deployment.address);
// print deployment details
await print_contract_details(A0, deployment.abi, deployment.address);
}
};
// Tags represent what the deployment script acts on. In general, it will be a single string value,
// the name of the contract it deploys or modifies.
// Then if another deploy script has such tag as a dependency, then when the latter deploy script has a specific tag
// and that tag is requested, the dependency will be executed first.
// https://www.npmjs.com/package/hardhat-deploy#deploy-scripts-tags-and-dependencies
module.exports.tags = ["AdvancedERC20_Impl", "deploy", "v1_0"];