add function to register the domains from config

This commit is contained in:
Jonathan Rainville 2018-07-13 16:41:35 -04:00
parent f0746a8d8b
commit 3265218000
1 changed files with 39 additions and 4 deletions

View File

@ -5,7 +5,6 @@ const async = require('async');
class ENS { class ENS {
constructor(embark, _options) { constructor(embark, _options) {
const self = this;
this.logger = embark.logger; this.logger = embark.logger;
this.events = embark.events; this.events = embark.events;
this.namesConfig = embark.config.namesystemConfig; this.namesConfig = embark.config.namesystemConfig;
@ -14,7 +13,11 @@ class ENS {
this.addENSToEmbarkJS(); this.addENSToEmbarkJS();
this.configureContracts(); this.configureContracts();
this.registerEvents();
}
registerEvents() {
const self = this;
self.embark.registerActionForEvent("contracts:deploy:afterAll", (cb) => { self.embark.registerActionForEvent("contracts:deploy:afterAll", (cb) => {
async.parallel([ async.parallel([
function getENSRegistry(paraCb) { function getENSRegistry(paraCb) {
@ -28,6 +31,7 @@ class ENS {
}); });
} }
], (err, results) => { ], (err, results) => {
// result[0] => ENSRegistry; result[1] => FIFSRegistrar
let config = { let config = {
registryAbi: results[0].abiDefinition, registryAbi: results[0].abiDefinition,
registryAddress: results[0].deployedAddress, registryAddress: results[0].deployedAddress,
@ -35,11 +39,42 @@ class ENS {
registrarAddress: results[1].deployedAddress registrarAddress: results[1].deployedAddress
}; };
self.addSetProvider(config); self.addSetProvider(config);
cb();
if (!self.registration || !self.registration.domains || !Object.keys(self.registration.domains).length) {
return cb();
}
self.registerConfigDomains(config, cb);
}); });
}); });
} }
registerConfigDomains(config, cb) {
const self = this;
self.events.request("blockchain:defaultAccount:get", (defaultAccount) => {
self.events.request("blockchain:contract:create",
{abi: config.registrarAbi, address: config.registrarAddress},
(registrar) => {
async.each(Object.keys(self.registration.domains), (subDomainName, eachCb) => {
const toSend = registrar.methods.register(utils.sha3(subDomainName),
defaultAccount, self.registration.domains[subDomainName]);
toSend.estimateGas().then(gasEstimated => {
return toSend.send({gas: gasEstimated + 1000, from: defaultAccount}).then(transaction => {
if (transaction.status !== "0x1" && transaction.status !== "0x01" && transaction.status !== true) {
return eachCb('Failed to register. Check gas cost.');
}
eachCb(null, transaction);
}).catch(err => {
eachCb('Failed to register with error: ' + (err.message || err));
});
}).catch(err => {
eachCb("Register would error. Is it already registered? Do you have token balance? Is Allowance set? " + (err.message || err));
});
}, cb);
});
});
}
addENSToEmbarkJS() { addENSToEmbarkJS() {
const self = this; const self = this;
// TODO: make this a shouldAdd condition // TODO: make this a shouldAdd condition
@ -52,10 +87,10 @@ class ENS {
} }
// get namehash, import it into file // get namehash, import it into file
self.events.request("version:get:eth-ens-namehash", function(EnsNamehashVersion) { self.events.request("version:get:eth-ens-namehash", function (EnsNamehashVersion) {
let currentEnsNamehashVersion = require('../../../package.json').dependencies["eth-ens-namehash"]; let currentEnsNamehashVersion = require('../../../package.json').dependencies["eth-ens-namehash"];
if (EnsNamehashVersion !== currentEnsNamehashVersion) { if (EnsNamehashVersion !== currentEnsNamehashVersion) {
self.events.request("version:getPackageLocation", "eth-ens-namehash", EnsNamehashVersion, function(err, location) { self.events.request("version:getPackageLocation", "eth-ens-namehash", EnsNamehashVersion, function (err, location) {
self.embark.registerImportFile("eth-ens-namehash", fs.dappPath(location)); self.embark.registerImportFile("eth-ens-namehash", fs.dappPath(location));
}); });
} }