Merge pull request #11 from embark-framework/features/seceure-send

add secureSend function in EmbarkJS Utils
This commit is contained in:
Iuri Matias 2018-08-14 13:44:31 -04:00 committed by GitHub
commit 5bcab1c2a6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 61 additions and 2 deletions

View File

@ -1,11 +1,70 @@
let Utils = {
fromAscii: function (str) {
fromAscii: function(str) {
var _web3 = new Web3();
return _web3.utils ? _web3.utils.fromAscii(str) : _web3.fromAscii(str);
},
toAscii: function (str) {
toAscii: function(str) {
var _web3 = new Web3();
return _web3.utils.toAscii(str);
},
secureSend: function(web3, toSend, params, isContractDeploy, cb) {
cb = cb || function() {};
return new Promise((resolve, reject) => {
let hash;
let calledBacked = false;
function callback(err, receipt) {
if (calledBacked) {
return;
}
if (!err && (isContractDeploy && !receipt.contractAddress)) {
return; // Not deployed yet. Need to wait
}
if (interval) {
clearInterval(interval);
}
calledBacked = true;
cb(err, receipt);
if (err) {
return reject(err);
}
resolve(receipt);
}
// This interval is there to compensate for the event that sometimes doesn't get triggered when using WebSocket
// FIXME The issue somehow only happens when the blockchain node is started in the same terminal
const interval = setInterval(() => {
if (!hash) {
return; // Wait until we receive the hash
}
web3.eth.getTransactionReceipt(hash, (err, receipt) => {
if (!err && !receipt) {
return; // Transaction is not yet complete
}
callback(err, receipt);
});
}, 100);
toSend.estimateGas()
.then(gasEstimated => {
params.gas = gasEstimated + 1000;
return toSend.send(params, function(err, transactionHash) {
if (err) {
return callback(err);
}
hash = transactionHash;
}).on('receipt', function(receipt) {
if (!isContractDeploy || receipt.contractAddress) {
callback(null, receipt);
}
}).then(function(_contract) {
if (!hash) {
return; // Somehow we didn't get the receipt yet... Interval will catch it
}
web3.eth.getTransactionReceipt(hash, callback);
}).catch(callback);
});
});
}
};