mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
728115171e
The 'reverseResolveAddress' method is intended to return undefined if unable to reverse resolve the given address. Instead it was throwing an error, which surfaced in the UI console. This error is now caught.
95 lines
2.2 KiB
JavaScript
95 lines
2.2 KiB
JavaScript
const ethUtil = require('ethereumjs-util')
|
|
const ObservableStore = require('obs-store')
|
|
const punycode = require('punycode')
|
|
const log = require('loglevel')
|
|
const Ens = require('./ens')
|
|
|
|
const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000'
|
|
const ZERO_X_ERROR_ADDRESS = '0x'
|
|
|
|
class EnsController {
|
|
constructor ({ ens, provider, networkStore } = {}) {
|
|
const initState = {
|
|
ensResolutionsByAddress: {},
|
|
}
|
|
|
|
this._ens = ens
|
|
if (!this._ens) {
|
|
const network = networkStore.getState()
|
|
if (Ens.getNetworkEnsSupport(network)) {
|
|
this._ens = new Ens({
|
|
network,
|
|
provider,
|
|
})
|
|
}
|
|
}
|
|
|
|
this.store = new ObservableStore(initState)
|
|
networkStore.subscribe((network) => {
|
|
this.store.putState(initState)
|
|
if (Ens.getNetworkEnsSupport(network)) {
|
|
this._ens = new Ens({
|
|
network,
|
|
provider,
|
|
})
|
|
} else {
|
|
delete this._ens
|
|
}
|
|
})
|
|
}
|
|
|
|
reverseResolveAddress (address) {
|
|
return this._reverseResolveAddress(ethUtil.toChecksumAddress(address))
|
|
}
|
|
|
|
async _reverseResolveAddress (address) {
|
|
if (!this._ens) {
|
|
return undefined
|
|
}
|
|
|
|
const state = this.store.getState()
|
|
if (state.ensResolutionsByAddress[address]) {
|
|
return state.ensResolutionsByAddress[address]
|
|
}
|
|
|
|
let domain
|
|
try {
|
|
domain = await this._ens.reverse(address)
|
|
} catch (error) {
|
|
log.debug(error)
|
|
return undefined
|
|
}
|
|
|
|
let registeredAddress
|
|
try {
|
|
registeredAddress = await this._ens.lookup(domain)
|
|
} catch (error) {
|
|
log.debug(error)
|
|
return undefined
|
|
}
|
|
|
|
if (registeredAddress === ZERO_ADDRESS || registeredAddress === ZERO_X_ERROR_ADDRESS) {
|
|
return undefined
|
|
}
|
|
|
|
if (ethUtil.toChecksumAddress(registeredAddress) !== address) {
|
|
return undefined
|
|
}
|
|
|
|
this._updateResolutionsByAddress(address, punycode.toASCII(domain))
|
|
return domain
|
|
}
|
|
|
|
_updateResolutionsByAddress (address, domain) {
|
|
const oldState = this.store.getState()
|
|
this.store.putState({
|
|
ensResolutionsByAddress: {
|
|
...oldState.ensResolutionsByAddress,
|
|
[address]: domain,
|
|
},
|
|
})
|
|
}
|
|
}
|
|
|
|
module.exports = EnsController
|