clean up deployment & add etherscan verification

Change-Id: Idd37f92c5ca61710bece77a473fad35af44ac8f9
This commit is contained in:
valentin 2021-07-20 19:59:56 +02:00 committed by Valentin Von Albrecht
parent d7b6281492
commit 58fd2bcbcb
6 changed files with 141 additions and 506 deletions

12
ethereum/.env.template Normal file
View File

@ -0,0 +1,12 @@
# Network Config
MNEMONIC=
INFURA_KEY=
# Verification
ETHERSCAN_KEY=
# Migrations # Example Format
INIT_SIGNERS= # ["0x0000000000000000000000000000000000000000"]
INIT_CHAIN_ID= # 0x2
INIT_GOV_CHAIN_ID= # 0x3
INIT_GOV_CONTRACT= # 0x000000000000000000000000000000000000000000000000000000000000000

5
ethereum/.env.test Normal file
View File

@ -0,0 +1,5 @@
# Migrations
INIT_SIGNERS=["0xbeFA429d57cD18b7F8A4d91A2da9AB4AF05d0FBe"]
INIT_CHAIN_ID=0x2
INIT_GOV_CHAIN_ID=0x3
INIT_GOV_CONTRACT=0x0000000000000000000000000000000000000000000000000000000000000004

View File

