mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Stop adding permissions middleware to trusted connections (#8701)
* don't add permissions middleware to trusted connections * fix test case
This commit is contained in:
parent
ddaa492751
commit
cf60c8e1f6
@ -1548,7 +1548,7 @@ export default class MetamaskController extends EventEmitter {
|
|||||||
tabId = sender.tab.id
|
tabId = sender.tab.id
|
||||||
}
|
}
|
||||||
|
|
||||||
const engine = this.setupProviderEngine({ origin, location: sender.url, extensionId, tabId })
|
const engine = this.setupProviderEngine({ origin, location: sender.url, extensionId, tabId, isInternal })
|
||||||
|
|
||||||
// setup connection
|
// setup connection
|
||||||
const providerStream = createEngineStream({ engine })
|
const providerStream = createEngineStream({ engine })
|
||||||
@ -1581,8 +1581,9 @@ export default class MetamaskController extends EventEmitter {
|
|||||||
* @param {string} options.location - The full URL of the sender
|
* @param {string} options.location - The full URL of the sender
|
||||||
* @param {extensionId} [options.extensionId] - The extension ID of the sender, if the sender is an external extension
|
* @param {extensionId} [options.extensionId] - The extension ID of the sender, if the sender is an external extension
|
||||||
* @param {tabId} [options.tabId] - The tab ID of the sender - if the sender is within a tab
|
* @param {tabId} [options.tabId] - The tab ID of the sender - if the sender is within a tab
|
||||||
|
* @param {boolean} [options.isInternal] - True if called for a connection to an internal process
|
||||||
**/
|
**/
|
||||||
setupProviderEngine ({ origin, location, extensionId, tabId }) {
|
setupProviderEngine ({ origin, location, extensionId, tabId, isInternal = false }) {
|
||||||
// setup json rpc engine stack
|
// setup json rpc engine stack
|
||||||
const engine = new RpcEngine()
|
const engine = new RpcEngine()
|
||||||
const provider = this.provider
|
const provider = this.provider
|
||||||
@ -1610,8 +1611,10 @@ export default class MetamaskController extends EventEmitter {
|
|||||||
// filter and subscription polyfills
|
// filter and subscription polyfills
|
||||||
engine.push(filterMiddleware)
|
engine.push(filterMiddleware)
|
||||||
engine.push(subscriptionManager.middleware)
|
engine.push(subscriptionManager.middleware)
|
||||||
|
if (!isInternal) {
|
||||||
// permissions
|
// permissions
|
||||||
engine.push(this.permissionsController.createMiddleware({ origin, extensionId }))
|
engine.push(this.permissionsController.createMiddleware({ origin, extensionId }))
|
||||||
|
}
|
||||||
// watch asset
|
// watch asset
|
||||||
engine.push(this.preferencesController.requestWatchAsset.bind(this.preferencesController))
|
engine.push(this.preferencesController.requestWatchAsset.bind(this.preferencesController))
|
||||||
// forward to metamask primary provider
|
// forward to metamask primary provider
|
||||||
|
@ -102,8 +102,8 @@ describe('permissions controller', function () {
|
|||||||
assert.deepEqual(cAccounts, [], 'origin should have no accounts')
|
assert.deepEqual(cAccounts, [], 'origin should have no accounts')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('does not handle "MetaMask" origin as special case', async function () {
|
it('does not handle "metamask" origin as special case', async function () {
|
||||||
const metamaskAccounts = await permController.getAccounts('MetaMask')
|
const metamaskAccounts = await permController.getAccounts('metamask')
|
||||||
assert.deepEqual(metamaskAccounts, [], 'origin should have no accounts')
|
assert.deepEqual(metamaskAccounts, [], 'origin should have no accounts')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user