-
Notifications
You must be signed in to change notification settings - Fork 10
/
truffle-config.js
123 lines (115 loc) · 4.86 KB
/
truffle-config.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
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
/**
* 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 API
* keys 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.
*
*/
/**
* Feel free to add here your own Truffle networks configuration.
*
* This Truffle Box comes with a series of preconfigured networks, under the assumption that suitable Web3 providers
* are locally available on different ports at localhost:XXXX.
*
* For example:
* - ethereum.mainnet → localhost:9545
* - ethereum.kovan → localhost:8542
* - ethereum.ropsten → localhost:8543
* - ethereum.rinkeby → localhost:8544
* - ethereum.goerli → localhost:8545
* - conflux.testnet → localhost:8540
* - conflux.tethys → localhost:9540
* - boba.rinkeby → localhost:8539
*
* For example, if you want to deploy to Ethereum mainnet, you will need an Ethereum mainnet node, an account-enabled
* Web3 gateway or an instance of ` @truffle/hdwallet-provider` running on localhost:9545.
*
* If you don't want to mess with any ot that, and prefer to configure an HDWalletProvider in the classic way, simply
* add your own configuration down below, inside the `manualNetworks` object.
*/
const manualNetworks = {
development: {
provider: require("ganache-cli").provider({ gasLimit: 100000000 }),
network_id: "*",
},
}
/**
* You shouldn't change anything below this line to preserve this Truffle Box's automatic handling of target realms,
* chains, networks, compiler versions, etc.
*
* If you want to configure anything related to networks, please customize the `manualNetworks` object above.
*
* Target realms (ethereum / boba / celo / conflux / etc.) are read from multiple possible sources, in this order:
* 1. `--network <realm>.<chain>` argument
* 2. `WITNET_EVM_REALM` environment variable
* 3. default (ethereum)
*/
const witnetSettings = require("./node_modules/witnet-ethereum-bridge/migrations/witnet.settings")
let realm = process.env.WITNET_EVM_REALM ? process.env.WITNET_EVM_REALM.toLowerCase() : "default"
const args = process.argv.join("=").split("=")
const networkIndex = args.indexOf("--network")
if (networkIndex >= 0) {
realm = (args[networkIndex + 1] || "default").split(".")[0]
}
console.info(`Configuring "${realm}" target realm...
==============================${"=".repeat(realm.length)}
> Default realm is "ethereum"
> Target realms and chains can be specified with "--network <realm>.<chain>"
> Available realms and chains can be found in "migrations/1_witnet_core.js"`)
// Use realm-specific compiler settings
const { merge } = require("lodash")
const compilers = merge(witnetSettings.compilers.default, witnetSettings.compilers[realm])
// Make sure that all configured networks are prefixed with a valid realm
const supportedNetworks = Object.entries(witnetSettings.networks).reduce((acc, [realmKey, realmVal]) => {
let realmEmit
if (realmKey === "default") {
realmEmit = realmVal
} else {
realmEmit = Object.entries(realmVal).reduce((acc, [netKey, netVal]) => {
let netEmit
if (netKey.includes(realmKey)) {
netEmit = { [netKey]: netVal }
} else {
netEmit = { [`${realmKey}.${netKey}`]: netVal }
}
return { ...acc, ...netEmit }
}, {})
}
return { ...acc, ...realmEmit }
}, 0)
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: {
...supportedNetworks,
...manualNetworks,
},
// The `solc` compiler is set to optimize output bytecode with 200 runs, which is the standard these days
compilers,
// This plugin allows to verify the source code of your contracts on Etherscan with this command:
// ETHERSCAN_API_KEY=<your_etherscan_api_key> truffle run verify <contract_name> --network <network_name>
plugins: [],
// This is just for the `truffle-plugin-verify` to catch the API key
api_keys: {
etherscan: process.env.ETHERSCAN_API_KEY,
},
}