@ -1,13 +1,13 @@
require('dotenv').config({ path: "../.env" });
const Implementation = artifacts.require("Implementation"); const Implementation = artifacts.require("Implementation");
const Wormhole = artifacts.require("Wormhole"); const Wormhole = artifacts.require("Wormhole");
const initialSigners = [ // CONFIG
// testSigner 1 & 2 const initialSigners = JSON.parse(process.env.INIT_SIGNERS);
"0xbeFA429d57cD18b7F8A4d91A2da9AB4AF05d0FBe", const chainId = process.env.INIT_CHAIN_ID;
] const governanceChainId = process.env.INIT_GOV_CHAIN_ID;
const chainId = "0x2"; const governanceContract = process.env.INIT_GOV_CONTRACT; // bytes32
const governanceChainId = "0x3";
const governanceContract = "0x0000000000000000000000000000000000000000000000000000000000000004"; // bytes32
module.exports = async function (deployer) { module.exports = async function (deployer) {
// deploy implementation // deploy implementation

File diff suppressed because it is too large Load Diff

View File

@ -13,7 +13,8 @@
"chai": "^4.2.0", "chai": "^4.2.0",
"mocha": "^8.2.1", "mocha": "^8.2.1",
"truffle": "^5.3.6", "truffle": "^5.3.6",
"truffle-assertions": "^0.9.2" "truffle-assertions": "^0.9.2",
"truffle-plugin-verify": "^0.5.11"
}, },
"scripts": { "scripts": {
"build": "truffle compile", "build": "truffle compile",
@ -23,6 +24,7 @@
"author": "", "author": "",
"license": "ISC", "license": "ISC",
"dependencies": { "dependencies": {
"dotenv": "^10.0.0",
"elliptic": "^6.5.2", "elliptic": "^6.5.2",
"ganache-cli": "^6.12.1", "ganache-cli": "^6.12.1",
"jsonfile": "^4.0.0", "jsonfile": "^4.0.0",

View File

@ -1,88 +1,35 @@
/** require('dotenv').config({ path: ".env" });
* Use this file to configure your truffle project. It's seeded with some
* common settings for different networks and features like migrations,
* compilation and testing. Uncomment the ones you need or modify
* them to suit your project as necessary.
*
* More information about configuration can be found at:
*
* truffleframework.com/docs/advanced/configuration
*
* To deploy via Infura you'll need a wallet provider (like @truffle/hdwallet-provider)
* to sign your transactions before they're sent to a remote public node. Infura accounts
* are available for free at: infura.io/register.
*
* You'll also need a mnemonic - the twelve word phrase the wallet uses to generate
* public/private key pairs. If you're publishing your code to GitHub make sure you load this
* phrase from a file you've .gitignored so it doesn't accidentally become public.
*
*/
const HDWalletProvider = require('@truffle/hdwallet-provider'); const HDWalletProvider = require('@truffle/hdwallet-provider');
const infuraKey = "94aa97cf706648c49af56e080b0f1bc3";
let mnemonic = "own great grid romance once pilot draw chuckle network desert race dream";
module.exports = { module.exports = {
/**
* Networks define how you connect to your ethereum client and let you set the
* defaults web3 uses to send transactions. If you don't specify one truffle
* will spin up a development blockchain for you on port 9545 when you
* run `develop` or `test`. You can ask a truffle command to use a specific
* network from the command line, e.g
*
* $ truffle test --network <network-name>
*/
networks: { networks: {
// Useful for testing. The `development` name is special - truffle uses it by default
// if it's defined here and no other network is specified at the command line.
// You should run a client (like ganache-cli, geth or parity) in a separate terminal
// tab if you use this network and you must also set the `host`, `port` and `network_id`
// options below to some value.
//
development: { development: {
host: "127.0.0.1", // Localhost (default: none) host: "127.0.0.1",
port: 8545, // Standard Ethereum port (default: none) port: 8545,
network_id: "*", // Any network (default: none) network_id: "*",
}, },
// Another network with more advanced options...
// advanced: {
// port: 8777, // Custom port
// network_id: 1342, // Custom network
// gas: 8500000, // Gas sent with each transaction (default: ~6700000)
// gasPrice: 20000000000, // 20 gwei (in wei) (default: 100 gwei)
// from: <address>, // Account to send txs from (default: accounts[0])
// websockets: true // Enable EventEmitter interface for web3 (default: false)
// },
// Useful for deploying to a public network.
// NB: It's important to wrap the provider as a function.
rinkeby: { rinkeby: {
provider: () => new HDWalletProvider(mnemonic, `https://rinkeby.infura.io/v3/94aa97cf706648c49af56e080b0f1bc3`), provider: () => new HDWalletProvider(process.env.MNEMONIC, `https://rinkeby.infura.io/v3/`+process.env.INFURA_KEY),
network_id: 4, // Ropsten's id network_id: 4,
gas: 5500000, // Ropsten has a lower block limit than mainnet gas: 5500000,
confirmations: 2, // # of confs to wait between deployments. (default: 0) confirmations: 2,
timeoutBlocks: 200, // # of blocks before a deployment times out (minimum/default: 50) timeoutBlocks: 200,
skipDryRun: true // Skip dry run before migrations? (default: false for public nets ) skipDryRun: true
},
goerli: {
provider: () => {
return new HDWalletProvider(process.env.MNEMONIC, 'https://goerli.infura.io/v3/'+process.env.INFURA_KEY)
},
network_id: '5',
gas: 4465030,
gasPrice: 10000000000,
}, },
// Useful for private networks
// private: {
// provider: () => new HDWalletProvider(mnemonic, `https://network.io`),
// network_id: 2111, // This network is yours, in the cloud.
// production: true // Treats this network as if it was a public net. (default: false)
// }
}, },
// Set default mocha options here, use special reporters etc.
mocha: {
// timeout: 100000
},
// Configure your compilers
compilers: { compilers: {
solc: { solc: {
version: "0.8.4", // Fetch exact version from solc-bin (default: truffle's version) version: "0.8.4",
// docker: true, // Use "0.5.1" you've installed locally with docker (default: false) settings: {
settings: { // See the solidity docs for advice about optimization and evmVersion
optimizer: { optimizer: {
enabled: true, enabled: true,
runs: 200 runs: 200
@ -92,6 +39,11 @@ module.exports = {
}, },
plugins: [ plugins: [
"@chainsafe/truffle-plugin-abigen" "@chainsafe/truffle-plugin-abigen",
"truffle-plugin-verify"
], ],
api_keys: {
etherscan: process.env.ETHERSCAN_KEY
},
}; };