PR feedback: Use request
This commit is contained in:
parent
85354fd877
commit
9f9a3401f6
|
@ -106,9 +106,10 @@ 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';
|
||||||
|
|
||||||
|
self.events.request("blockchain:contract:create", {abi: contract.abiDefinition, address: contract.deployedAddress}, (contractObj) => {
|
||||||
try {
|
try {
|
||||||
contractObj.methods[req.body.method].apply(this, req.body.inputs)[funcCall]({from: account}, (error, result) => {
|
contractObj.methods[req.body.method].apply(this, req.body.inputs)[funcCall]({from: account}, (error, result) => {
|
||||||
if (error) {
|
if (error) {
|
||||||
|
@ -121,6 +122,7 @@ class ContractsManager {
|
||||||
res.send({result: e.message});
|
res.send({result: e.message});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -135,20 +137,23 @@ 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);
|
|
||||||
|
self.events.request("blockchain:contract:create", {abi: contract.abiDefinition}, async (contractObj) => {
|
||||||
try {
|
try {
|
||||||
let gas = await contractObj.deploy({data: `0x${contract.code}`, arguments: req.body.inputs}).estimateGas();
|
const params = {data: `0x${contract.code}`, arguments: req.body.inputs};
|
||||||
let newContract = await contractObj.deploy({data: `0x${contract.code}`, arguments: req.body.inputs}).send({from: account, gas});
|
let gas = await contractObj.deploy(params).estimateGas();
|
||||||
|
let newContract = await contractObj.deploy(params).send({from: account, gas});
|
||||||
res.send({result: newContract._address});
|
res.send({result: newContract._address});
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
res.send({result: e.message});
|
res.send({result: e.message});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue