content/base/test/bug435425.sjs

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.

michael@0 1 const CC = Components.Constructor;
michael@0 2 const BinaryInputStream = CC("@mozilla.org/binaryinputstream;1",
michael@0 3 "nsIBinaryInputStream",
michael@0 4 "setInputStream");
michael@0 5
michael@0 6 function handleRequest(request, response)
michael@0 7 {
michael@0 8 response.setHeader("Content-Type", "text/plain", false);
michael@0 9 if (request.method == "GET") {
michael@0 10 response.write(request.queryString);
michael@0 11 } else {
michael@0 12 var body = new BinaryInputStream(request.bodyInputStream);
michael@0 13
michael@0 14 var avail;
michael@0 15 var bytes = [];
michael@0 16
michael@0 17 while ((avail = body.available()) > 0)
michael@0 18 Array.prototype.push.apply(bytes, body.readByteArray(avail));
michael@0 19
michael@0 20 var data = String.fromCharCode.apply(null, bytes);
michael@0 21 response.bodyOutputStream.write(data, data.length);
michael@0 22 }
michael@0 23 }
michael@0 24

mercurial