aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakub Stasiak <kubafr2@gmail.com>2018-04-12 00:32:27 +0800
committerJakub Stasiak <kubafr2@gmail.com>2018-04-18 03:49:40 +0800
commitad7d38c0dc206074379c813b307ed9350c7efeb0 (patch)
treeca75631e551a7d2d608681474cb15e82267f52d2
parent7b70804aa0d74120098a4bcb2c375d29080e8368 (diff)
downloadtangerine-wallet-browser-ad7d38c0dc206074379c813b307ed9350c7efeb0.tar.gz
tangerine-wallet-browser-ad7d38c0dc206074379c813b307ed9350c7efeb0.tar.zst
tangerine-wallet-browser-ad7d38c0dc206074379c813b307ed9350c7efeb0.zip
Update: allow other extension to connect
-rw-r--r--app/manifest.json3
-rw-r--r--app/scripts/background.js14
2 files changed, 12 insertions, 5 deletions
diff --git a/app/manifest.json b/app/manifest.json
index dc46f1ca4..950bab2f1 100644
--- a/app/manifest.json
+++ b/app/manifest.json
@@ -67,6 +67,7 @@
"externally_connectable": {
"matches": [
"https://metamask.io/*"
- ]
+ ],
+ "ids": ["*"]
}
} \ No newline at end of file
diff --git a/app/scripts/background.js b/app/scripts/background.js
index 6550e8944..6296eaa21 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -197,6 +197,7 @@ function setupController (initState, initLangCode) {
// connect to other contexts
//
extension.runtime.onConnect.addListener(connectRemote)
+ extension.runtime.onConnectExternal.addListener(connectExternal)
const metamaskInternalProcessHash = {
[ENVIRONMENT_TYPE_POPUP]: true,
@@ -211,9 +212,9 @@ function setupController (initState, initLangCode) {
function connectRemote (remotePort) {
const processName = remotePort.name
const isMetaMaskInternalProcess = metamaskInternalProcessHash[processName]
- const portStream = new PortStream(remotePort)
if (isMetaMaskInternalProcess) {
+ const portStream = new PortStream(remotePort)
// communication with popup
controller.isClientOpen = true
controller.setupTrustedCommunication(portStream, 'MetaMask')
@@ -246,12 +247,17 @@ function setupController (initState, initLangCode) {
})
}
} else {
- // communication with page
- const originDomain = urlUtil.parse(remotePort.sender.url).hostname
- controller.setupUntrustedCommunication(portStream, originDomain)
+ connectExternal(remotePort)
}
}
+ // communication with page or other extension
+ function connectExternal(remotePort) {
+ const originDomain = urlUtil.parse(remotePort.sender.url).hostname
+ const portStream = new PortStream(remotePort)
+ controller.setupUntrustedCommunication(portStream, originDomain)
+ }
+
//
// User Interface setup
//