From c0c8dedc5f9b72fee2ea36492bb55ce9ccdbe322 Mon Sep 17 00:00:00 2001 From: Matias Romeo Date: Wed, 15 Nov 2023 12:01:26 -0300 Subject: [PATCH] Add launch scripts --- scripts/.env-sample | 14 +++ scripts/start-evm-node.sh | 78 ++++++++++++ scripts/start-evm-runtime.sh | 40 ++++++ tests/nodeos_eos_evm_server.py | 216 +++++++++++++++++++++------------ 4 files changed, 270 insertions(+), 78 deletions(-) create mode 100644 scripts/.env-sample create mode 100755 scripts/start-evm-node.sh create mode 100755 scripts/start-evm-runtime.sh diff --git a/scripts/.env-sample b/scripts/.env-sample new file mode 100644 index 0000000..e44392d --- /dev/null +++ b/scripts/.env-sample @@ -0,0 +1,14 @@ +CORE_SYMBOL_NAME=EOS +EVM_CONTRACT_ROOT=/path/to/eos-evm-contract +LEAP_ROOT=/path/to/leap-4 +EVM_BRIDGE_ROOT=/path/to/evm-bridge-contracts +EVM_NODE_ROOT=/path/to/eos-evm-node +WEB3_RPC_ENDPOINT=http://localhost:5000 +NODEOS_RPC_ENDPOINT=http://localhost:8889 +POLL_INTERVAL=500 +WS_LISTENING_PORT=3333 +WS_LISTENING_HOST=localhost +MAX_LOGS_SUBS_PER_CONNECTION=1 +MAX_MINEDTX_SUBS_PER_CONNECTION=1 +LOG_LEVEL=debug +GENESIS_JSON=eos-evm-genesis.json diff --git a/scripts/start-evm-node.sh b/scripts/start-evm-node.sh new file mode 100755 index 0000000..ea2993a --- /dev/null +++ b/scripts/start-evm-node.sh @@ -0,0 +1,78 @@ +#!/bin/bash +if [ ! -f .env ]; then + echo ".env file not found" + exit 1 +fi + +source .env +trap "kill 0" SIGINT + +CLEAN=0 +if [ "$1" == "--clean" ]; then + CLEAN=1 +fi + +if [ $CLEAN -eq 1 ]; then + rm -rf data-evm-node +fi + +mkdir -p data-evm-node/snapshots + +if [ ! -f $EVM_NODE_ROOT/build/src/eos-evm-node ]; then + echo $EVM_NODE_ROOT/build/src/eos-evm-node not found + exit 1 +fi + +if [ ! -f $EVM_NODE_ROOT/build/src/eos-evm-rpc ]; then + echo $EVM_NODE_ROOT/build/src/eos-evm-rpc not found + exit 1 +fi + +if [ ! -f $EVM_NODE_ROOT/peripherals/eos-evm-ws-proxy/main.js ]; then + echo $EVM_NODE_ROOT/peripherals/eos-evm-ws-proxy/main.js not found + exit 1 +fi + +if [ ! -f eos-evm-genesis.json ]; then + echo "Waiting for eos-evm-genesis.json ..." + while [ ! -f eos-evm-genesis.json ]; do + sleep 1 + done +fi + +echo "Launching EOS EVM Node" +$EVM_NODE_ROOT/build/src/eos-evm-node \ + --plugin=blockchain_plugin \ + --ship-endpoint=127.0.0.1:8999 \ + --genesis-json=eos-evm-genesis.json \ + --ship-core-account=eosio.evm \ + --chain-data=data-evm-node \ + --ship-max-retry=1000000 \ + --ship-delay-second=2 \ + --stdout=1 \ + --nocolor=1 \ + --verbosity=5 > node.log & + +sleep 2 + +echo "Launching EOS EVM Rpc" +$EVM_NODE_ROOT/build/src/eos-evm-rpc \ + --eos-evm-node=127.0.0.1:8080 \ + --http-port=0.0.0.0:8881 \ + --chaindata=data-evm-node \ + --stdout=1 \ + --nocolor=1 \ + --verbosity=10 \ + --api-spec=eth,debug,net,trace > rpc.log & + +sleep 2 + +echo "Launching EOS EVM WS proxy" +if [ ! -d "node_modules" ]; then + cp $EVM_NODE_ROOT/peripherals/eos-evm-ws-proxy/package.json . + npm install +fi + +node $EVM_NODE_ROOT/peripherals/eos-evm-ws-proxy/main.js > ws.log & + +wait diff --git a/scripts/start-evm-runtime.sh b/scripts/start-evm-runtime.sh new file mode 100755 index 0000000..6ed758a --- /dev/null +++ b/scripts/start-evm-runtime.sh @@ -0,0 +1,40 @@ +#!/bin/bash +if [ ! -f .env ]; then + echo ".env file not found" + exit 1 +fi + +source .env + +# check required files / folder +if [ ! -d $LEAP_ROOT/build/tests/TestHarness ]; then + echo $LEAP_ROOT/build/tests/TestHarness not found + exit 1 +fi + +if [[ ! -f "$EVM_CONTRACT_ROOT/build/evm_runtime/evm_runtime.wasm" || ! -f "$EVM_CONTRACT_ROOT/build/evm_runtime/evm_runtime.abi" ]]; then + echo $EVM_CONTRACT_ROOT/build/evm_runtime/evm_runtime wasm/abi not found + exit 1 +fi + +if [[ "$CORE_SYMBOL_NAME" != "EOS" ]]; then + echo "CORE_SYMBOL_NAME is not 'EOS' (warning)" +fi + +CLEAN=0 +if [ "$1" == "--clean" ]; then + CLEAN=1 +fi + +if [ $CLEAN -eq 1 ]; then + rm -rf venv +fi + +if [ ! -d "venv" ]; then + python3 -m venv venv + ./venv/bin/pip install web3 flask flask_cors + ln -s $LEAP_ROOT/build/tests/TestHarness venv/lib/python3.10/site-packages/TestHarness +fi + +CORE_SYMBOL_NAME=$CORE_SYMBOL_NAME ./venv/bin/python3 $EVM_NODE_ROOT/tests/nodeos_eos_evm_server.py --eos-evm-contract-root $EVM_CONTRACT_ROOT/build --eos-evm-bridge-contracts-root $EVM_BRIDGE_ROOT/build +mv eos-evm-genesis.json eos-evm-genesis.json.last &> /dev/null diff --git a/tests/nodeos_eos_evm_server.py b/tests/nodeos_eos_evm_server.py index 60981d7..585804b 100755 --- a/tests/nodeos_eos_evm_server.py +++ b/tests/nodeos_eos_evm_server.py @@ -7,6 +7,7 @@ import signal import calendar from datetime import datetime +import tempfile from flask import Flask, request, jsonify from flask_cors import CORS @@ -64,6 +65,7 @@ appArgs=AppArgs() appArgs.add(flag="--eos-evm-contract-root", type=str, help="EOS EVM Contract build dir", default=None) +appArgs.add(flag="--eos-evm-bridge-contracts-root", type=str, help="EOS EVM Bridge contracts build dir", default=None) appArgs.add(flag="--genesis-json", type=str, help="File to save generated genesis json", default="eos-evm-genesis.json") appArgs.add(flag="--read-endpoint", type=str, help="EVM read endpoint (eos-evm-rpc)", default="http://localhost:8881") appArgs.add(flag="--use-eos-vm-oc", type=bool, help="EOS EVM Contract build dir", default=False) @@ -75,6 +77,7 @@ keepLogs=args.keep_logs killAll=args.clean_run eosEvmContractRoot=args.eos_evm_contract_root +eosEvmBridgeContractsRoot=args.eos_evm_bridge_contracts_root gensisJson=args.genesis_json readEndpoint=args.read_endpoint useEosVmOC=args.use_eos_vm_oc @@ -114,7 +117,7 @@ specificExtraNodeosArgs[1]="--plugin eosio::state_history_plugin --state-history-endpoint 127.0.0.1:8999 --trace-history --chain-state-history --disable-replay-opts " # producer nodes will be mapped to 0 through totalProducerNodes-1, so the number totalProducerNodes will be the non-producing node specificExtraNodeosArgs[totalProducerNodes]="--plugin eosio::test_control_api_plugin " - extraNodeosArgs="--contracts-console" + extraNodeosArgs="--contracts-console --resource-monitor-not-shutdown-on-threshold-exceeded" if useEosVmOC: extraNodeosArgs += " --wasm-runtime eos-vm-jit --eos-vm-oc-enable" @@ -139,7 +142,11 @@ prodNode1 = cluster.getNode(1) nonProdNode = cluster.getNode(2) - accounts=cluster.createAccountKeys(6) + total_accounts_to_create = 6 + if eosEvmBridgeContractsRoot: + total_accounts_to_create += 3 + + accounts=cluster.createAccountKeys(total_accounts_to_create) if accounts is None: Utils.errorExit("FAILURE - create keys") @@ -147,16 +154,34 @@ evmAcc.name = "eosio.evm" evmAcc.activePrivateKey="5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3" evmAcc.activePublicKey="EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV" + accounts[1].name="tester111111" # needed for voting accounts[2].name="tester222222" # needed for voting accounts[3].name="tester333333" # needed for voting accounts[4].name="tester444444" # needed for voting accounts[5].name="tester555555" # needed for voting - testWalletName="test" + if eosEvmBridgeContractsRoot: + evmIn = accounts[6] + evmIn.name = "eosio.evmin" + evmIn.activePrivateKey="5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3" + evmIn.activePublicKey="EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV" + + evmErc20 = accounts[7] + evmErc20.name = "eosio.erc2o" + evmErc20.activePrivateKey="5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3" + evmErc20.activePublicKey="EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV" + simpleToken = accounts[8] + simpleToken.name = "simpletoken" + simpleToken.activePrivateKey="5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3" + simpleToken.activePublicKey="EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV" + + testWalletName="test" Print("Creating wallet \"%s\"." % (testWalletName)) - testWallet=walletMgr.create(testWalletName, [cluster.eosioAccount,accounts[0],accounts[1],accounts[2],accounts[3],accounts[4],accounts[5]]) + tmp=[cluster.eosioAccount,accounts[0],accounts[1],accounts[2],accounts[3],accounts[4],accounts[5]] + if eosEvmBridgeContractsRoot: tmp += [accounts[6],accounts[7],accounts[8]] + testWallet=walletMgr.create(testWalletName, tmp) for _, account in cluster.defProducerAccounts.items(): walletMgr.importKey(account, testWallet, ignoreDupKeyWarning=True) @@ -176,7 +201,7 @@ Print("Create new account %s via %s with private key: %s" % (account.name, cluster.eosioAccount.name, account.activePrivateKey)) trans=nonProdNode.createInitializeAccount(account, cluster.eosioAccount, stakedDeposit=0, waitForTransBlock=True, stakeNet=10000, stakeCPU=10000, buyRAM=10000000, exitOnError=True) # max supply 1000000000.0000 (1 Billion) - transferAmount="100000000.0000 {0}".format(CORE_SYMBOL) + transferAmount="50000000.0000 {0}".format(CORE_SYMBOL) Print("Transfer funds %s from account %s to %s" % (transferAmount, cluster.eosioAccount.name, account.name)) nonProdNode.transferFunds(cluster.eosioAccount, account, transferAmount, "test transfer", waitForTransBlock=True) trans=nonProdNode.delegatebw(account, 20000000.0000, 20000000.0000, waitForTransBlock=False, exitOnError=True) @@ -246,6 +271,110 @@ "timestamp": hex(int(calendar.timegm(datetime.strptime(block["timestamp"].split(".")[0], '%Y-%m-%dT%H:%M:%S').timetuple()))) } + if eosEvmBridgeContractsRoot: + Utils.Print("Set eosio.evm as privileged account") + trans=prodNode.pushMessage("eosio", "setpriv", json.dumps({"account":"eosio.evm", "is_priv":1}), '-p eosio@active') + + Utils.Print("Set eosio.erc2o as privileged account") + trans=prodNode.pushMessage("eosio", "setpriv", json.dumps({"account":"eosio.erc2o", "is_priv":1}), '-p eosio@active') + + Utils.Print("Set eosio.evmin as privileged account") + trans=prodNode.pushMessage("eosio", "setpriv", json.dumps({"account":"eosio.evmin", "is_priv":1}), '-p eosio@active') + + # Open eosio.erc2o balance on eosio.evm + Utils.Print("Open eosio.erc2o balance in eosio.evm") + data="{\"owner\": \"eosio.erc2o\"}" + trans=prodNode.pushMessage("eosio.evm", "open", data, '-p eosio.erc2o@active') + prodNode.waitForTransBlockIfNeeded(trans[1], True) + + Utils.Print("Voy a transfer 100 EOS") + # Fund with 100.0000 EOS eosio.erc2o + data={"from":"eosio.erc2o", "to":"eosio.evm", "quantity":"100.0000 {0}".format(CORE_SYMBOL), "memo":"eosio.erc2o"} + trans=prodNode.pushMessage("eosio.token", "transfer", json.dumps(data), '-p eosio.erc2o@active') + + Utils.Print("Set Code") + # Set eosio.evmin code + contractDir=eosEvmBridgeContractsRoot + "/antelope_contracts/contracts/deposit_proxy" + wasmFile="deposit_proxy.wasm" + tempabi = tempfile.NamedTemporaryFile(delete=True) + tempabi.write(b"{}") + tempabi.flush() + abiFile=tempabi.name + Utils.Print("Publish deposit_proxy contract") + prodNode.publishContract(evmIn, contractDir, wasmFile, abiFile, waitForTransBlock=True) + tempabi.close() + + # add eosio.code permission + cmd="set account permission eosio.evmin active --add-code -p eosio.evmin@active" + prodNode.processCleosCmd(cmd, cmd, silentErrors=True, returnType=ReturnType.raw) + + # Set eosio.erc2o code + contractDir=eosEvmBridgeContractsRoot + "/antelope_contracts/contracts/erc20" + wasmFile="erc20.wasm" + abiFile="erc20.abi" + Utils.Print("Publish erc20 contract") + prodNode.publishContract(evmErc20, contractDir, wasmFile, abiFile, waitForTransBlock=True) + + # add eosio.code permission + cmd="set account permission eosio.erc2o active --add-code -p eosio.erc2o@active" + prodNode.processCleosCmd(cmd, cmd, silentErrors=True, returnType=ReturnType.raw) + + # Call upgradeto + Utils.Print("Call upgradeto on eosio.erc2o") + #data="{\"impl_address\": \"0x8ac75488C3B376e13d36CcA6110f985bb65A23c2\"}" + data="{}" + opts="-p eosio.erc2o@active" + trans=prodNode.pushMessage("eosio.erc2o", "upgrade", data, opts) + prodNode.waitForTransBlockIfNeeded(trans[1], True) + + # Publish simple token + contract="eosio.token" + contractDir=str(cluster.unittestsContractsPath / contract) + wasmFile="%s.wasm" % (contract) + abiFile="%s.abi" % (contract) + Utils.Print("Publish simple contract token") + prodNode.publishContract(simpleToken, contractDir, wasmFile, abiFile, waitForTransBlock=True) + + # Create SIM token + contract=simpleToken.name + Utils.Print("Create SIM token") + action="create" + data="{\"issuer\":\"%s\",\"maximum_supply\":\"1000000000.0000 %s\"}" % (simpleToken.name, "SIM") + opts="--permission %s@active" % (simpleToken.name) + trans=prodNode.pushMessage(contract, action, data, opts) + prodNode.waitForTransBlockIfNeeded(trans[1], True) + + #Issue SIM token + Utils.Print("Issue SIM token") + action="issue" + data="{\"to\":\"%s\",\"quantity\":\"1000000000.0000 %s\",\"memo\":\"initial issue\"}" % (simpleToken.name, "SIM") + opts="--permission %s@active" % (simpleToken.name) + trans=prodNode.pushMessage(contract, action, data, opts) + prodNode.waitForTransBlockIfNeeded(trans[1], True) + + # Register eosio.erc2o in trustless bridge + contract="eosio.evm" + Utils.Print("Register eosio.erc2o") + action="bridgereg" + data="{\"handler\": \"eosio.erc2o\", \"min_fee\": \"0.0100 %s\", \"receiver\": \"eosio.erc2o\"}" % CORE_SYMBOL + opts="-p eosio.evm@active -p eosio.erc2o@active" + trans=prodNode.pushMessage(contract, action, data, opts) + prodNode.waitForTransBlockIfNeeded(trans[1], True) + + # Call regtoken on eosio.erc2o + Utils.Print("Register SIM token on eosio.erc2o") + data="{\"egress_fee\": \"0.0100 %s\", \"eos_contract_name\": \"simpletoken\", \"erc20_precision\": 6, \"evm_token_name\": \"SIM\", \"evm_token_symbol\": \"SIM\", \"ingress_fee\": \"0.0100 SIM\"}" % CORE_SYMBOL + opts="-p eosio.erc2o@active" + trans=prodNode.pushMessage("eosio.erc2o", "regtoken", data, opts) + prodNode.waitForTransBlockIfNeeded(trans[1], True) + Utils.Print("SE CAE?") + + # Add egress account + Utils.Print("Add egress accounts on eosio.erc2o") + data="{\"accounts\": [\"binancecleos\",\"huobideposit\",\"okbtothemoon\"]}" + opts="-p eosio.erc2o@active" + trans=prodNode.pushMessage("eosio.erc2o", "addegress", data, opts) + Utils.Print("Send small balance to special balance to allow the bridge to work") transferAmount="1.0000 {0}".format(CORE_SYMBOL) Print("Transfer funds %s from account %s to %s" % (transferAmount, cluster.eosioAccount.name, evmAcc.name)) @@ -255,7 +384,7 @@ # mnemonic: "test test test test test test test test test test test junk", # path: "m/44'/60'/0'/0", # initialIndex: 0, - # count: 20, + # count: 10, # passphrase: "", # } @@ -270,82 +399,12 @@ "0x14dC79964da2C08b23698B3D3cc7Ca32193d9955":"0x0201f2bf1fa920e77a43c7aec2587d0b3814093420cc59a9b3ad66dd5734dda7be,0x4bbbf85ce3377467afe5d46f804f221813b2bb87f24d81f60f1fcdbf7cbf4356", "0x23618e81E3f5cdF7f54C3d65f7FBc0aBf5B21E8f":"0x03931e7fda8da226f799f791eefc9afebcd7ae2b1b19a03c5eaa8d72122d9fe74d,0xdbda1821b80551c9d65939329250298aa3472ba22feea921c0cf5d620ea67b97", "0xa0Ee7A142d267C1f36714E4a8F75612F20a79720":"0x023255458e24278e31d5940f304b16300fdff3f6efd3e2a030b5818310ac67af45,0x2a871d0798f97d79848a013d4936a73bf4cc922c825d33c1cf7073dff6d409c6", - "0xBcd4042DE499D14e55001CcbB24a551F3b954096":"0x030bb316cf4dbaeff8df7c6a8f3c55a11c72f7f2f8d79c274f27cdce2220f36371,0xf214f2b2cd398c806f84e317254e0f0b801d0643303237d97a22a48e01628897", - "0x71bE63f3384f5fb98995898A86B02Fb2426c5788":"0x02e393c954d127d79d56b594a46df6b2e053f49446759eac612dbe12ade3095c67,0x701b615bbdfb9de65240bc28bd21bbc0d996645a3dd57e7b12bc2bdf6f192c82", - "0xFABB0ac9d68B0B445fB7357272Ff202C5651694a":"0x02463e7db0f9c35ba7ae68a8098f1024019b90191281276eeef294acb3f1354b0a,0xa267530f49f8280200edf313ee7af6b827f2a8bce2897751d06a843f644967b1", - "0x1CBd3b2770909D4e10f157cABC84C7264073C9Ec":"0x037805be0fc5186c4437306b531c8e981d3922e5fc81d72d527931b995445fb78e,0x47c99abed3324a2707c28affff1267e45918ec8c3f20b8aa892e8b065d2942dd", - "0xdF3e18d64BC6A983f673Ab319CCaE4f1a57C7097":"0x03407a862c69cbc66dceea40079757697abcf931043f5a5f128a56ae6e51bdbce7,0xc526ee95bf44d8fc405a158bb884d9d1238d99f0612e9f33d006bb0789009aaa", - "0xcd3B766CCDd6AE721141F452C550Ca635964ce71":"0x02d5ab34891bfe989bfa557f983cb5d031c4acc845ad990baaefb58ca1db0e7716,0x8166f546bab6da521a8369cab06c5d2b9e46670292d85c875ee9ec20e84ffb61", - "0x2546BcD3c84621e976D8185a91A922aE77ECEc30":"0x0364c1c85d9aa8081a8ef94c35379fa7532942b2d8cbbd1e3ea71c0e3609b96cc0,0xea6c44ac03bff858b476bba40716402b03e41b8e97e276d1baec7c37d42484a0", - "0xbDA5747bFD65F08deb54cb465eB87D40e51B197E":"0x02c216848622dfc38a2ad2a921f524103cf654a22b8679736ecedc4901453ea3f7,0x689af8efa8c651a91ad287602527f3af2fe9f6501a7ac4b061667b5a93e037fd", - "0xdD2FD4581271e230360230F9337D5c0430Bf44C0":"0x02302a94bd084ff317493db7c2fe07e0935c0f6d3e6772d6af3c58e92abebfb402,0xde9be858da4a475276426320d5e9262ecfc3ba460bfac56360bfa6c4c28b4ee0", - "0x8626f6940E2eb28930eFb4CeF49B2d1F2C9C1199":"0x027bf824b28c4bf11ce553fa746a18754949ab4959e2ea73465778d14179211f8c,0xdf57089febbacf7ba0bc227dafbffa9fc08a93fdc68e1e42411a14efcf23656e", - "0x09DB0a93B389bEF724429898f539AEB7ac2Dd55f":"0x02ecc9c3f6303fddcd44f5c9ecaa225eafaa18b8464a022389a4c4be474e4557a9,0xeaa861a9a01391ed3d587d8a5a84ca56ee277629a8b02c22093a419bf240e65d", - "0x02484cb50AAC86Eae85610D6f4Bf026f30f6627D":"0x031a7044a0e2549a114c92dfa83a25bfc17f4b7c2db4a7e7e48d35ed67c285de3b,0xc511b2aa70776d4ff1d376e8537903dae36896132c90b91d52c1dfbae267cd8b", - "0x08135Da0A343E492FA2d4282F2AE34c6c5CC1BbE":"0x02abca850bc9472d92402203e9cbafc2e8dedb19f1103911a62b11ba2a4370e635,0x224b7eb7449992aac96d631d9677f7bf5888245eef6d6eeda31e62d2f29a83e4", - "0x5E661B79FE2D3F6cE70F5AAC07d8Cd9abb2743F1":"0x02092a3ba818f25a71a947d3daa7f9d501c3f18296057c928bc5feffa8b61d54f3,0x4624e0802698b9769f5bdb260a3777fbd4941ad2901f5966b854f953497eec1b", - "0x61097BA76cD906d2ba4FD106E757f7Eb455fc295":"0x030b1d683d363d0704f04e4fb59a33b6e22bd0187303f9cce881d0809d3a535f28,0x375ad145df13ed97f8ca8e27bb21ebf2a3819e9e0a06509a812db377e533def7", - "0xDf37F81dAAD2b0327A0A50003740e1C935C70913":"0x02da995e8954b8c4681db2986bc3004f403c8f5600d1d33a949a63045c50abf41d,0x18743e59419b01d1d846d97ea070b5a3368a3e7f6f0242cf497e1baac6972427", - "0x553BC17A05702530097c3677091C5BB47a3a7931":"0x027bc620a41c572668c4d7b508e020cd8f4e9e50074016c461370e7995838b5dbd,0xe383b226df7c8282489889170b0f68f66af6459261f4833a781acd0804fafe7a", - "0x87BdCE72c06C21cd96219BD8521bDF1F42C78b5e":"0x0335aafbd21e02e958638c90c562dc048df89452b743dd7c3c7eadb8a223925895,0xf3a6b71b94f5cd909fb2dbb287da47badaa6d8bcdc45d595e2884835d8749001", - "0x40Fc963A729c542424cD800349a7E4Ecc4896624":"0x032cd2af66ea588191488e7a647190584a3999630e2db8d5abba0ac290fbd291ab,0x4e249d317253b9641e477aba8dd5d8f1f7cf5250a5acadd1229693e262720a19", - "0x9DCCe783B6464611f38631e6C851bf441907c710":"0x0329fdd393d57616eafdf67ebb6272a8ddb2ebf1eaa9b95b9e0702de79bf90da02,0x233c86e887ac435d7f7dc64979d7758d69320906a0d340d2b6518b0fd20aa998", - "0x1BcB8e569EedAb4668e55145Cfeaf190902d3CF2":"0x02a3b615dcceb0b919884b12fed0d3125c5324dd01e95fd0e5dfbee1fc51cbbe15,0x85a74ca11529e215137ccffd9c95b2c72c5fb0295c973eb21032e823329b3d2d", - "0x8263Fce86B1b78F95Ab4dae11907d8AF88f841e7":"0x02352c8ff139eb4b92f0b24d60e434c365ee202acc25aaa4f438852fce49eb41c8,0xac8698a440d33b866b6ffe8775621ce1a4e6ebd04ab7980deb97b3d997fc64fb", - "0xcF2d5b3cBb4D7bF04e3F7bFa8e27081B52191f91":"0x02eb8d75ab6953483cb4df4fae49e0199a220b3cd204852960e55e1f1dbb3cfa21,0xf076539fbce50f0513c488f32bf81524d30ca7a29f400d68378cc5b1b17bc8f2", - "0x86c53Eb85D0B7548fea5C4B4F82b4205C8f6Ac18":"0x0353db5e250d783f4368322de94bab64276c80a7284b9db0eae18bcae1f3eb0e28,0x5544b8b2010dbdbef382d254802d856629156aba578f453a76af01b81a80104e", - "0x1aac82773CB722166D7dA0d5b0FA35B0307dD99D":"0x02e749e4fb83ae7afc7d19acdfc6a97ec5ae677019decf2c46758096a679021c6c,0x47003709a0a9a4431899d4e014c1fd01c5aad19e873172538a02370a119bae11", - "0x2f4f06d218E426344CFE1A83D53dAd806994D325":"0x022a04ffd79e7334daa2724d9227d11ecf8124f0f2e2ae82b78cbfba14bca47577,0x9644b39377553a920edc79a275f45fa5399cbcf030972f771d0bca8097f9aad3", - "0x1003ff39d25F2Ab16dBCc18EcE05a9B6154f65F4":"0x023f1e0c738f9604febf39304f7a8c918da05a7d0fc574cca239893b1f24e10639,0xcaa7b4a2d30d1d565716199f068f69ba5df586cf32ce396744858924fdf827f0", - "0x9eAF5590f2c84912A08de97FA28d0529361Deb9E":"0x0354d2c78f37e8efe3014735fcca95cabae6a1e7901262a3f4e71355b1b406e555,0xfc5a028670e1b6381ea876dd444d3faaee96cffae6db8d93ca6141130259247c", - "0x11e8F3eA3C6FcF12EcfF2722d75CEFC539c51a1C":"0x023e21c805452630d51c2116c0be5d78586f09f0239e5e0c78c1301bca129dd60a,0x5b92c5fe82d4fabee0bc6d95b4b8a3f9680a0ed7801f631035528f32c9eb2ad5", - "0x7D86687F980A56b832e9378952B738b614A99dc6":"0x03cae5771b32d2b0639db908805738158abd3943623f23eaf875cc7e7eaefa9662,0xb68ac4aa2137dd31fd0732436d8e59e959bb62b4db2e6107b15f594caf0f405f", - "0x9eF6c02FB2ECc446146E05F1fF687a788a8BF76d":"0x036fa7e0bea88907ab4753030c9e2bde73f1740ade3e134eba7414729be25eddbf,0xc95eaed402c8bd203ba04d81b35509f17d0719e3f71f40061a2ec2889bc4caa7", - "0x08A2DE6F3528319123b25935C92888B16db8913E":"0x033f52ffb1962b253b7b62f5a3a6e68b71f25fa8f5e3eeeeeb666c3fb73eac90f2,0x55afe0ab59c1f7bbd00d5531ddb834c3c0d289a4ff8f318e498cb3f004db0b53", - "0xe141C82D99D85098e03E1a1cC1CdE676556fDdE0":"0x0389b4c6ccde6226f5efdaad52831601004334d110e5eceb8060143a8adf234a12,0xc3f9b30f83d660231203f8395762fa4257fa7db32039f739630f87b8836552cc", - "0x4b23D303D9e3719D6CDf8d172Ea030F80509ea15":"0x039141c8858729dd0c6849821158bce66f986cc07c8f02915798b559b0bfd54d4f,0x3db34a7bcc6424e7eadb8e290ce6b3e1423c6e3ef482dd890a812cd3c12bbede", - "0xC004e69C5C04A223463Ff32042dd36DabF63A25a":"0x03a4c793122ddb400993b158b5fc2c49537892aca278a78800d901ced771af1b49,0xae2daaa1ce8a70e510243a77187d2bc8da63f0186074e4a4e3a7bfae7fa0d639", - "0x5eb15C0992734B5e77c888D713b4FC67b3D679A2":"0x02a634ff1801b05722f7c5d1f90c49a9647bbb1687ff78f6def5aa37b3fe99e4f3,0x5ea5c783b615eb12be1afd2bdd9d96fae56dda0efe894da77286501fd56bac64", - "0x7Ebb637fd68c523613bE51aad27C35C4DB199B9c":"0x02f339bf0e15d6b2fff7b2770bca8b08204cde82272e8c86116996aba7ac9f86aa,0xf702e0ff916a5a76aaf953de7583d128c013e7f13ecee5d701b49917361c5e90", - "0x3c3E2E178C69D4baD964568415a0f0c84fd6320A":"0x02a7dbabe4d7d8ce4b97b2a6d35d7e3258f02cc961d2c83477dbaeadbc04627c9b,0x7ec49efc632757533404c2139a55b4d60d565105ca930a58709a1c52d86cf5d3", - "0x35304262b9E87C00c430149f28dD154995d01207":"0x03e719f368cc8eb4573b9d22e88141ae459d886145219064923ff564afb432c9ac,0x755e273950f5ae64f02096ae99fe7d4f478a28afd39ef2422068ee7304c636c0", - "0xD4A1E660C916855229e1712090CcfD8a424A2E33":"0x021a7791080bafa8601bb57bd37697f6791b525476b97289b71da04ab3a4a2b30c,0xaf6ecabcdbbfb2aefa8248b19d811234cd95caa51b8e59b6ffd3d4bbc2a6be4c", - "0xEe7f6A930B29d7350498Af97f0F9672EaecbeeFf":"0x03d41afe51df3bc945686fc68692bbf1b842625d237f37fc6be7e7f48b12dd179a,0x70c2bd1b41084c2e2238551eace483321f8c1a413a471c3b49c8a5d1d6b3d0c4", - "0x145e2dc5C8238d1bE628F87076A37d4a26a78544":"0x024982335a4f5adc6a12deb2e993b4a3a758c934cfd7f039f9b7f2da9bba3584e5,0xcb8e373c93609268cdcec93450f3578b92bb20c3ac2e77968d106025005f97b5", - "0xD6A098EbCc5f8Bd4e174D915C54486B077a34A51":"0x03a3d9eb25c55ec1b2f806bf74467179ba5dafc0b60a71df8584186bb5e00d33e9,0x6f29f6e0b750bcdd31c3403f48f11d72215990375b6d23380b39c9bbf854a7d3", - "0x042a63149117602129B6922ecFe3111168C2C323":"0x0324b9bda0e580b02d781560fd0e0cbfd2eaeba437385f8cdef34be6ec9bd8a3e5,0xff249f7eba6d8d3a65794995d724400a23d3b0bd1714265c965870ef47808be8", - "0xa0EC9eE47802CeB56eb58ce80F3E41630B771b04":"0x02293160c8d9443c5005f079f69c8d6ccd300bb6ca602047d441cadd34fce69e6a,0x5599a7be5589682da3e0094806840e8510dae6493665a701b06c59cbe9d97968", - "0xe8B1ff302A740fD2C6e76B620d45508dAEc2DDFf":"0x02e9c73d939eca4abac1a04ae265b74ff31cdd24be067aae13dcd54128e649161f,0x93de2205919f5b472723722fedb992e962c34d29c4caaedd82cd33e16f1fd3cf", - "0xAb707cb80e7de7C75d815B1A653433F3EEc44c74":"0x026d93cfa091c70da11e27ee30dbcca537002ed21b19e05ac93e7d851a96138046,0xd20ecf81c6c3ad87a4e8dbeb7ceef41dd0eebc7a1657efb9d34e47217694b5cb", - "0x0d803cdeEe5990f22C2a8DF10A695D2312dA26CC":"0x026af2062598d0630cc1c6f5353e66932434d1eb575bafab8da38741e34e82e281,0xe4058704ed240d68a94b6fb226824734ddabd4b1fe37bc85ce22f5b17f98830e", - "0x1c87Bb9234aeC6aDc580EaE6C8B59558A4502220":"0x02505ad7c2117c6a2eef85f5b70fb590a8f13f9f37b01f7e5b10139186bef06f2a,0x4ae4408221b5042c0ee36f6e9e6b586a00d0452aa89df2e7f4f5aec42152ec43", - "0x4779d18931B35540F84b0cd0e9633855B84df7b8":"0x03dd485c6f4db4f3978db121fba82550acef94eaf7f5ab88ecc3f6715b903c7184,0x0e7c38ba429fa5081692121c4fcf6304ca5895c6c86d31ed155b0493c516107f", - "0xC0543b0b980D8c834CBdF023b2d2A75b5f9D1909":"0x0270f7e08d92e184babc782d65b155a9b7dfbc0b671cc7b1a8c164e279df10524c,0xd5df67c2e4da3ff9c8c6045d9b7c41581efeb2a3660921ad4ba863cc4b8c211c", - "0x73B3074ac649A8dc31c2C90a124469456301a30F":"0x02f8660f6999a86ebe5cd7a3d70406e9a40b91b2adb9f5a4c0bc417d9782fdda90,0x92456ac1fa1ef65a04fb4689580ad5e4cda7369f3620ef3a02fa4015725f460a", - "0x265188114EB5d5536BC8654d8e9710FE72C28c4d":"0x037e2b32c6115bd151f79cb03a02eda9a8e358fb6be1eaec990ea5a60edc5371dc,0x65b10e7d7315bb8b7f7c6eefcbd87b36ad4007c4ade9c032354f016e84ad9c5e", - "0x924Ba5Ce9f91ddED37b4ebf8c0dc82A40202fc0A":"0x02744c74fdfbaf21ce24cb7b8b388cbdbb5d5f6cb17cbd8947937c101b5ddabd72,0x365820b3376c77dab008476d49f7cd7af87fc7bbd57dc490378106c3353b2b33", - "0x64492E25C30031EDAD55E57cEA599CDB1F06dad1":"0x027aba8dcc8f89805a671b6f5c9cb045bbdffcc34be8d67c08676834be4e05108e,0xb07579b9864bb8e69e8b6e716284ab5b5f39fe5bb57ae4c83af795a242390202", - "0x262595fa2a3A86adACDe208589614d483e3eF1C0":"0x03d886c44c0449efb2b3e8786b84526b145312be2218b0df7e9cd36acfab8a7906,0xbf071d2b017426fcbf763cce3b3efe3ffc9663a42c77a431df521ef6c79cacad", - "0xDFd99099Fa13541a64AEe9AAd61c0dbf3D32D492":"0x02261caf03c748989a5d7d540b2fbf31f1a7e073a79f44b970ab2eb6de8aefe618,0x8bbffff1588b3c4eb8d415382546f6f6d5f0f61087c3be7c7c4d9e0d41d97258", - "0x63c3686EF31C03a641e2Ea8993A91Ea351e5891a":"0x03ed764675312dedf399f1bc201d3793228ccf560d0af20ea647362c82232838be,0xb658f0575a14a7ac05075cb0f8727f0aae168a091dfb32d92514d1a7c11cf498", - "0x9394cb5f737Bd3aCea7dcE90CA48DBd42801EE5d":"0x02317b1f8a1fbe4fe6f797c699557e934c32ba84124b84d96c5169739aea200aee,0x228330af91fa515d7514cf5ac6594ab90b296cbd8ff7bc4567306aa66cacd79f", - "0x344dca30F5c5f74F2f13Dc1d48Ad3A9069d13Ad9":"0x033faa1f92cfcc003fb2881ebc43ec06afb7e827affb98e31ee4322730351cc422,0xe6f80f9618311c0cd58f6a3fc6621cdbf6da4a72cc42e2974c98829343e7927b", - "0xF23E054D8b4D0BECFa22DeEF5632F27f781f8bf5":"0x0364c2c11140a075eb0091cf670323d36e13befec4e8a10cba171a9a2de9f1ab45,0x36d0435aa9a2c24d72a0aa69673b3acc2649969c38a581103df491aac6c33dd4", - "0x6d69F301d1Da5C7818B5e61EECc745b30179C68b":"0x03c550d4a3aaabcf2489acc382f8f8809b1e1601115564e39b239348690ae701bc,0xf3ed98f9148171cfed177aef647e8ac0e2579075f640d05d37df28e6e0551083", - "0xF0cE7BaB13C99bA0565f426508a7CD8f4C247E5a":"0x03a5d94447bc763e337e2dd4a88a4d5be5bda78f7ebb891ed9ed9cdf9d49a01ec4,0x8fc20c439fd7cf4f36217471a5db7594188540cf9997a314520a018de27544dd", - "0x011bD5423C5F77b5a0789E27f922535fd76B688F":"0x0351ee10626b0a786de6055e2ae0d5425ba3f17059b40219fe8820946d16249e1e,0x549078aab3adafeff862b2d40b6b27756c5c4669475c3367edfb8dcf63ea1ae5", - "0xD9065f27e9b706E5F7628e067cC00B288dddbF19":"0x0229157c9e5a73e54e55a062cf19104f6061dbcb11a23e31f60913d0b12c553d3d,0xacf192decb2e4ddd8ad61693ab8edd67e3620b2ed79880ff4e1e04482c52c916", - "0x54ccCeB38251C29b628ef8B00b3cAB97e7cAc7D5":"0x03feca36c85fc354f47dfcc23f0e5baca85357c64bbe8616560675cd3333b8acbc,0x47dc59330fb8c356ef61c55c11f9bb49ee463df50cbfe59f389de7637037b029", - "0xA1196426b41627ae75Ea7f7409E074BE97367da2":"0x0352536b2204dc725b8b98c2931079fcb912bc702215da262e9d5cd444d226cc68,0xf0050439b33fd77f7183f44375bc43a869a9880dca82a187fab9be91e020d029", - "0xE74cEf90b6CF1a77FEfAd731713e6f53e575C183":"0x026ffa4ca4e8e4e9e9426f2b762e31a9b0b3586f8eafb470bb32aca6e5fd46ffcd,0xe995cc7ea38e5c2927b97607765c2a20f4a6052d6810a3a1102e84d77c0df13b", - "0x7Df8Efa6d6F1CB5C4f36315e0AcB82b02Ae8BA40":"0x03c85a8ab2a97379d1c3ff45e28815a7dc5485d2246362bd4823fceee257b7e798,0x8232e778c8e32eddb268e12aee5e82c7bb540cc176e150d64f35ee4ae2faf2b2", - "0x9E126C57330FA71556628e0aabd6B6B6783d99fA":"0x034d7b61c8dd53a761ab44d1e06be6b1338de4095c620112494b8830792c84f64b,0xba8c9ff38e4179748925335a9891b969214b37dc3723a1754b8b849d3eea9ac0" } - # init with 100,000 EOS + # init with 1,000,000 EOS each for i,k in enumerate(addys): print("addys: [{0}] [{1}] [{2}]".format(i,k[2:].lower(), len(k[2:]))) - transferAmount="100000.0000 {0}".format(CORE_SYMBOL) + transferAmount="1000000.0000 {0}".format(CORE_SYMBOL) Print("Transfer funds %s from account %s to %s" % (transferAmount, cluster.eosioAccount.name, evmAcc.name)) trans = prodNode.transferFunds(cluster.eosioAccount, evmAcc, transferAmount, "0x" + k[2:].lower(), waitForTransBlock=False) if not (i+1) % 20: time.sleep(1) @@ -405,6 +464,7 @@ def restore(): @app.route("/", methods=["POST"]) def default(): def forward_request(req): + print("METHOD: ", req['method']) if req['method'] == "eth_sendRawTransaction": actData = {"miner":"eosio.evm", "rlptx":req['params'][0][2:]} prodNode1.pushMessage(evmAcc.name, "pushtx", json.dumps(actData), '-p eosio.evm')