resolve appears to be done, now I just need some help wiring the module together

Signed-off-by: VoR0220 <catalanor0220@gmail.com>
This commit is contained in:
VoR0220 2018-05-23 09:58:18 -05:00
parent 3aa4c9fd1f
commit 4de830ca29
2 changed files with 24 additions and 5 deletions

View File

@ -1,7 +1,8 @@
const namehash = require('eth-ens-namehash');
/*global web3*/
let __embarkENS = {};
/*
// registry interface for later
var registryInterface = [
{
@ -91,7 +92,6 @@ var registryInterface = [
"type": "function"
}
];
*/
var resolverInterface = [
{
@ -260,12 +260,12 @@ __embarkENS.setProvider = function (options) {
provider = options.server + ':' + options.port;
}
// TODO: take into account type
var web3 = new Web3(new Web3.providers.WebsocketProvider("ws://" + provider));
let web3 = new Web3(new Web3.providers.WebsocketProvider("ws://" + provider));
self.web3 = web3;
// get network id and then assign ENS contract based on that
self.ens = web3.eth.net.getId().then(id => {
if (registryAddresses[id] !== undefined) {
return new web3.eth.Contract(resolverInterface, registryAddresses[id]);
return new web3.eth.Contract(registryInterface, registryAddresses[id]);
}
// todo: deploy at this point
return undefined;
@ -273,6 +273,15 @@ __embarkENS.setProvider = function (options) {
}
__embarkENS.resolve = function(name) {
const self = this;
const web3 = this.web3;
if (this.ens === undefined)
return undefined;
let node = namehash(name)
this.ens.methods.resolver(node).call().then((resolverAddress) => {
let resolverContract = new web3.eth.Contract(resolverInterface, resolverAddress);
return resolverContract.methods.addr(node).call()
}).then((addr) => {
return addr
}).catch(err => err);
}

10
lib/modules/ens/index.js Normal file
View File

@ -0,0 +1,10 @@
const fs = require('../../core/fs.js');
class ENS {
constructor(embark, options) {
this.logger = embark.logger;
this.events = embark.events;
this.web3 = options.web3;
this.embark = embark;
}
}