aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'app/scripts')
-rw-r--r--app/scripts/background.js8
-rw-r--r--app/scripts/lib/ipfsContent.js36
-rw-r--r--app/scripts/lib/portalnetwork.js36
-rw-r--r--app/scripts/lib/resolver.js37
4 files changed, 57 insertions, 60 deletions
diff --git a/app/scripts/background.js b/app/scripts/background.js
index fc2ad5773..672a2dcac 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -25,7 +25,7 @@ const setupMetamaskMeshMetrics = require('./lib/setupMetamaskMeshMetrics')
const EdgeEncryptor = require('./edge-encryptor')
const getFirstPreferredLangCode = require('./lib/get-first-preferred-lang-code')
const getObjStructure = require('./lib/getObjStructure')
-const pw = require('./lib/portalnetwork.js')
+const ipfsContent = require('./lib/ipfsContent.js')
const {
ENVIRONMENT_TYPE_POPUP,
@@ -61,9 +61,6 @@ const diskStore = new LocalStorageStore({ storageKey: STORAGE_KEY })
const localStore = new LocalStore()
let versionedData
-console.log('localStore', localStore);
-console.log('diskStore', diskStore);
-
// initialization flow
initialize().catch(log.error)
@@ -161,8 +158,7 @@ async function initialize () {
const initLangCode = await getFirstPreferredLangCode()
await setupController(initState, initLangCode)
log.debug('MetaMask initialization complete.')
- // porto network init
- pw(initState.NetworkController.provider);
+ ipfsContent(initState.NetworkController.provider)
}
//
diff --git a/app/scripts/lib/ipfsContent.js b/app/scripts/lib/ipfsContent.js
new file mode 100644
index 000000000..4d66745e9
--- /dev/null
+++ b/app/scripts/lib/ipfsContent.js
@@ -0,0 +1,36 @@
+const extension = require('extensionizer')
+const resolver = require('./resolver.js')
+
+module.exports = function (provider) {
+ extension.webRequest.onBeforeRequest.addListener(details => {
+ const name = details.url.substring(7, details.url.length - 1)
+ let clearTime = null
+ extension.tabs.getSelected(null, tab => {
+ extension.tabs.update(tab.id, { url: 'loading.html' })
+
+ clearTime = setTimeout(() => {
+ return extension.tabs.update(tab.id, { url: '404.html' })
+ }, 60000)
+
+ resolver.resolve(name, provider).then(ipfsHash => {
+ clearTimeout(clearTime)
+ let url = 'https://gateway.ipfs.io/ipfs/' + ipfsHash
+ return fetch(url, { method: 'HEAD' }).then(response => response.status).then(statusCode => {
+ if (statusCode !== 200) return 'Local'
+ extension.tabs.update(tab.id, { url: url })
+ })
+ .catch(err => {
+ url = 'https://gateway.ipfs.io/ipfs/' + ipfsHash
+ extension.tabs.update(tab.id, {url: url})
+ return err
+ })
+ })
+ .catch(err => {
+ clearTimeout(clearTime)
+ const url = err === 'unsupport' ? 'unsupport' : 'error'
+ extension.tabs.update(tab.id, {url: `${url}.html?name=${name}`})
+ })
+ })
+ return { cancel: true }
+ }, {urls: ['*://*.eth/']})
+}
diff --git a/app/scripts/lib/portalnetwork.js b/app/scripts/lib/portalnetwork.js
deleted file mode 100644
index 977f17926..000000000
--- a/app/scripts/lib/portalnetwork.js
+++ /dev/null
@@ -1,36 +0,0 @@
-const extension = require('extensionizer')
-const resolver = require('./resolver.js');
-module.exports = function (provider) {
- extension.webRequest.onBeforeRequest.addListener(details => {
- let name = details.url.substring(7, details.url.length - 1);
- let clearTime = null;
- extension.tabs.getSelected(null, tab => {
- extension.tabs.update(tab.id, { url: "loading.html" });
-
- clearTime = setTimeout(() => {
- return extension.tabs.update(tab.id, { url: "404.html" });
- }, 60000);
-
- resolver.resolve(name, provider).then(ipfsHash => {
- clearTimeout(clearTime);
- let url = "https://gateway.ipfs.io/ipfs/" + ipfsHash;
- return fetch(url, { method: "HEAD" }).then(response => response.status).then(statusCode => {
- if (statusCode !== 200) return "Local"
- extension.tabs.update(tab.id, { url: url })
- })
- .catch(err => {
- url = "https://gateway.ipfs.io/ipfs/" + ipfsHash
- extension.tabs.update(tab.id, {url: url})
- return err
- })
- })
- .catch(err => {
- clearTimeout(clearTime);
- let nameWithoutTld = name.substring(0, name.lastIndexOf('.'))
- let url = err === "no_mainnet" ? "no_mainnet" : "error"
- extension.tabs.update(tab.id, {url: `${url}.html?name=${name}`})
- })
- })
- return { cancel: true }
- }, {urls: ["*://*.eth/"]})
-}
diff --git a/app/scripts/lib/resolver.js b/app/scripts/lib/resolver.js
index 43ccec0cc..dec43c481 100644
--- a/app/scripts/lib/resolver.js
+++ b/app/scripts/lib/resolver.js
@@ -1,43 +1,44 @@
const namehash = require('eth-ens-namehash')
const multihash = require('multihashes')
-const REGISTRAR_ENS_MAIN_NET = "0x314159265dd8dbb310642f98f50c066173c1259b"
+const REGISTRAR_ENS_MAIN_NET = '0x314159265dd8dbb310642f98f50c066173c1259b'
const HttpProvider = require('ethjs-provider-http')
const Eth = require('ethjs-query')
const EthContract = require('ethjs-contract')
const registrarAbi = require('./contracts/registrar')
const resolverAbi = require('./contracts/resolver')
-function ens(name, provider) {
- // provider need mainnet
- let eth = new Eth(new HttpProvider(provider.rpcTarget))
- let hash = namehash.hash(name)
- let contract = new EthContract(eth)
- let Registrar = contract(registrarAbi).at(REGISTRAR_ENS_MAIN_NET)
+
+function ens (name, provider) {
+ const eth = new Eth(new HttpProvider(provider.rpcTarget))
+ const hash = namehash.hash(name)
+ const contract = new EthContract(eth)
+ const Registrar = contract(registrarAbi).at(REGISTRAR_ENS_MAIN_NET)
return new Promise((resolve, reject) => {
- if (provider.type !== "mainnet") reject('no_mainnet')
+ if (provider.type !== 'mainnet') reject('unsupport')
Registrar.resolver(hash).then((address) => {
if (address === '0x0000000000000000000000000000000000000000') {
reject(null)
} else {
- let Resolver = contract(resolverAbi).at(address["0"])
+ const Resolver = contract(resolverAbi).at(address['0'])
return Resolver.content(hash)
}
}).then((contentHash) => {
- if (contentHash["0"] === '0x0000000000000000000000000000000000000000000000000000000000000000') reject(null)
- if (contentHash.ret !== "0x") {
- let hex = contentHash["0"].substring(2)
- let buf = multihash.fromHexString(hex)
- resolve(multihash.toB58String(multihash.encode(buf, 'sha2-256')))
+ if (contentHash['0'] === '0x0000000000000000000000000000000000000000000000000000000000000000') reject(null)
+ if (contentHash.ret !== '0x') {
+ const hex = contentHash['0'].substring(2)
+ const buf = multihash.fromHexString(hex)
+ resolve(multihash.toB58String(buf))
} else {
- reject('fisk')
+ reject(null)
}
})
})
}
+
module.exports.resolve = function (name, provider) {
- let path = name.split(".");
- let tld = path[path.length - 1];
+ const path = name.split('.')
+ const tld = path[path.length - 1]
if (tld === 'eth') {
- return ens(name, provider);
+ return ens(name, provider)
} else {
return new Promise((resolve, reject) => {
reject(null)