Bug 1270679 - Ensure blob URLs are only accessible within the same usercontextId, r=bz

This commit is contained in:
Andrea Marchesini 2016-05-11 19:53:13 +02:00
Родитель aeefdaab56
Коммит 487efd0283
3 изменённых файлов: 84 добавлений и 2 удалений

Просмотреть файл

@ -14,3 +14,4 @@ skip-if = os == "mac" || os == "win" # Intermittent failure - bug 1268276
[browser_windowOpen.js]
[browser_serviceworkers.js]
[browser_broadcastchannel.js]
[browser_blobUrl.js]

Просмотреть файл

@ -0,0 +1,81 @@
"use strict";
// Here we want to test that blob URLs are not available cross containers.
const BASE_URI = "http://mochi.test:8888/browser/browser/components/"
+ "contextualidentity/test/browser/empty_file.html";
add_task(function* setup() {
yield new Promise((resolve) => {
SpecialPowers.pushPrefEnv({"set": [
["privacy.userContext.enabled", true]
]}, resolve);
});
});
add_task(function* test() {
info("Creating a tab with UCI = 1...");
let tab1 = gBrowser.addTab(BASE_URI, {userContextId: 1});
is(tab1.getAttribute('usercontextid'), 1, "New tab has UCI equal 1");
let browser1 = gBrowser.getBrowserForTab(tab1);
yield BrowserTestUtils.browserLoaded(browser1);
let blobURL;
info("Creating a blob URL...");
yield ContentTask.spawn(browser1, null, function() {
return Promise.resolve(content.window.URL.createObjectURL(new content.window.Blob([123])));
}).then(newURL => { blobURL = newURL });
info("Blob URL: " + blobURL);
info("Creating a tab with UCI = 2...");
let tab2 = gBrowser.addTab(BASE_URI, {userContextId: 2});
is(tab2.getAttribute('usercontextid'), 2, "New tab has UCI equal 2");
let browser2 = gBrowser.getBrowserForTab(tab2);
yield BrowserTestUtils.browserLoaded(browser2);
yield ContentTask.spawn(browser2, blobURL, function(url) {
return new Promise(resolve => {
var xhr = new content.window.XMLHttpRequest();
xhr.open("GET", url);
try {
xhr.send();
resolve("SendSucceeded");
} catch(e) {
resolve("SendThrew");
}
});
}).then(status => {
is(status, "SendThrew", "Using a blob URI from one user context id in another should not work");
});
info("Creating a tab with UCI = 1...");
let tab3 = gBrowser.addTab(BASE_URI, {userContextId: 1});
is(tab3.getAttribute('usercontextid'), 1, "New tab has UCI equal 1");
let browser3 = gBrowser.getBrowserForTab(tab3);
yield BrowserTestUtils.browserLoaded(browser3);
yield ContentTask.spawn(browser3, blobURL, function(url) {
return new Promise(resolve => {
var xhr = new content.window.XMLHttpRequest();
xhr.open("GET", url);
try {
xhr.send();
resolve("SendSucceeded");
} catch(e) {
resolve("SendThrew");
}
});
}).then(status => {
is(status, "SendSucceeded", "Using a blob URI within a single user context id should work");
});
yield BrowserTestUtils.removeTab(tab1);
yield BrowserTestUtils.removeTab(tab2);
yield BrowserTestUtils.removeTab(tab3);
});

Просмотреть файл

@ -254,8 +254,8 @@ nsPrincipal::MayLoadInternal(nsIURI* aURI)
if (uriWithPrin) {
uriWithPrin->GetPrincipal(getter_AddRefs(uriPrin));
}
if (uriPrin && nsIPrincipal::Subsumes(uriPrin)) {
return true;
if (uriPrin) {
return nsIPrincipal::Subsumes(uriPrin);
}
// If this principal is associated with an addon, check whether that addon