Added RNS integration
This commit is contained in:
parent
eb14ba7bce
commit
21d58f5a5f
|
@ -355,6 +355,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "ENS name not found"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "RNS name not found"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "Enter password"
|
||||
},
|
||||
|
|
|
@ -349,6 +349,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "Nom ENS inconnu"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "Nom RNS inconnu"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "Entrez votre mot de passe"
|
||||
},
|
||||
|
|
|
@ -313,6 +313,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "Nou pa jwenn non ENS ou a"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "Nou pa jwenn non RNS ou a"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "Mete modpas"
|
||||
},
|
||||
|
|
|
@ -352,6 +352,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "Nome ENS non trovato"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "Nome RNS non trovato"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "Inserisci password"
|
||||
},
|
||||
|
|
|
@ -349,6 +349,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "ENS 이름을 찾을 수 없습니다"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "RNS 이름을 찾을 수 없습니다"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "비밀번호를 입력해주세요"
|
||||
},
|
||||
|
|
|
@ -313,6 +313,9 @@
|
|||
"ensNameNotFound": {
|
||||
"message": "Nie znaleziono nazwy ENS"
|
||||
},
|
||||
"rnsNameNotFound": {
|
||||
"message": "Nie znaleziono nazwy RNS"
|
||||
},
|
||||
"enterPassword": {
|
||||
"message": "Wpisz hasło"
|
||||
},
|
||||
|
|
|
@ -5,11 +5,15 @@ const debounce = require('debounce')
|
|||
const copyToClipboard = require('copy-to-clipboard')
|
||||
const ENS = require('ethjs-ens')
|
||||
const networkMap = require('ethjs-ens/lib/network-map.json')
|
||||
const RNSRegistryData = require('@rsksmart/rns-registry/RNSRegistryData.json');
|
||||
const ensRE = /.+\..+$/
|
||||
const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000'
|
||||
const log = require('loglevel')
|
||||
const { isValidENSAddress } = require('../util')
|
||||
|
||||
const { isValidENSAddress, isValidRNSAddress } = require('../util')
|
||||
const {
|
||||
RSK_CODE,
|
||||
RSK_TESTNET_CODE,
|
||||
} = require('../../../app/scripts/controllers/network/enums')
|
||||
|
||||
module.exports = EnsInput
|
||||
|
||||
|
@ -24,7 +28,8 @@ EnsInput.prototype.render = function () {
|
|||
function onInputChange () {
|
||||
const network = this.props.network
|
||||
const networkHasEnsSupport = getNetworkEnsSupport(network)
|
||||
if (!networkHasEnsSupport) return
|
||||
const networkHasRnsSupport = getNetworkRnsSupport(network)
|
||||
if (!networkHasEnsSupport && !networkHasRnsSupport) return
|
||||
|
||||
const recipient = document.querySelector('input[name="address"]').value
|
||||
if (recipient.match(ensRE) === null) {
|
||||
|
@ -81,20 +86,26 @@ EnsInput.prototype.render = function () {
|
|||
EnsInput.prototype.componentDidMount = function () {
|
||||
const network = this.props.network
|
||||
const networkHasEnsSupport = getNetworkEnsSupport(network)
|
||||
const rnsRegistry = getNetworkRnsSupport(network)
|
||||
|
||||
this.setState({ ensResolution: ZERO_ADDRESS })
|
||||
|
||||
if (networkHasEnsSupport) {
|
||||
const provider = global.ethereumProvider
|
||||
this.ens = new ENS({ provider, network })
|
||||
this.checkName = debounce(this.lookupEnsName.bind(this), 200)
|
||||
this.checkName = debounce(this.lookupEnsName.bind(this, 'ENS'), 200)
|
||||
} else if (rnsRegistry) {
|
||||
const provider = global.ethereumProvider
|
||||
this.ens = new ENS({ provider, network, registryAddress: rnsRegistry })
|
||||
this.checkName = debounce(this.lookupEnsName.bind(this, 'RNS'), 200)
|
||||
}
|
||||
}
|
||||
|
||||
EnsInput.prototype.lookupEnsName = function () {
|
||||
EnsInput.prototype.lookupEnsName = function (nameService) {
|
||||
const recipient = document.querySelector('input[name="address"]').value
|
||||
const { ensResolution } = this.state
|
||||
|
||||
log.info(`ENS attempting to resolve name: ${recipient}`)
|
||||
log.info(`${nameService} attempting to resolve name: ${recipient}`)
|
||||
this.ens.lookup(recipient.trim())
|
||||
.then((address) => {
|
||||
if (address === ZERO_ADDRESS) throw new Error('No address has been set for this name.')
|
||||
|
@ -116,9 +127,12 @@ EnsInput.prototype.lookupEnsName = function () {
|
|||
ensFailure: true,
|
||||
toError: null,
|
||||
}
|
||||
if (isValidENSAddress(recipient) && reason.message === 'ENS name not defined.') {
|
||||
setStateObj.hoverText = 'ENS name not found'
|
||||
setStateObj.toError = 'ensNameNotFound'
|
||||
if (
|
||||
(isValidENSAddress(recipient) || isValidRNSAddress(recipient))
|
||||
&& reason.message === 'ENS name not defined.'
|
||||
) {
|
||||
setStateObj.hoverText = `${nameService} name not found`
|
||||
setStateObj.toError = `${nameService.toLowerCase}NameNotFound`
|
||||
setStateObj.ensFailure = false
|
||||
} else {
|
||||
log.error(reason)
|
||||
|
@ -198,3 +212,15 @@ EnsInput.prototype.ensIconContents = function (recipient) {
|
|||
function getNetworkEnsSupport (network) {
|
||||
return Boolean(networkMap[network])
|
||||
}
|
||||
|
||||
function getNetworkRnsSupport (network) {
|
||||
if (network == RSK_CODE) {
|
||||
return RNSRegistryData.address.rskMainnet;
|
||||
}
|
||||
|
||||
if (network == RSK_TESTNET_CODE) {
|
||||
return RNSRegistryData.address.rskTestnet;
|
||||
};
|
||||
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -67,6 +67,7 @@ module.exports = {
|
|||
isAllOneCase,
|
||||
isValidAddress,
|
||||
isValidENSAddress,
|
||||
isValidRNSAddress,
|
||||
numericBalance,
|
||||
parseBalance,
|
||||
formatBalance,
|
||||
|
@ -139,6 +140,10 @@ function isValidENSAddress (address) {
|
|||
return address.match(/^.{7,}\.(eth|test)$/)
|
||||
}
|
||||
|
||||
function isValidRNSAddress (address) {
|
||||
return address.match(/([a-z0-9])+\.(rsk)/)
|
||||
}
|
||||
|
||||
function isInvalidChecksumAddress (address, network) {
|
||||
const prefixed = ethUtil.addHexPrefix(address)
|
||||
if (address === '0x0000000000000000000000000000000000000000') return false
|
||||
|
|
|
@ -1966,6 +1966,14 @@
|
|||
"react-lifecycles-compat": "^3.0.4"
|
||||
}
|
||||
},
|
||||
"@rsksmart/rns-registry": {
|
||||
"version": "1.0.4",
|
||||
"resolved": "https://registry.npmjs.org/@rsksmart/rns-registry/-/rns-registry-1.0.4.tgz",
|
||||
"integrity": "sha512-phhzFT2URDi+buxychLvaKPtSytGvXh+HVJUUwvyAHDjvBPXiBSLr7OTnaciVYjVnTns++lwcMoVdgqQMVt3xQ==",
|
||||
"requires": {
|
||||
"minimist": "^1.2.3"
|
||||
}
|
||||
},
|
||||
"@rsksmart/rsk-contract-metadata": {
|
||||
"version": "github:rsksmart/rsk-contract-metadata#d7913739e5ee93dac8667043e2c17b0ef339c206",
|
||||
"from": "github:rsksmart/rsk-contract-metadata#master"
|
||||
|
|
|
@ -85,6 +85,7 @@
|
|||
"dependencies": {
|
||||
"@babel/runtime": "^7.5.5",
|
||||
"@material-ui/core": "^4.1.1",
|
||||
"@rsksmart/rns-registry": "^1.0.4",
|
||||
"@rsksmart/rsk-contract-metadata": "github:rsksmart/rsk-contract-metadata#master",
|
||||
"@rsksmart/rsk-testnet-contract-metadata": "github:rsksmart/rsk-testnet-contract-metadata#master",
|
||||
"@zxing/library": "^0.8.0",
|
||||
|
|
Loading…
Reference in New Issue