mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-24 12:40:21 +00:00
fix: deploy hangs
The bug seems to be in web3 but we fix it by avoiding extra tx
This commit is contained in:
parent
ffb8f54939
commit
92610ed70a
@ -217,15 +217,25 @@ class ENS {
|
|||||||
}
|
}
|
||||||
|
|
||||||
registerConfigDomains(config, cb) {
|
registerConfigDomains(config, cb) {
|
||||||
const self = this;
|
|
||||||
const secureSend = embarkJsUtils.secureSend;
|
const secureSend = embarkJsUtils.secureSend;
|
||||||
|
|
||||||
self.events.request("blockchain:defaultAccount:get", (defaultAccount) => {
|
this.events.request("blockchain:defaultAccount:get", (defaultAccount) => {
|
||||||
async.each(Object.keys(self.registration.subdomains), (subDomainName, eachCb) => {
|
async.each(Object.keys(this.registration.subdomains), (subDomainName, eachCb) => {
|
||||||
const address = self.registration.subdomains[subDomainName];
|
const address = this.registration.subdomains[subDomainName];
|
||||||
|
this.ensResolve(`${subDomainName}.${this.registration.rootDomain}`, (error, currentAddress) => {
|
||||||
|
if (currentAddress && currentAddress.toLowerCase() === address.toLowerCase()) {
|
||||||
|
return eachCb();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (error) {
|
||||||
|
this.logger.error(error);
|
||||||
|
return eachCb();
|
||||||
|
}
|
||||||
|
|
||||||
const reverseNode = utils.soliditySha3(address.toLowerCase().substr(2) + reverseAddrSuffix);
|
const reverseNode = utils.soliditySha3(address.toLowerCase().substr(2) + reverseAddrSuffix);
|
||||||
ENSFunctions.registerSubDomain(self.ensContract, self.registrarContract, self.resolverContract, defaultAccount,
|
ENSFunctions.registerSubDomain(this.ensContract, this.registrarContract, this.resolverContract, defaultAccount,
|
||||||
subDomainName, self.registration.rootDomain, reverseNode, address, self.logger, secureSend, eachCb);
|
subDomainName, this.registration.rootDomain, reverseNode, address, this.logger, secureSend, eachCb);
|
||||||
|
});
|
||||||
}, cb);
|
}, cb);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -401,7 +411,7 @@ class ENS {
|
|||||||
paraCb(null, web3);
|
paraCb(null, web3);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
], (err, result) => {
|
], async (err, result) => {
|
||||||
self.ensContract = result[0];
|
self.ensContract = result[0];
|
||||||
self.registrarContract = result[1];
|
self.registrarContract = result[1];
|
||||||
self.resolverContract = result[2];
|
self.resolverContract = result[2];
|
||||||
@ -409,6 +419,12 @@ class ENS {
|
|||||||
|
|
||||||
const rootNode = namehash.hash(self.registration.rootDomain);
|
const rootNode = namehash.hash(self.registration.rootDomain);
|
||||||
var reverseNode = web3.utils.soliditySha3(web3.eth.defaultAccount.toLowerCase().substr(2) + reverseAddrSuffix);
|
var reverseNode = web3.utils.soliditySha3(web3.eth.defaultAccount.toLowerCase().substr(2) + reverseAddrSuffix);
|
||||||
|
const owner = await self.ensContract.methods.owner(rootNode).call();
|
||||||
|
|
||||||
|
if (owner === web3.eth.defaultAccount) {
|
||||||
|
return next();
|
||||||
|
}
|
||||||
|
|
||||||
self.ensContract.methods.setOwner(rootNode, web3.eth.defaultAccount).send({from: web3.eth.defaultAccount, gas: ENS_GAS_PRICE}).then(() => {
|
self.ensContract.methods.setOwner(rootNode, web3.eth.defaultAccount).send({from: web3.eth.defaultAccount, gas: ENS_GAS_PRICE}).then(() => {
|
||||||
return self.ensContract.methods.setResolver(rootNode, config.resolverAddress).send({from: web3.eth.defaultAccount, gas: ENS_GAS_PRICE});
|
return self.ensContract.methods.setResolver(rootNode, config.resolverAddress).send({from: web3.eth.defaultAccount, gas: ENS_GAS_PRICE});
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user