mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-11 22:44:45 +00:00
add function to register the domains from config
This commit is contained in:
parent
1c881274b1
commit
67da4e6a84
@ -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,7 +39,38 @@ 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);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -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));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user