From 881c58c8b88b095d055d8921174aca6878674c89 Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Fri, 14 Sep 2018 11:35:46 -0400 Subject: [PATCH 1/3] Obtaining relayer balance and switched method to obtain latest blocks --- test-dapp/app/components/body-identity.js | 4 ++ .../app/components/body-sntcontroller.js | 34 ++++++++++---- test-dapp/app/components/execute.js | 37 +++++++++------ test-dapp/app/components/status-identity.js | 8 +++- .../app/components/status-sntcontroller.js | 45 +++++++++++-------- test-dapp/app/components/transfersnt.js | 39 ++++++++++------ 6 files changed, 112 insertions(+), 55 deletions(-) diff --git a/test-dapp/app/components/body-identity.js b/test-dapp/app/components/body-identity.js index ff4ce00..0af7bef 100644 --- a/test-dapp/app/components/body-identity.js +++ b/test-dapp/app/components/body-identity.js @@ -69,6 +69,10 @@ class Body extends Component { let relayers = this.state.relayers; relayers[msgObj.sig] = msgObj.address; + + if(this.state.relayerAddress == '0x0000000000000000000000000000000000000000'){ + this.setState({relayerAddress: msgObj.address}); + } this.setState({relayers}); } diff --git a/test-dapp/app/components/body-sntcontroller.js b/test-dapp/app/components/body-sntcontroller.js index 6eba1f2..5376a42 100644 --- a/test-dapp/app/components/body-sntcontroller.js +++ b/test-dapp/app/components/body-sntcontroller.js @@ -30,7 +30,8 @@ class Body extends Component { kid: null, skid: null, message: '', - relayers: [] + relayerAddress: '0x0000000000000000000000000000000000000000', + relayers: {} }; } @@ -43,6 +44,14 @@ class Body extends Component { const web3js = new Web3('ws://localhost:8546'); + + // Default for devenv + web3js.eth.net.getId().then(netId => { + if(netId != 1 && netId != 3){ + this.setState({relayerAddress: config.relayAccount}); + } + }); + web3js.shh.newKeyPair() .then((kid) => { web3js.shh.addSymKey(config.relaySymKey) @@ -58,9 +67,14 @@ class Body extends Component { if(msgObj.message == Messages.available){ // found a relayer console.log("Relayer available: " + msgObj.sig); + let relayers = this.state.relayers; - relayers.push(msgObj.sig); - relayers = relayers.filter((value, index, self) => self.indexOf(value) === index); + relayers[msgObj.sig] = msgObj.address; + + if(this.state.relayerAddress == '0x0000000000000000000000000000000000000000'){ + this.setState({relayerAddress: msgObj.address}); + } + this.setState({relayers}); } @@ -79,7 +93,7 @@ class Body extends Component { web3.eth.getAccounts() .then(accounts => { - this.setState({walletAddress: accounts[2]}); + this.setState({walletAddress: accounts[0]}); }); }); @@ -89,6 +103,10 @@ class Body extends Component { this.setState({tab}); }; + updateRelayer = (relayer) => { + this.setState({relayerAddress: this.state.relayers[relayer]}); + } + updateNonce = (newNonce) => { this.setState({nonce: newNonce}); } @@ -98,18 +116,18 @@ class Body extends Component { } render(){ - const {tab, walletAddress, nonce, web3js, message, kid, skid, relayers} = this.state; + const {tab, walletAddress, nonce, web3js, message, kid, skid, relayers, relayerAddress} = this.state; return - {tab === 0 && } - {tab === 1 && } + {tab === 0 && } + {tab === 1 && } - + ; } diff --git a/test-dapp/app/components/execute.js b/test-dapp/app/components/execute.js index 7e335ed..a71ecb0 100644 --- a/test-dapp/app/components/execute.js +++ b/test-dapp/app/components/execute.js @@ -51,6 +51,9 @@ class Execute extends Component { } handleChange = name => event => { + if(name == 'relayer'){ + this.props.updateRelayer(event.target.value); + } this.setState({ [name]: event.target.value }); @@ -67,7 +70,7 @@ class Execute extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[0]) .execute(this.state.allowedContract, this.state.data) .setGas(this.state.gasPrice, this.state.gasMinimal); @@ -104,7 +107,7 @@ class Execute extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.AvailableRelayers(Contracts.SNT, SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.AvailableRelayers(Contracts.SNT, SNTController.options.address, accounts[0]) .setRelayersSymKeyID(skid) .setAsymmetricKeyID(kid) .setGas(STT.options.address, this.state.gasPrice); @@ -124,10 +127,16 @@ class Execute extends Component { const {web3, kid} = this.props; let relayer = this.state.relayer; - if(relayer == '' && this.props.relayers.length == 1){ - relayer = this.props.relayers[0]; - } + + let relayers = []; + for (var key in this.props.relayers) { + if (this.props.relayers.hasOwnProperty(key)) relayers.push(key); + } + + if(relayer == '' && relayers.length == 1){ + relayer = relayers[0]; + } this.setState({ messagingError: '', @@ -138,7 +147,7 @@ class Execute extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[0]) .execute(this.state.allowedContract, this.state.data) .setGas(this.state.gasPrice, this.state.gasMinimal) .setRelayer(relayer) @@ -156,6 +165,12 @@ class Execute extends Component { render(){ const {classes} = this.props; + + let relayers = []; + for (var key in this.props.relayers) { + if (this.props.relayers.hasOwnProperty(key)) relayers.push(key); + } + return
@@ -279,12 +294,7 @@ class Execute extends Component { native: true }} > - { - this.props.relayers.length > 0 ? - this.props.relayers.map((r, i) => ) - : - - } + { relayers.length > 0 ? relayers.map((r, i) => ) : } { + this.web3BlockRead(); + } + + web3BlockRead = () => { + web3.eth.getBlock('latest').then(block => { this.setState({block: block.number}); this.readChain(); + setTimeout(this.web3BlockRead, 10000); return true; }); } diff --git a/test-dapp/app/components/status-sntcontroller.js b/test-dapp/app/components/status-sntcontroller.js index b49bb6d..8cc5973 100644 --- a/test-dapp/app/components/status-sntcontroller.js +++ b/test-dapp/app/components/status-sntcontroller.js @@ -52,9 +52,9 @@ class Status extends Component { constructor(props){ super(props); this.state = { + 'isDev': true, 'addressETHBalance': 0, 'addressSTTBalance': 0, - 'relayerAddress': null, 'relayerEthBalance': 0, 'relayerSTTBalance': 0, 'block': 0, @@ -72,19 +72,25 @@ class Status extends Component { return; } - this.setState({ - relayerAddress: config.relayAccount - }); - this.getBlock(); }); } getBlock = () => { - web3.eth.subscribe('newBlockHeaders') - .on('data', (block) => { + + // Default for devenv + web3.eth.net.getId().then(netId => { + this.setState({isDev: netId != 1 && netId != 3}); + }); + + this.web3BlockRead(); + } + + web3BlockRead = () => { + web3.eth.getBlock('latest').then(block => { this.setState({block: block.number}); this.readChain(); + setTimeout(this.web3BlockRead, 10000); return true; }); } @@ -117,12 +123,12 @@ class Status extends Component { }); } - web3.eth.getBalance(this.state.relayerAddress) + web3.eth.getBalance(this.props.relayerAddress) .then(relayerEthBalance => { this.setState({relayerEthBalance}); }); - STT.methods.balanceOf(this.state.relayerAddress) + STT.methods.balanceOf(this.props.relayerAddress) .call() .then(relayerSTTBalance => { this.setState({relayerSTTBalance: web3.utils.fromWei(relayerSTTBalance, 'ether')}); @@ -170,7 +176,7 @@ class Status extends Component { submitState.etherSend = false; this.setState({submitState}); - web3.eth.sendTransaction({from: web3.eth.defaultAccount, to: this.state.relayerAddress, value: web3.utils.toWei('1', "ether")}) + web3.eth.sendTransaction({from: web3.eth.defaultAccount, to: this.props.relayerAddress, value: web3.utils.toWei('1', "ether")}) .then((receipt) => { console.log(receipt); submitState = this.state.submitState; @@ -180,8 +186,8 @@ class Status extends Component { } render(){ - const {classes, walletAddress, nonce} = this.props; - const {addressETHBalance, relayerAddress, relayerEthBalance, addressSTTBalance, relayerSTTBalance, submitState, block} = this.state; + const {classes, walletAddress, nonce, relayerAddress} = this.props; + const {addressETHBalance, relayerEthBalance, addressSTTBalance, relayerSTTBalance, submitState, block, isDev} = this.state; return @@ -200,14 +206,14 @@ class Status extends Component { Address - - } + { isDev && + } @@ -247,10 +253,10 @@ class Status extends Component { Relayer - + } @@ -292,7 +298,8 @@ Status.propTypes = { walletAddress: PropTypes.string, nonce: PropTypes.string.isRequired, nonceUpdateFunction: PropTypes.func.isRequired, - message: PropTypes.string + message: PropTypes.string, + relayerAddress: PropTypes.string }; export default withStyles(styles)(Status); diff --git a/test-dapp/app/components/transfersnt.js b/test-dapp/app/components/transfersnt.js index d9129c1..5881675 100644 --- a/test-dapp/app/components/transfersnt.js +++ b/test-dapp/app/components/transfersnt.js @@ -51,6 +51,9 @@ class TransferSNT extends Component { } handleChange = name => event => { + if(name == 'relayer'){ + this.props.updateRelayer(event.target.value); + } this.setState({ [name]: event.target.value }); @@ -77,7 +80,7 @@ class TransferSNT extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[0]) .transferSNT(this.state.to, this.state.amount) .setGas(this.state.gasPrice); @@ -105,7 +108,7 @@ class TransferSNT extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.AvailableRelayers(Contracts.SNT, SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.AvailableRelayers(Contracts.SNT, SNTController.options.address, accounts[0]) .setRelayersSymKeyID(skid) .setAsymmetricKeyID(kid) .setGas(STT.options.address, this.state.gasPrice); @@ -125,9 +128,16 @@ class TransferSNT extends Component { const {web3, kid} = this.props; let relayer = this.state.relayer; - if(relayer == '' && this.props.relayers.length == 1){ - relayer = this.props.relayers[0]; - } + + + let relayers = []; + for (var key in this.props.relayers) { + if (this.props.relayers.hasOwnProperty(key)) relayers.push(key); + } + + if(relayer == '' && relayers.length == 1){ + relayer = relayers[0]; + } this.setState({ messagingError: '', @@ -138,7 +148,7 @@ class TransferSNT extends Component { try { const accounts = await web3.eth.getAccounts(); - const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[2]) + const s = new StatusGasRelayer.SNTController(SNTController.options.address, accounts[0]) .transferSNT(this.state.to, this.state.amount) .setGas(this.state.gasPrice) .setRelayer(relayer) @@ -156,6 +166,12 @@ class TransferSNT extends Component { render(){ const {classes} = this.props; + + let relayers = []; + for (var key in this.props.relayers) { + if (this.props.relayers.hasOwnProperty(key)) relayers.push(key); + } + return
@@ -270,12 +286,8 @@ class TransferSNT extends Component { native: true }} > - { - this.props.relayers.length > 0 ? - this.props.relayers.map((r, i) => ) - : - - } + { relayers.length > 0 ? relayers.map((r, i) => ) : } + Date: Fri, 14 Sep 2018 12:00:30 -0400 Subject: [PATCH 2/3] FIx: condition to display buttons --- test-dapp/app/components/status-identity.js | 2 +- test-dapp/app/components/status-sntcontroller.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/test-dapp/app/components/status-identity.js b/test-dapp/app/components/status-identity.js index f97a4ff..7b07f1d 100644 --- a/test-dapp/app/components/status-identity.js +++ b/test-dapp/app/components/status-identity.js @@ -83,7 +83,7 @@ class Status extends Component { // Default for devenv web3.eth.net.getId().then(netId => { - this.setState({isDev: netId != 1 && netId != 3}); + this.setState({isDev: netId != 1}); }); this.web3BlockRead(); diff --git a/test-dapp/app/components/status-sntcontroller.js b/test-dapp/app/components/status-sntcontroller.js index 8cc5973..9fa6a12 100644 --- a/test-dapp/app/components/status-sntcontroller.js +++ b/test-dapp/app/components/status-sntcontroller.js @@ -80,7 +80,7 @@ class Status extends Component { // Default for devenv web3.eth.net.getId().then(netId => { - this.setState({isDev: netId != 1 && netId != 3}); + this.setState({isDev: netId != 1}); }); this.web3BlockRead(); From fd6e7c994ef98d6d6acad88882352417c9def909 Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Fri, 14 Sep 2018 13:30:26 -0400 Subject: [PATCH 3/3] Added loading indicator, and changed contract addresses --- gas-relayer/config/config.testnet.js | 8 +-- .../app/components/status-sntcontroller.js | 12 +++- test-dapp/config/contracts.js | 27 ++++---- test-dapp/contracts/tests/TestMiniMeToken.sol | 61 ++++++++++++++++++- 4 files changed, 87 insertions(+), 21 deletions(-) diff --git a/gas-relayer/config/config.testnet.js b/gas-relayer/config/config.testnet.js index 7a1b70e..b9890c1 100644 --- a/gas-relayer/config/config.testnet.js +++ b/gas-relayer/config/config.testnet.js @@ -31,8 +31,8 @@ module.exports = { "currency": "USD" } }, - "0xd7879e4401c548544196dc0215df449B2a1E23B3": { - "name": "Status Test Token", + "0x121a430A73Fc13e2D6d4a9dc3E943de647c30f8f": { + "name": "Status Gas Relayer Test Token", "symbol": "SNT", "minAccepted":{ "value": 1, @@ -46,7 +46,7 @@ module.exports = { "IdentityGasRelay": { "abiFile": "../abi/IdentityGasRelay.json", "isIdentity": true, - "factoryAddress": "0x7F106A1Bc637AC4AAed3DC72582749c4562D4323", + "factoryAddress": "0x89976FeEC7CFDF2DF5194e363FD2a3388e2DC91A", "kernelVerification": "isKernel(bytes32)", "allowedFunctions": [ { @@ -63,7 +63,7 @@ module.exports = { "SNTController": { "abiFile": "../abi/SNTController.json", "isIdentity": false, - "address": "0xA77A1014F55157c3119FB3f53E653E42f8fa634c", + "address": "0xf558aC91312821B0E1802567BC785355AA811783", "allowedFunctions": [ { "function":"transferSNT(address,uint256,uint256,uint256,bytes)" diff --git a/test-dapp/app/components/status-sntcontroller.js b/test-dapp/app/components/status-sntcontroller.js index 9fa6a12..4cad09a 100644 --- a/test-dapp/app/components/status-sntcontroller.js +++ b/test-dapp/app/components/status-sntcontroller.js @@ -60,6 +60,7 @@ class Status extends Component { 'block': 0, 'submitState': { 'etherSend': false, + 'changeSNTController': false, 'generateSTT': false } }; @@ -158,6 +159,12 @@ class Status extends Component { changeSNTController = event => { event.preventDefault(); + + let submitState = this.state.submitState; + submitState.changeSNTController = true; + this.setState({submitState}); + + const toSend = STT.methods.changeController(SNTController.options.address); toSend.estimateGas() @@ -166,6 +173,9 @@ class Status extends Component { }) .then(receipt => { console.log(receipt); + submitState = this.state.submitState; + submitState.changeSNTController = false; + this.setState({submitState}); }); } @@ -173,7 +183,7 @@ class Status extends Component { event.preventDefault(); let submitState = this.state.submitState; - submitState.etherSend = false; + submitState.etherSend = true; this.setState({submitState}); web3.eth.sendTransaction({from: web3.eth.defaultAccount, to: this.props.relayerAddress, value: web3.utils.toWei('1', "ether")}) diff --git a/test-dapp/config/contracts.js b/test-dapp/config/contracts.js index 9beb80c..2a685d4 100644 --- a/test-dapp/config/contracts.js +++ b/test-dapp/config/contracts.js @@ -51,12 +51,12 @@ module.exports = { "IdentityKernel": {"deploy": false}, "STT": { "instanceOf": "TestMiniMeToken", - "args":["$MiniMeTokenFactory", "0x0", "0x0", "Status Test Token", 18, "STT", true], + "args":["$MiniMeTokenFactory", "0x0", "0x0", "Status Gas Relayer Test Token", 18, "STT", true], "gasLimit": 4000000 }, "SNTController": { "args": ["0x5f803F54679577fC974813E48abF012A243dD439", "$STT"] - }, + }, "IdentityGasRelay": { "deploy": true, "args": [[], [], [], 1, 1, "0x0000000000000000000000000000000000000000"] @@ -73,31 +73,32 @@ module.exports = { }, testnet: { contracts: { + // "MiniMeTokenFactory": { - "address": "0xBda00586BF6D79F22203EeDe046DEcaaf2B771B4" + "address": "0xD1A2f3726331d6100E8BcD1484EdF796B0b20cc9" }, "STT": { "instanceOf": "TestMiniMeToken", - "address": "0xd7879e4401c548544196dc0215df449B2a1E23B3" + "address": "0x121a430A73Fc13e2D6d4a9dc3E943de647c30f8f" }, "SNTController": { - "address": "0xA77A1014F55157c3119FB3f53E653E42f8fa634c" + "address": "0xf558aC91312821B0E1802567BC785355AA811783" }, "IdentityGasRelay": { - "address": "0xEA60E967BA16Bf4313B5d23b78e44763C8928C67" + "address": "0x4b571c5e75E93F53E985b12A3D107318178b9B5F" }, "IdentityFactory": { - "address": "0x7F106A1Bc637AC4AAed3DC72582749c4562D4323" + "address": "0x89976FeEC7CFDF2DF5194e363FD2a3388e2DC91A" }, "TestContract": { - "address": "0x1F0C9ebD14Ba43BDD5b43C52EbEfc31066704988" + "address": "0xa7aeF1cd3e4a8425D9A1E13B5557908895dCbdBE" } // If needed to deploy contracts again, uncomment the following lines /* "MiniMeTokenFactory": {"args":[]}, "STT": { "instanceOf": "MiniMeToken", - "args":["$MiniMeTokenFactory", "0x0", "0x0", "Status Test Token", 18, "STT", true], + "args":["$MiniMeTokenFactory", "0x0", "0x0", "Status Gas Relayer Test Token", 18, "STT", true], "gasLimit": 4000000 }, "SNTController": { @@ -114,9 +115,7 @@ module.exports = { }, "TestContract": { "args": ["$STT"] - } - */ - }, - accounts: [{privateKey: "71DB9B832BF457B4D812D6D6D673A02A1A2F5F687DBF59A2E41302A43459153C"}] - } + }*/ + } + } }; diff --git a/test-dapp/contracts/tests/TestMiniMeToken.sol b/test-dapp/contracts/tests/TestMiniMeToken.sol index 3a4f698..bd1aed6 100644 --- a/test-dapp/contracts/tests/TestMiniMeToken.sol +++ b/test-dapp/contracts/tests/TestMiniMeToken.sol @@ -1,5 +1,47 @@ pragma solidity ^0.4.23; + +/* +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +INTENTIONALLY INSECURE DO NOT USE IN MAINNET +*/ /* Copyright 2016, Jordi Baylina @@ -26,7 +68,6 @@ pragma solidity ^0.4.23; * @dev It is ERC20 compliant, but still needs to under go further testing. */ -import "../common/Controlled.sol"; import "../token/TokenController.sol"; import "../token/ApproveAndCallFallBack.sol"; import "../token/MiniMeTokenInterface.sol"; @@ -37,7 +78,7 @@ import "../token/MiniMeTokenFactory.sol"; * that deploys the contract, so usually this token will be deployed by a * token controller contract, which Giveth will call a "Campaign" */ -contract TestMiniMeToken is MiniMeTokenInterface, Controlled { +contract TestMiniMeToken is MiniMeTokenInterface { string public name; //The Token's name: e.g. DigixDAO Tokens uint8 public decimals; //Number of decimals of the smallest unit @@ -86,6 +127,20 @@ contract TestMiniMeToken is MiniMeTokenInterface, Controlled { // The factory used to create new clone tokens MiniMeTokenFactory public tokenFactory; + modifier onlyController { + require(msg.sender == controller); + _; + } + + address public controller; + + /// @notice Changes the controller of the contract + /// @param _newController The new controller of the contract + function changeController(address _newController) public { + controller = _newController; + } + + //////////////// // Constructor //////////////// @@ -116,6 +171,8 @@ contract TestMiniMeToken is MiniMeTokenInterface, Controlled { ) public { + controller = msg.sender; + tokenFactory = MiniMeTokenFactory(_tokenFactory); name = _tokenName; // Set the name decimals = _decimalUnits; // Set the decimals