PR feedback: Use request

This commit is contained in:
Anthony Laibe 2018-08-21 11:38:05 +01:00 committed by Iuri Matias
parent 85354fd877
commit 9f9a3401f6

View File

@ -106,20 +106,22 @@ class ContractsManager {
return res.send({error: error.message}); return res.send({error: error.message});
} }
const {account, contract} = result; const {account, contract} = result;
const contractObj = new web3.eth.Contract(contract.abiDefinition, contract.deployedAddress);
const abi = contract.abiDefinition.find(definition => definition.name === req.body.method); const abi = contract.abiDefinition.find(definition => definition.name === req.body.method);
const funcCall = (abi.constant === true || abi.stateMutability === 'view' || abi.stateMutability === 'pure') ? 'call' : 'send'; const funcCall = (abi.constant === true || abi.stateMutability === 'view' || abi.stateMutability === 'pure') ? 'call' : 'send';
try {
contractObj.methods[req.body.method].apply(this, req.body.inputs)[funcCall]({from: account}, (error, result) => {
if (error) {
return res.send({result: error.message});
}
res.send({result}); self.events.request("blockchain:contract:create", {abi: contract.abiDefinition, address: contract.deployedAddress}, (contractObj) => {
}); try {
} catch (e) { contractObj.methods[req.body.method].apply(this, req.body.inputs)[funcCall]({from: account}, (error, result) => {
res.send({result: e.message}); if (error) {
} return res.send({result: error.message});
}
res.send({result});
});
} catch (e) {
res.send({result: e.message});
}
});
}); });
} }
); );
@ -135,19 +137,22 @@ class ContractsManager {
account: (callback) => { account: (callback) => {
self.events.request("blockchain:defaultAccount:get", (account) => callback(null, account)); self.events.request("blockchain:defaultAccount:get", (account) => callback(null, account));
} }
}, async (error, result) => { }, (error, result) => {
if (error) { if (error) {
return res.send({error: error.message}); return res.send({error: error.message});
} }
const {account, contract} = result; const {account, contract} = result;
const contractObj = new web3.eth.Contract(contract.abiDefinition);
try { self.events.request("blockchain:contract:create", {abi: contract.abiDefinition}, async (contractObj) => {
let gas = await contractObj.deploy({data: `0x${contract.code}`, arguments: req.body.inputs}).estimateGas(); try {
let newContract = await contractObj.deploy({data: `0x${contract.code}`, arguments: req.body.inputs}).send({from: account, gas}); const params = {data: `0x${contract.code}`, arguments: req.body.inputs};
res.send({result: newContract._address}); let gas = await contractObj.deploy(params).estimateGas();
} catch (e) { let newContract = await contractObj.deploy(params).send({from: account, gas});
res.send({result: e.message}); res.send({result: newContract._address});
} } catch (e) {
res.send({result: e.message});
}
});
}); });
} }
); );