truffle-config.js 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. require('dotenv').config()
  2. const HDWalletProvider = require('truffle-hdwallet-provider')
  3. const utils = require('web3-utils')
  4. // const infuraKey = "fj4jll3k.....";
  5. //
  6. // const fs = require('fs');
  7. // const mnemonic = fs.readFileSync(".secret").toString().trim();
  8. module.exports = {
  9. /**
  10. * Networks define how you connect to your ethereum client and let you set the
  11. * defaults web3 uses to send transactions. If you don't specify one truffle
  12. * will spin up a development blockchain for you on port 9545 when you
  13. * run `develop` or `test`. You can ask a truffle command to use a specific
  14. * network from the command line, e.g
  15. *
  16. * $ truffle test --network <network-name>
  17. */
  18. networks: {
  19. // Useful for testing. The `development` name is special - truffle uses it by default
  20. // if it's defined here and no other network is specified at the command line.
  21. // You should run a client (like ganache-cli, geth or parity) in a separate terminal
  22. // tab if you use this network and you must also set the `host`, `port` and `network_id`
  23. // options below to some value.
  24. development: {
  25. host: '127.0.0.1', // Localhost (default: none)
  26. port: 8545, // Standard Ethereum port (default: none)
  27. network_id: '*', // Any network (default: none)
  28. },
  29. // Another network with more advanced options...
  30. // advanced: {
  31. // port: 8777, // Custom port
  32. // network_id: 1342, // Custom network
  33. // gas: 8500000, // Gas sent with each transaction (default: ~6700000)
  34. // gasPrice: 20000000000, // 20 gwei (in wei) (default: 100 gwei)
  35. // from: <address>, // Account to send txs from (default: accounts[0])
  36. // websockets: true // Enable EventEmitter interface for web3 (default: false)
  37. // },
  38. // Useful for deploying to a public network.
  39. // NB: It's important to wrap the provider as a function.
  40. kovan: {
  41. provider: () => new HDWalletProvider(process.env.PRIVATE_KEY, 'https://kovan.infura.io/v3/c7463beadf2144e68646ff049917b716'),
  42. network_id: 42,
  43. gas: 6000000,
  44. gasPrice: utils.toWei('1', 'gwei'),
  45. // confirmations: 0,
  46. // timeoutBlocks: 200,
  47. skipDryRun: true
  48. },
  49. mainnet: {
  50. provider: () => new HDWalletProvider(process.env.PRIVATE_KEY, 'http://ethereum-rpc.trustwalletapp.com'),
  51. network_id: 1,
  52. gas: 6000000,
  53. gasPrice: utils.toWei('2', 'gwei'),
  54. // confirmations: 0,
  55. // timeoutBlocks: 200,
  56. skipDryRun: true
  57. },
  58. // Useful for private networks
  59. // private: {
  60. // provider: () => new HDWalletProvider(mnemonic, `https://network.io`),
  61. // network_id: 2111, // This network is yours, in the cloud.
  62. // production: true // Treats this network as if it was a public net. (default: false)
  63. // }
  64. },
  65. // Set default mocha options here, use special reporters etc.
  66. mocha: {
  67. // timeout: 100000
  68. },
  69. // Configure your compilers
  70. compilers: {
  71. solc: {
  72. version: '0.5.11', // Fetch exact version from solc-bin (default: truffle's version)
  73. // docker: true, // Use "0.5.1" you've installed locally with docker (default: false)
  74. settings: { // See the solidity docs for advice about optimization and evmVersion
  75. optimizer: {
  76. enabled: true,
  77. runs: 200
  78. },
  79. // evmVersion: "byzantium"
  80. }
  81. }
  82. }
  83. }