meritocracy/config/contracts.js
2019-03-21 19:21:05 -04:00

186 lines
6.0 KiB
JavaScript

const options = require("../app/js/contributors");
function getContributors () {
var addresses = options.map(a => "'"+ a.value + "'");
if ( new Set(addresses).size !== addresses.length ) {
throw 'duplicates in options';
}
return addresses;
}
module.exports = {
// default applies to all environments
default: {
// Blockchain node to deploy the contracts
deployment: {
host: "localhost", // Host of the blockchain node
port: 8546, // Port of the blockchain node
type: "ws" // Type of connection (ws or rpc),
// Accounts to use instead of the default account to populate your wallet
// The order here corresponds to the order of `web3.eth.getAccounts`, so the first one is the `defaultAccount`
/*,accounts: [
{
privateKey: "your_private_key",
balance: "5 ether" // You can set the balance of the account in the dev environment
// Balances are in Wei, but you can specify the unit with its name
},
{
privateKeyFile: "path/to/file", // Either a keystore or a list of keys, separated by , or ;
password: "passwordForTheKeystore" // Needed to decrypt the keystore file
},
{
mnemonic: "12 word mnemonic",
addressIndex: "0", // Optionnal. The index to start getting the address
numAddresses: "1", // Optionnal. The number of addresses to get
hdpath: "m/44'/60'/0'/0/" // Optionnal. HD derivation path
},
{
"nodeAccounts": true // Uses the Ethereum node's accounts
}
]*/
},
// order of connections the dapp should connect to
dappConnection: [
"$WEB3", // uses pre existing web3 object if available (e.g in Mist)
"ws://localhost:8546",
"http://localhost:8545"
],
// Automatically call `ethereum.enable` if true.
// If false, the following code must run before sending any transaction: `await EmbarkJS.enableEthereum();`
// Default value is true.
// dappAutoEnable: true,
gas: "auto",
// Strategy for the deployment of the contracts:
// - implicit will try to deploy all the contracts located inside the contracts directory
// or the directory configured for the location of the contracts. This is default one
// when not specified
// - explicit will only attempt to deploy the contracts that are explicity specified inside the
// contracts section.
//strategy: 'implicit',
strategy: 'explicit',
contracts: {
"MiniMeToken": { "deploy": false },
"MiniMeTokenFactory": {
},
"SNT": {
"instanceOf": "MiniMeToken",
"args": [
"$MiniMeTokenFactory",
"0x0000000000000000000000000000000000000000",
0,
"TestMiniMeToken",
18,
"STT",
true
]
},
"Meritocracy": {
"args": [ "$SNT", 66]
}
}
},
// default environment, merges with the settings in default
// assumed to be the intended environment by `embark run`
development: {
dappConnection: [
"$WEB3", // uses pre existing web3 object if available (e.g in Mist)
"ws://localhost:8546",
"http://localhost:8545",
],
deployment: {
// The order here corresponds to the order of `web3.eth.getAccounts`, so the first one is the `defaultAccount`
accounts: [
{
nodeAccounts: true
},
{
mnemonic: "foster gesture flock merge beach plate dish view friend leave drink valley shield list enemy",
balance: "5 ether",
numAddresses: "10"
}
]
},
"afterDeploy": [
// Give Tokens to Meritocracy Owner
"SNT.methods.generateTokens('$accounts[0]', '1000000000000000000000').send()",
// Add All Contributors
"Meritocracy.methods.addContributors([" + getContributors().toString() + "]).send()",
// Allocate Owner Tokens
"SNT.methods.approve('$Meritocracy', '1000000000000000000000').send()",
"Meritocracy.methods.allocate('1000000000000000000000').send()",
]
},
// merges with the settings in default
// used with "embark run privatenet"
privatenet: {
},
// merges with the settings in default
// used with "embark run testnet"
testnet: {
contracts: {
"MiniMeToken": { "deploy": false },
"MiniMeTokenFactory": {
"address": "0x6bfa86a71a7dbc68566d5c741f416e3009804279"
},
"SNT": {
"address": "0xc55cF4B03948D7EBc8b9E8BAD92643703811d162"
},
"Meritocracy": {
"address": "0xf40f9418D8236f373eB27f91Cc1a01739EB8c301"
}
},
deployment: {
accounts: [{
mnemonic: "your ropsten mnemonic here",
numAddresses: "10"
}]
},
"afterDeploy": [
// Add All Contributors
// "Meritocracy.methods.addContributors([" + getContributors().toString() + "]).send()",
]
},
// merges with the settings in default
// used with "embark run livenet"
livenet: {
contracts: {
"MiniMeToken": { "deploy": false },
"MiniMeTokenFactory": {
"address": "0xa1c957c0210397d2d0296341627b74411756d476"
},
"SNT": {
"address": "0x744d70fdbe2ba4cf95131626614a1763df805b9e"
},
"Meritocracy": {
"address": "0x3d8ec98c08b55ec42310aace562e077d784591d6"
}
},
deployment: {
accounts: [{
mnemonic: "your mainnet mnemonic here",
numAddresses: "10"
}]
},
"afterDeploy": [
// Add All Contributors
// "Meritocracy.methods.addContributors([" + getContributors().toString() + "]).send()",
]
},
// you can name an environment with specific settings and then specify with
// "embark run custom_name" or "embark blockchain custom_name"
//custom_name: {
//}
};