mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Merge pull request #4656 from MetaMask/portal-metamask-ens-test
Add support for .test ENS domains
This commit is contained in:
commit
3784a7e2c8
@ -448,4 +448,4 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- run:
|
- run:
|
||||||
name: All Tests Passed
|
name: All Tests Passed
|
||||||
command: echo 'weew - everything passed!'
|
command: echo 'weew - everything passed!'
|
@ -62,7 +62,8 @@
|
|||||||
"https://*.infura.io/",
|
"https://*.infura.io/",
|
||||||
"activeTab",
|
"activeTab",
|
||||||
"webRequest",
|
"webRequest",
|
||||||
"*://*.eth/"
|
"*://*.eth/",
|
||||||
|
"*://*.test/"
|
||||||
],
|
],
|
||||||
"web_accessible_resources": [
|
"web_accessible_resources": [
|
||||||
"inpage.js"
|
"inpage.js"
|
||||||
|
@ -53,6 +53,7 @@ const isIE = !!document.documentMode
|
|||||||
// Edge 20+
|
// Edge 20+
|
||||||
const isEdge = !isIE && !!window.StyleMedia
|
const isEdge = !isIE && !!window.StyleMedia
|
||||||
|
|
||||||
|
let ipfsHandle
|
||||||
let popupIsOpen = false
|
let popupIsOpen = false
|
||||||
let notificationIsOpen = false
|
let notificationIsOpen = false
|
||||||
const openMetamaskTabsIDs = {}
|
const openMetamaskTabsIDs = {}
|
||||||
@ -158,7 +159,7 @@ async function initialize () {
|
|||||||
const initLangCode = await getFirstPreferredLangCode()
|
const initLangCode = await getFirstPreferredLangCode()
|
||||||
await setupController(initState, initLangCode)
|
await setupController(initState, initLangCode)
|
||||||
log.debug('MetaMask initialization complete.')
|
log.debug('MetaMask initialization complete.')
|
||||||
ipfsContent(initState.NetworkController.provider)
|
ipfsHandle = ipfsContent(initState.NetworkController.provider)
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -262,6 +263,10 @@ function setupController (initState, initLangCode) {
|
|||||||
})
|
})
|
||||||
global.metamaskController = controller
|
global.metamaskController = controller
|
||||||
|
|
||||||
|
controller.networkController.on('networkDidChange', () => {
|
||||||
|
ipfsHandle && ipfsHandle.remove()
|
||||||
|
ipfsHandle = ipfsContent(controller.networkController.providerStore.getState())
|
||||||
|
})
|
||||||
|
|
||||||
// report failed transactions to Sentry
|
// report failed transactions to Sentry
|
||||||
controller.txController.on(`tx:status-update`, (txId, status) => {
|
controller.txController.on(`tx:status-update`, (txId, status) => {
|
||||||
|
@ -2,39 +2,43 @@ const extension = require('extensionizer')
|
|||||||
const resolver = require('./resolver.js')
|
const resolver = require('./resolver.js')
|
||||||
|
|
||||||
module.exports = function (provider) {
|
module.exports = function (provider) {
|
||||||
extension.webRequest.onBeforeRequest.addListener(details => {
|
function ipfsContent (details) {
|
||||||
const urlhttpreplace = details.url.replace(/\w+?:\/\//, '')
|
const name = details.url.substring(7, details.url.length - 1)
|
||||||
const url = urlhttpreplace.replace(/[\\/].*/g, '') // eslint-disable-line no-useless-escape
|
let clearTime = null
|
||||||
let domainhtml = urlhttpreplace.match(/[\\/].*/g) // eslint-disable-line no-useless-escape
|
extension.tabs.getSelected(null, tab => {
|
||||||
let clearTime = null
|
extension.tabs.update(tab.id, { url: 'loading.html' })
|
||||||
const name = url.replace(/\/$/g, '')
|
|
||||||
if (domainhtml === null) domainhtml = ['']
|
|
||||||
extension.tabs.getSelected(null, tab => {
|
|
||||||
extension.tabs.update(tab.id, { url: 'loading.html' })
|
|
||||||
|
|
||||||
clearTime = setTimeout(() => {
|
clearTime = setTimeout(() => {
|
||||||
return extension.tabs.update(tab.id, { url: '404.html' })
|
return extension.tabs.update(tab.id, { url: '404.html' })
|
||||||
}, 60000)
|
}, 60000)
|
||||||
|
|
||||||
resolver.resolve(name, provider).then(ipfsHash => {
|
resolver.resolve(name, provider).then(ipfsHash => {
|
||||||
clearTimeout(clearTime)
|
clearTimeout(clearTime)
|
||||||
let url = 'https://ipfs.infura.io/ipfs/' + ipfsHash + domainhtml[0]
|
let url = 'https://ipfs.infura.io/ipfs/' + ipfsHash
|
||||||
return fetch(url, { method: 'HEAD' }).then(response => response.status).then(statusCode => {
|
return fetch(url, { method: 'HEAD' }).then(response => response.status).then(statusCode => {
|
||||||
if (statusCode !== 200) return extension.tabs.update(tab.id, { url: '404.html' })
|
if (statusCode !== 200) return extension.tabs.update(tab.id, { url: '404.html' })
|
||||||
extension.tabs.update(tab.id, { url: url })
|
extension.tabs.update(tab.id, { url: url })
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
url = 'https://ipfs.infura.io/ipfs/' + ipfsHash + domainhtml[0]
|
url = 'https://ipfs.infura.io/ipfs/' + ipfsHash
|
||||||
extension.tabs.update(tab.id, {url: url})
|
extension.tabs.update(tab.id, {url: url})
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
clearTimeout(clearTime)
|
clearTimeout(clearTime)
|
||||||
const url = err === 'unsupport' ? 'unsupport' : 'error'
|
const url = err === 'unsupport' ? 'unsupport' : 'error'
|
||||||
extension.tabs.update(tab.id, {url: `${url}.html?name=${name}`})
|
extension.tabs.update(tab.id, {url: `${url}.html?name=${name}`})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
return { cancel: true }
|
return { cancel: true }
|
||||||
}, {urls: ['*://*.eth/', '*://*.eth/*']})
|
}
|
||||||
|
|
||||||
|
extension.webRequest.onBeforeRequest.addListener(ipfsContent, {urls: ['*://*.eth/', '*://*.test/']})
|
||||||
|
|
||||||
|
return {
|
||||||
|
remove () {
|
||||||
|
extension.webRequest.onBeforeRequest.removeListener(ipfsContent)
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -60,8 +60,8 @@ function getRegistrar (type) {
|
|||||||
|
|
||||||
module.exports.resolve = function (name, provider) {
|
module.exports.resolve = function (name, provider) {
|
||||||
const path = name.split('.')
|
const path = name.split('.')
|
||||||
const tld = path[path.length - 1]
|
const topLevelDomain = path[path.length - 1]
|
||||||
if (tld === 'eth') {
|
if (topLevelDomain === 'eth' || topLevelDomain === 'test') {
|
||||||
return ens(name, provider)
|
return ens(name, provider)
|
||||||
} else {
|
} else {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user