Bug 1319452: Part 2 - Don't expose extension views that the caller cannot access. r=billm

MozReview-Commit-ID: IS7mpOnQ8y0
This commit is contained in:
Kris Maglione
2016-11-22 12:31:37 -08:00
parent 7eab9e39f9
commit cd9c98da7e
4 changed files with 128 additions and 1 deletions

View File

@@ -41,6 +41,7 @@ support-files =
[browser_ext_contextMenus_urlPatterns.js]
[browser_ext_currentWindow.js]
[browser_ext_getViews.js]
[browser_ext_incognito_views.js]
[browser_ext_incognito_popup.js]
[browser_ext_lastError.js]
[browser_ext_optionsPage_privileges.js]

View File

@@ -0,0 +1,121 @@
/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set sts=2 sw=2 et tw=80: */
"use strict";
add_task(function* testIncognitoViews() {
let extension = ExtensionTestUtils.loadExtension({
manifest: {
"permissions": ["tabs"],
"browser_action": {
"default_popup": "popup.html",
},
},
background: async function() {
window.isBackgroundPage = true;
let resolveMessage;
browser.runtime.onMessage.addListener(msg => {
if (resolveMessage && msg.message == "popup-details") {
resolveMessage(msg);
}
});
let awaitPopup = windowId => {
return new Promise(resolve => {
resolveMessage = resolve;
}).then(msg => {
browser.test.assertEq(windowId, msg.windowId, "Got popup message from correct window");
return msg;
});
};
let testWindow = async window => {
browser.test.sendMessage("click-browserAction");
let msg = await awaitPopup(window.id);
browser.test.assertEq(window.incognito, msg.incognito, "Correct incognito status in browserAction popup");
};
const URL = "http://example.com/incognito";
let windowReady = new Promise(resolve => {
browser.tabs.onUpdated.addListener(function listener(tabId, changed, tab) {
if (changed.status == "complete" && tab.url == URL) {
browser.tabs.onUpdated.removeListener(listener);
resolve();
}
});
});
try {
{
let window = await browser.windows.getCurrent();
await testWindow(window);
}
{
let window = await browser.windows.create({incognito: true, url: URL});
await windowReady;
await testWindow(window);
await browser.windows.remove(window.id);
}
browser.test.notifyPass("incognito-views");
} catch (error) {
browser.test.fail(`Error: ${error} :: ${error.stack}`);
browser.test.notifyFail("incognito-views");
}
},
files: {
"popup.html": '<html><head><meta charset="utf-8"><script src="popup.js"></script></head></html>',
"popup.js": async function() {
let views = browser.extension.getViews();
if (browser.extension.inIncognitoContext) {
let bgPage = browser.extension.getBackgroundPage();
browser.test.assertEq(null, bgPage, "Should not be able to access background page in incognito context");
bgPage = await browser.runtime.getBackgroundPage();
browser.test.assertEq(null, bgPage, "Should not be able to access background page in incognito context");
browser.test.assertEq(1, views.length, "Should only see one view in incognito popup");
browser.test.assertEq(window, views[0], "This window should be the only view");
} else {
let bgPage = browser.extension.getBackgroundPage();
browser.test.assertEq(true, bgPage.isBackgroundPage,
"Should be able to access background page in non-incognito context");
bgPage = await browser.runtime.getBackgroundPage();
browser.test.assertEq(true, bgPage.isBackgroundPage,
"Should be able to access background page in non-incognito context");
browser.test.assertEq(2, views.length, "Should only two views in non-incognito popup");
browser.test.assertEq(bgPage, views[0], "The background page should be the first view");
browser.test.assertEq(window, views[1], "This window should be the second view");
}
let win = await browser.windows.getCurrent();
browser.runtime.sendMessage({
message: "popup-details",
windowId: win.id,
incognito: browser.extension.inIncognitoContext,
});
window.close();
},
},
});
extension.onMessage("click-browserAction", () => {
clickBrowserAction(extension, Services.wm.getMostRecentWindow("navigator:browser"));
});
yield extension.startup();
yield extension.awaitFinish("incognito-views");
yield extension.unload();
});

View File

@@ -25,10 +25,11 @@ global.initializeBackgroundPage = (contentWindow) => {
extensions.registerSchemaAPI("extension", "addon_child", context => {
function getBackgroundPage() {
for (let view of context.extension.views) {
if (view.viewType == "background") {
if (view.viewType == "background" && context.principal.subsumes(view.principal)) {
return view.contentWindow;
}
}
return null;
}
return {
extension: {

View File

@@ -34,6 +34,10 @@ extensions.registerSchemaAPI("extension", "addon_child", context => {
if (!view.active) {
continue;
}
if (!context.principal.subsumes(view.principal)) {
continue;
}
if (fetchProperties !== null) {
if (fetchProperties.type !== null && view.viewType != fetchProperties.type) {
continue;