content/base/test/echo.sjs

Tue, 06 Jan 2015 21:39:09 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Tue, 06 Jan 2015 21:39:09 +0100
branch
TOR_BUG_9701
changeset 8
97036ab72558
permissions
-rw-r--r--

Conditionally force memory storage according to privacy.thirdparty.isolate;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.

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");
michael@0 9 if (request.method == "GET") {
michael@0 10 response.write(request.queryString);
michael@0 11 return;
michael@0 12 }
michael@0 13
michael@0 14 var bodyStream = new BinaryInputStream(request.bodyInputStream);
michael@0 15 var body = "";
michael@0 16 var bodyAvail;
michael@0 17 while ((bodyAvail = bodyStream.available()) > 0)
michael@0 18 body += String.fromCharCode.apply(null, bodyStream.readByteArray(bodyAvail));
michael@0 19
michael@0 20 response.write(body);
michael@0 21 }

mercurial