content/base/test/responseIdentical.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.

     1 const CC = Components.Constructor;
     2 const BinaryInputStream = CC("@mozilla.org/binaryinputstream;1",
     3                              "nsIBinaryInputStream",
     4                              "setInputStream");
     6 // Simply sending back the same data that is received
     7 function handleRequest(request, response)
     8 {
     9   var body = "";
    10   var bodyStream = new BinaryInputStream(request.bodyInputStream);
    11   var bytes = [], avail = 0;
    12   while ((avail = bodyStream.available()) > 0)
    13     body += String.fromCharCode.apply(String, bodyStream.readByteArray(avail));
    15   response.setHeader("Content-Type", "application/octet-stream", false);
    16   response.write(body);
    17 }

mercurial