https://github.com/mozilla/gecko-dev
Raw File
Tip revision: b387c9ff3aee85387f008dec92aa6ae16d48e52c authored by ffxbld on 10 February 2016, 20:54:13 UTC
Added FIREFOX_38_6_1esr_RELEASE FIREFOX_38_6_1esr_BUILD1 tag(s) for changeset 43cd30a17135. DONTBUILD CLOSED TREE a=release
Tip revision: b387c9f
WebappManagerWorker.js
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

importScripts("resource://gre/modules/osfile.jsm");
importScripts("resource://gre/modules/workers/require.js");
let Log = require("resource://gre/modules/AndroidLog.jsm");

// Define the "log" function as a binding of the Log.d function so it specifies
// the "debug" priority and a log tag.
let log = Log.d.bind(null, "WebappManagerWorker");

onmessage = function(event) {
  let { url, path } = event.data;

  let file = OS.File.open(path, { truncate: true });
  let request = new XMLHttpRequest({ mozSystem: true });

  request.open("GET", url, true);
  request.responseType = "moz-chunked-arraybuffer";

  request.onprogress = function(event) {
    log("onprogress: received " + request.response.byteLength + " bytes");
    let bytesWritten = file.write(new Uint8Array(request.response));
    log("onprogress: wrote " + bytesWritten + " bytes");
  };

  request.onreadystatechange = function(event) {
    log("onreadystatechange: " + request.readyState);

    if (request.readyState !== 4) {
      return;
    }

    file.close();

    if (request.status === 200) {
      postMessage({ type: "success" });
    } else {
      try {
        OS.File.remove(path);
      } catch(ex) {
        log("error removing " + path + ": " + ex);
      }
      let statusMessage = request.status + " - " + request.statusText;
      postMessage({ type: "failure", message: statusMessage });
    }
  };

  request.send(null);
}
back to top