summaryrefslogtreecommitdiffstats
path: root/dom/media/test/allowed.sjs
diff options
context:
space:
mode:
Diffstat (limited to 'dom/media/test/allowed.sjs')
-rw-r--r--dom/media/test/allowed.sjs61
1 files changed, 61 insertions, 0 deletions
diff --git a/dom/media/test/allowed.sjs b/dom/media/test/allowed.sjs
new file mode 100644
index 0000000000..4460cd05af
--- /dev/null
+++ b/dom/media/test/allowed.sjs
@@ -0,0 +1,61 @@
+function parseQuery(request, key) {
+ var params = request.queryString.split("&");
+ for (var j = 0; j < params.length; ++j) {
+ var p = params[j];
+ if (p == key) {
+ return true;
+ }
+ if (p.indexOf(key + "=") == 0) {
+ return p.substring(key.length + 1);
+ }
+ if (!p.includes("=") && key == "") {
+ return p;
+ }
+ }
+ return false;
+}
+
+var types = {
+ js: "text/javascript",
+ m4s: "video/mp4",
+ mp4: "video/mp4",
+ ogg: "video/ogg",
+ ogv: "video/ogg",
+ oga: "audio/ogg",
+ webm: "video/webm",
+ wav: "audio/x-wav",
+};
+
+// Return file with name as per the query string with access control
+// allow headers.
+function handleRequest(request, response) {
+ var resource = parseQuery(request, "");
+
+ var file = Services.dirsvc.get("CurWorkD", Ci.nsIFile);
+ var fis = Cc["@mozilla.org/network/file-input-stream;1"].createInstance(
+ Ci.nsIFileInputStream
+ );
+ var bis = Cc["@mozilla.org/binaryinputstream;1"].createInstance(
+ Ci.nsIBinaryInputStream
+ );
+ var paths = "tests/dom/media/test/" + resource;
+ var split = paths.split("/");
+ for (var i = 0; i < split.length; ++i) {
+ file.append(split[i]);
+ }
+ fis.init(file, -1, -1, false);
+ dump("file=" + file + "\n");
+ bis.setInputStream(fis);
+ var bytes = bis.readBytes(bis.available());
+ response.setStatusLine(request.httpVersion, 206, "Partial Content");
+ response.setHeader(
+ "Content-Range",
+ "bytes 0-" + (bytes.length - 1) + "/" + bytes.length
+ );
+ response.setHeader("Content-Length", "" + bytes.length, false);
+ var ext = resource.substring(resource.lastIndexOf(".") + 1);
+ response.setHeader("Content-Type", types[ext], false);
+ response.setHeader("Access-Control-Allow-Origin", "*");
+ response.write(bytes, bytes.length);
+ bis.close();
+}