Tue, 06 Jan 2015 21:39:09 +0100
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 | function handleRequest(request, response) |
michael@0 | 2 | { |
michael@0 | 3 | var file = Components.classes["@mozilla.org/file/directory_service;1"]. |
michael@0 | 4 | getService(Components.interfaces.nsIProperties). |
michael@0 | 5 | get("CurWorkD", Components.interfaces.nsILocalFile); |
michael@0 | 6 | var fis = Components.classes['@mozilla.org/network/file-input-stream;1']. |
michael@0 | 7 | createInstance(Components.interfaces.nsIFileInputStream); |
michael@0 | 8 | var bis = Components.classes["@mozilla.org/binaryinputstream;1"]. |
michael@0 | 9 | createInstance(Components.interfaces.nsIBinaryInputStream); |
michael@0 | 10 | var paths = "tests/content/media/test/seek.ogv"; |
michael@0 | 11 | var split = paths.split("/"); |
michael@0 | 12 | for(var i = 0; i < split.length; ++i) { |
michael@0 | 13 | file.append(split[i]); |
michael@0 | 14 | } |
michael@0 | 15 | fis.init(file, -1, -1, false); |
michael@0 | 16 | bis.setInputStream(fis); |
michael@0 | 17 | var bytes = bis.readBytes(bis.available()); |
michael@0 | 18 | response.setHeader("Content-Length", ""+bytes.length, false); |
michael@0 | 19 | response.setHeader("Content-Type", "video/ogg", false); |
michael@0 | 20 | response.setHeader("Accept-Ranges", "bytes", false); |
michael@0 | 21 | response.write(bytes, bytes.length); |
michael@0 | 22 | bis.close(); |
michael@0 | 23 | } |