mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-11 06:25:57 +00:00
Merge pull request #905 from embark-framework/bugfix/infura-simultaneous-tx
Bugfix/infura simultaneous tx
This commit is contained in:
commit
8d13cd8e9d
@ -20,6 +20,7 @@ class BlockchainConnector {
|
||||
this.isDev = options.isDev;
|
||||
this.web3Endpoint = '';
|
||||
this.isWeb3Ready = false;
|
||||
this.deployers = {};
|
||||
|
||||
self.events.setCommandHandler("blockchain:web3:isReady", (cb) => {
|
||||
cb(self.isWeb3Ready);
|
||||
@ -232,9 +233,29 @@ class BlockchainConnector {
|
||||
}
|
||||
|
||||
deployContractFromObject(deployContractObject, params, cb) {
|
||||
let deployer = this.deployers[deployContractObject._deployData];
|
||||
|
||||
if (!deployer) {
|
||||
deployer = {running: false, requested: []};
|
||||
this.deployers[deployContractObject._deployData] = deployer;
|
||||
}
|
||||
|
||||
if (deployer.running) {
|
||||
deployer.requested.push({deployContractObject, params, cb});
|
||||
return;
|
||||
}
|
||||
|
||||
deployer.running = true;
|
||||
embarkJsUtils.secureSend(this.web3, deployContractObject, {
|
||||
from: params.from, gas: params.gas, gasPrice: params.gasPrice
|
||||
}, true, cb);
|
||||
}, true, (error, receipt) => {
|
||||
deployer.running = false;
|
||||
if (deployer.requested.length > 0) {
|
||||
let request = deployer.requested.shift();
|
||||
this.deployContractFromObject(request.deployContractObject, request.params, request.cb);
|
||||
}
|
||||
cb(error, receipt);
|
||||
});
|
||||
}
|
||||
|
||||
determineDefaultAccount(cb) {
|
||||
|
@ -275,7 +275,7 @@ class ContractDeployer {
|
||||
if (error) {
|
||||
contract.error = error.message;
|
||||
self.events.emit("deploy:contract:error", contract);
|
||||
if (error.message && error.message.indexOf('replacement transaction underpriced')) {
|
||||
if (error.message && error.message.indexOf('replacement transaction underpriced') !== -1) {
|
||||
self.logger.warn("replacement transaction underpriced: This warning typically means a transaction exactly like this one is still pending on the blockchain");
|
||||
}
|
||||
return next(new Error("error deploying =" + contract.className + "= due to error: " + error.message));
|
||||
|
Loading…
x
Reference in New Issue
Block a user