Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
michael@0 | 1 | function parseQuery(request, key) { |
michael@0 | 2 | var params = request.queryString.split('&'); |
michael@0 | 3 | for (var j = 0; j < params.length; ++j) { |
michael@0 | 4 | var p = params[j]; |
michael@0 | 5 | if (p == key) |
michael@0 | 6 | return true; |
michael@0 | 7 | if (p.indexOf(key + "=") == 0) |
michael@0 | 8 | return p.substring(key.length + 1); |
michael@0 | 9 | if (p.indexOf("=") < 0 && key == "") |
michael@0 | 10 | return p; |
michael@0 | 11 | } |
michael@0 | 12 | return false; |
michael@0 | 13 | } |
michael@0 | 14 | |
michael@0 | 15 | function handleRequest(request, response) { |
michael@0 | 16 | var name = parseQuery(request, "name"); |
michael@0 | 17 | var type = parseQuery(request, "type"); |
michael@0 | 18 | var cors = parseQuery(request, "cors"); |
michael@0 | 19 | var file = Components.classes["@mozilla.org/file/directory_service;1"]. |
michael@0 | 20 | getService(Components.interfaces.nsIProperties). |
michael@0 | 21 | get("CurWorkD", Components.interfaces.nsILocalFile); |
michael@0 | 22 | var fis = Components.classes['@mozilla.org/network/file-input-stream;1']. |
michael@0 | 23 | createInstance(Components.interfaces.nsIFileInputStream); |
michael@0 | 24 | var bis = Components.classes["@mozilla.org/binaryinputstream;1"]. |
michael@0 | 25 | createInstance(Components.interfaces.nsIBinaryInputStream); |
michael@0 | 26 | var split = name.split("/"); |
michael@0 | 27 | for(var i = 0; i < split.length; ++i) { |
michael@0 | 28 | file.append(split[i]); |
michael@0 | 29 | } |
michael@0 | 30 | fis.init(file, -1, -1, false); |
michael@0 | 31 | bis.setInputStream(fis); |
michael@0 | 32 | var bytes = bis.readBytes(bis.available()); |
michael@0 | 33 | response.setHeader("Content-Length", ""+bytes.length, false); |
michael@0 | 34 | response.setHeader("Content-Type", type, false); |
michael@0 | 35 | if (cors == "anonymous") { |
michael@0 | 36 | response.setHeader("Access-Control-Allow-Origin", "*", false); |
michael@0 | 37 | } else if (cors == "use-credentials") { |
michael@0 | 38 | response.setHeader("Access-Control-Allow-Origin", "http://mochi.test:8888", false); |
michael@0 | 39 | response.setHeader("Access-Control-Allow-Credentials", "true", false); |
michael@0 | 40 | } |
michael@0 | 41 | response.write(bytes, bytes.length); |
michael@0 | 42 | bis.close(); |
michael@0 | 43 | } |