mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Added subjectType
to setupProviderConnection
and setupUntrustedCommunication
(#13437)
These changes were split off from the snaps branch [here](https://github.com/MetaMask/metamask-extension/pull/11837#discussion_r792942834). The `subjectType` is necessary to handle connecting to snaps using these methods.
This commit is contained in:
parent
bac20099e5
commit
3772dfee11
@ -414,7 +414,10 @@ function setupController(initState, initLangCode) {
|
||||
// communication with page or other extension
|
||||
function connectExternal(remotePort) {
|
||||
const portStream = new PortStream(remotePort);
|
||||
controller.setupUntrustedCommunication(portStream, remotePort.sender);
|
||||
controller.setupUntrustedCommunication({
|
||||
connectionStream: portStream,
|
||||
sender: remotePort.sender,
|
||||
});
|
||||
}
|
||||
|
||||
//
|
||||
|
@ -2650,11 +2650,23 @@ export default class MetamaskController extends EventEmitter {
|
||||
* Used to create a multiplexed stream for connecting to an untrusted context
|
||||
* like a Dapp or other extension.
|
||||
*
|
||||
* @param {*} connectionStream - The Duplex stream to connect to.
|
||||
* @param {MessageSender} sender - The sender of the messages on this stream
|
||||
* @param options - Options bag.
|
||||
* @param {ReadableStream} options.connectionStream - The Duplex stream to connect to.
|
||||
* @param {MessageSender | SnapSender} options.sender - The sender of the messages on this stream.
|
||||
* @param {string} [options.subjectType] - The type of the sender, i.e. subject.
|
||||
*/
|
||||
setupUntrustedCommunication(connectionStream, sender) {
|
||||
setupUntrustedCommunication({ connectionStream, sender, subjectType }) {
|
||||
const { usePhishDetect } = this.preferencesController.store.getState();
|
||||
let _subjectType;
|
||||
if (subjectType) {
|
||||
_subjectType = subjectType;
|
||||
} else if (sender.id && sender.id !== this.extension.runtime.id) {
|
||||
_subjectType = SUBJECT_TYPES.EXTENSION;
|
||||
} else {
|
||||
_subjectType = SUBJECT_TYPES.WEBSITE;
|
||||
}
|
||||
|
||||
if (sender.url) {
|
||||
const { hostname } = new URL(sender.url);
|
||||
// Check if new connection is blocked if phishing detection is on
|
||||
if (usePhishDetect && this.phishingController.test(hostname)) {
|
||||
@ -2662,17 +2674,24 @@ export default class MetamaskController extends EventEmitter {
|
||||
this.sendPhishingWarning(connectionStream, hostname);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
// setup multiplexing
|
||||
const mux = setupMultiplex(connectionStream);
|
||||
|
||||
// messages between inpage and background
|
||||
this.setupProviderConnection(mux.createStream('metamask-provider'), sender);
|
||||
this.setupProviderConnection(
|
||||
mux.createStream('metamask-provider'),
|
||||
sender,
|
||||
_subjectType,
|
||||
);
|
||||
|
||||
// TODO:LegacyProvider: Delete
|
||||
if (sender.url) {
|
||||
// legacy streams
|
||||
this.setupPublicConfig(mux.createStream('publicConfig'));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Used to create a multiplexed stream for connecting to a trusted context,
|
||||
@ -2688,7 +2707,11 @@ export default class MetamaskController extends EventEmitter {
|
||||
const mux = setupMultiplex(connectionStream);
|
||||
// connect features
|
||||
this.setupControllerConnection(mux.createStream('controller'));
|
||||
this.setupProviderConnection(mux.createStream('provider'), sender, true);
|
||||
this.setupProviderConnection(
|
||||
mux.createStream('provider'),
|
||||
sender,
|
||||
SUBJECT_TYPES.INTERNAL,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -2747,17 +2770,19 @@ export default class MetamaskController extends EventEmitter {
|
||||
*
|
||||
* @param {*} outStream - The stream to provide over.
|
||||
* @param {MessageSender} sender - The sender of the messages on this stream
|
||||
* @param {boolean} isInternal - True if this is a connection with an internal process
|
||||
* @param {string} subjectType - The type of the sender, i.e. subject.
|
||||
*/
|
||||
setupProviderConnection(outStream, sender, isInternal) {
|
||||
const origin = isInternal ? 'metamask' : new URL(sender.url).origin;
|
||||
let subjectType = isInternal
|
||||
? SUBJECT_TYPES.INTERNAL
|
||||
: SUBJECT_TYPES.WEBSITE;
|
||||
setupProviderConnection(outStream, sender, subjectType) {
|
||||
let origin;
|
||||
if (subjectType === SUBJECT_TYPES.INTERNAL) {
|
||||
origin = 'metamask';
|
||||
} else {
|
||||
origin = new URL(sender.url).origin;
|
||||
}
|
||||
|
||||
if (sender.id !== this.extension.runtime.id) {
|
||||
subjectType = SUBJECT_TYPES.EXTENSION;
|
||||
this.subjectMetadataController.addSubjectMetadata(origin, {
|
||||
if (sender.id && sender.id !== this.extension.runtime.id) {
|
||||
this.subjectMetadataController.addSubjectMetadata({
|
||||
origin,
|
||||
extensionId: sender.id,
|
||||
subjectType: SUBJECT_TYPES.EXTENSION,
|
||||
});
|
||||
@ -2770,8 +2795,8 @@ export default class MetamaskController extends EventEmitter {
|
||||
|
||||
const engine = this.setupProviderEngine({
|
||||
origin,
|
||||
location: sender.url,
|
||||
tabId,
|
||||
sender,
|
||||
subjectType,
|
||||
});
|
||||
|
||||
@ -2799,14 +2824,14 @@ export default class MetamaskController extends EventEmitter {
|
||||
*
|
||||
* @param {Object} options - Provider engine options
|
||||
* @param {string} options.origin - The origin of the sender
|
||||
* @param {string} options.location - The full URL of the sender
|
||||
* @param {MessageSender | SnapSender} options.sender - The sender object.
|
||||
* @param {string} options.subjectType - The type of the sender subject.
|
||||
* @param {tabId} [options.tabId] - The tab ID of the sender - if the sender is within a tab
|
||||
*/
|
||||
setupProviderEngine({ origin, location, subjectType, tabId }) {
|
||||
setupProviderEngine({ origin, subjectType, sender, tabId }) {
|
||||
// setup json rpc engine stack
|
||||
const engine = new JsonRpcEngine();
|
||||
const { provider, blockTracker } = this;
|
||||
const { blockTracker, provider } = this;
|
||||
|
||||
// create filter polyfill middleware
|
||||
const filterMiddleware = createFilterMiddleware({ provider, blockTracker });
|
||||
@ -2828,13 +2853,16 @@ export default class MetamaskController extends EventEmitter {
|
||||
}
|
||||
// logging
|
||||
engine.push(createLoggerMiddleware({ origin }));
|
||||
engine.push(this.permissionLogController.createMiddleware());
|
||||
// onboarding
|
||||
if (subjectType === SUBJECT_TYPES.WEBSITE) {
|
||||
engine.push(
|
||||
createOnboardingMiddleware({
|
||||
location,
|
||||
location: sender.url,
|
||||
registerOnboarding: this.onboardingController.registerOnboarding,
|
||||
}),
|
||||
);
|
||||
engine.push(this.permissionLogController.createMiddleware());
|
||||
}
|
||||
engine.push(
|
||||
createMethodMiddleware({
|
||||
origin,
|
||||
|
@ -995,10 +995,10 @@ describe('MetaMaskController', function () {
|
||||
cb();
|
||||
});
|
||||
|
||||
metamaskController.setupUntrustedCommunication(
|
||||
streamTest,
|
||||
phishingMessageSender,
|
||||
);
|
||||
metamaskController.setupUntrustedCommunication({
|
||||
connectionStream: streamTest,
|
||||
sender: phishingMessageSender,
|
||||
});
|
||||
await promise;
|
||||
streamTest.end();
|
||||
});
|
||||
@ -1016,7 +1016,10 @@ describe('MetaMaskController', function () {
|
||||
cb();
|
||||
});
|
||||
|
||||
metamaskController.setupUntrustedCommunication(streamTest, messageSender);
|
||||
metamaskController.setupUntrustedCommunication({
|
||||
connectionStream: streamTest,
|
||||
sender: messageSender,
|
||||
});
|
||||
|
||||
const message = {
|
||||
id: 1999133338649204,
|
||||
@ -1055,7 +1058,10 @@ describe('MetaMaskController', function () {
|
||||
cb();
|
||||
});
|
||||
|
||||
metamaskController.setupUntrustedCommunication(streamTest, messageSender);
|
||||
metamaskController.setupUntrustedCommunication({
|
||||
connectionStream: streamTest,
|
||||
sender: messageSender,
|
||||
});
|
||||
|
||||
const message = {
|
||||
id: 1999133338649204,
|
||||
|
Loading…
Reference in New Issue
Block a user