mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
33f0551ea5
- Bug 1172382 - Enable AccessibleCaret on B2G. r=roc (f5c58c2798) - remove duplicated (8823cc4a43) - Bug 1219310 - part 1 - ask the prefs file for its size directly; r=njn (93073cbc5e) - Bug 1219310 - part 2 - keep track of how much pref file we have read; r=njn (6a2a10a8b1) - Bug 1213123 - Make Preferences::SetString accept char16ptr_t instead of char16_t*. r=froydnj (a895a36861) - Bug 1216901 - Make the FasterMake backend reticulate splines when moz.build or jar.mn files are modified. r=mshal (ed4ec93b18) - Bug 1219122 - Move webapprt.ini definition to moz.build. - Add corresponding webpprt files. (da6bc91b5c) - Bug 1219126 - Move greprefs.js definition in moz.build. r=mshal (52f404c935) - code style (1b1e543834) - Bug 1162690 - Remove malformed uri warning in nsURLParser::ParseURL r=mcmanus (8534fcebb7) - Bug 1163028 - URL: stop escaping [ and ] in path r=mcmanus (f2f3deec40) - Bug 1163030 - URL: stop escaping ` in query r=mcmanus (17d6c07640) - Bug 1191423 - Disallow illegal characters in cookies set via HTTP. r=jduell (b1786d140f) - Bug 1210235 - Skip package verification if pref out or no signature. The package would be treated unsigned. r=valentin (63870dd7ef) - Bug 1216062 - Notify OnStartSignedPackagedRequest with package identifier. r=valentin. (81a14af3db) - Bug 1214079 - Doom the package cache if the signature verification failed. r=valentin (83824c2d5d) - Bug 1178448 - Use imported CA in developer mode. r=keeler,valentin (b9cf64b477) - Bug 1216469 - Bypass verification for signed packages from trust origins. r=valentin (a36d0a6d2f) - Bug 1218284 - Match signed packages' with trust origin without suffix. r=valentin (45529dc7df) - Bug 412457 - should unescape hostname first, then perform IDNA r=mcmanus (23ebe47574) - Bug 1217316 - Remove for-each from netwerk/. r=jduell (8d0ca69e9e) - Bug 1208847 - Add telemetry to measure how often secure cookies are set from non-secure origins r=mcmanus (57ecf3651d) - Bug 1165267 - Part 1: Replace appId and inBrowser by originAttributes v2. r=honzab (7710301407) - Bug 1165267 - Fix downgrading issue by restoring appId and inBrowserElement columns v3. r=honzab (3e8b8e4dfb) - Bug 1221049 - Use originAttributes from TabContext. r=kanru (5eaebe3b28) - Bug 1197944 - Change pref so that the http auth dialog is presented for sub resources as well. r=jduell (e3a7e2a1a7) - Bug 1202421 - Rename the network.auth.allow-subresource-auth pref. r=michal (87e29e1fdf) - Bug 1213577 - Use OriginAttributes in nsHttpAuthManager, r=mcmanus (33d0a25ac4) - Bug 961049 - Part 1: Remove unused members and methods; r=baku (0f3e6de06b)
143 lines
5.3 KiB
JavaScript
143 lines
5.3 KiB
JavaScript
/* 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/. */
|
|
|
|
"use strict";
|
|
|
|
this.EXPORTED_SYMBOLS = ["WebappManager"];
|
|
|
|
var Cc = Components.classes;
|
|
var Ci = Components.interfaces;
|
|
var Cu = Components.utils;
|
|
|
|
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
|
|
Cu.import("resource://gre/modules/Services.jsm");
|
|
Cu.import("resource://gre/modules/Webapps.jsm");
|
|
Cu.import("resource://gre/modules/AppsUtils.jsm");
|
|
Cu.import("resource://gre/modules/NativeApp.jsm");
|
|
Cu.import("resource://gre/modules/WebappOSUtils.jsm");
|
|
Cu.import("resource://gre/modules/Task.jsm");
|
|
Cu.import("resource://webapprt/modules/WebappRT.jsm");
|
|
|
|
|
|
this.WebappManager = {
|
|
observe: function(aSubject, aTopic, aData) {
|
|
let data = JSON.parse(aData);
|
|
data.mm = aSubject;
|
|
|
|
let chromeWin;
|
|
switch (aTopic) {
|
|
case "webapps-ask-install":
|
|
chromeWin = Services.wm.getOuterWindowWithId(data.oid);
|
|
if (chromeWin)
|
|
this.doInstall(data, chromeWin);
|
|
break;
|
|
case "webapps-ask-uninstall":
|
|
chromeWin = Services.wm.getOuterWindowWithId(data.windowId);
|
|
if (chromeWin) {
|
|
this.doUninstall(data, chromeWin);
|
|
}
|
|
break;
|
|
case "webapps-launch":
|
|
WebappOSUtils.launch(data);
|
|
break;
|
|
case "webapps-uninstall":
|
|
WebappOSUtils.uninstall(data).then(null, Cu.reportError);
|
|
break;
|
|
}
|
|
},
|
|
|
|
update: function(aApp, aManifest, aZipPath) {
|
|
let nativeApp = new NativeApp(aApp, aManifest,
|
|
WebappRT.config.app.categories,
|
|
WebappRT.config.registryDir);
|
|
nativeApp.prepareUpdate(aApp, aManifest, aZipPath);
|
|
},
|
|
|
|
doInstall: function(data, window) {
|
|
let jsonManifest = data.isPackage ? data.app.updateManifest : data.app.manifest;
|
|
let manifest =
|
|
new ManifestHelper(jsonManifest, data.app.origin, data.app.manifestURL);
|
|
let name = manifest.name;
|
|
let bundle = Services.strings.createBundle("chrome://webapprt/locale/webapp.properties");
|
|
|
|
let choice = Services.prompt.confirmEx(
|
|
window,
|
|
bundle.formatStringFromName("webapps.install.title", [name], 1),
|
|
bundle.formatStringFromName("webapps.install.description", [name], 1),
|
|
// Set both buttons to strings with the cancel button being default
|
|
Ci.nsIPromptService.BUTTON_POS_1_DEFAULT |
|
|
Ci.nsIPromptService.BUTTON_TITLE_IS_STRING * Ci.nsIPromptService.BUTTON_POS_0 |
|
|
Ci.nsIPromptService.BUTTON_TITLE_IS_STRING * Ci.nsIPromptService.BUTTON_POS_1,
|
|
bundle.GetStringFromName("webapps.install.install"),
|
|
bundle.GetStringFromName("webapps.install.dontinstall"),
|
|
null,
|
|
null,
|
|
{});
|
|
|
|
// Perform the install if the user allows it
|
|
if (choice == 0) {
|
|
let nativeApp = new NativeApp(data.app, jsonManifest,
|
|
data.app.categories,
|
|
WebappRT.config.registryDir);
|
|
let localDir;
|
|
try {
|
|
localDir = nativeApp.createProfile();
|
|
} catch (ex) {
|
|
DOMApplicationRegistry.denyInstall(data);
|
|
return;
|
|
}
|
|
|
|
DOMApplicationRegistry.confirmInstall(data, localDir,
|
|
Task.async(function*(aApp, aManifest, aZipPath) {
|
|
yield nativeApp.install(aApp, aManifest, aZipPath);
|
|
})
|
|
);
|
|
} else {
|
|
DOMApplicationRegistry.denyInstall(data);
|
|
}
|
|
},
|
|
|
|
doUninstall: function(aData, aWindow) {
|
|
let jsonManifest = aData.isPackage ? aData.app.updateManifest : aData.app.manifest;
|
|
let manifest = new ManifestHelper(jsonManifest, aData.app.origin,
|
|
aData.app.manifestURL);
|
|
let name = manifest.name;
|
|
let bundle = Services.strings.createBundle("chrome://webapprt/locale/webapp.properties");
|
|
|
|
let choice = Services.prompt.confirmEx(
|
|
aWindow,
|
|
bundle.formatStringFromName("webapps.uninstall.title", [name], 1),
|
|
bundle.formatStringFromName("webapps.uninstall.description", [name], 1),
|
|
// Set both buttons to strings with the cancel button being default
|
|
Ci.nsIPromptService.BUTTON_POS_1_DEFAULT |
|
|
Ci.nsIPromptService.BUTTON_TITLE_IS_STRING * Ci.nsIPromptService.BUTTON_POS_0 |
|
|
Ci.nsIPromptService.BUTTON_TITLE_IS_STRING * Ci.nsIPromptService.BUTTON_POS_1,
|
|
bundle.GetStringFromName("webapps.uninstall.uninstall"),
|
|
bundle.GetStringFromName("webapps.uninstall.dontuninstall"),
|
|
null,
|
|
null,
|
|
{});
|
|
|
|
// Perform the uninstall if the user allows it
|
|
if (choice == 0) {
|
|
DOMApplicationRegistry.confirmUninstall(aData).then((aApp) => {
|
|
WebappOSUtils.uninstall(aApp).then(null, Cu.reportError);
|
|
});
|
|
} else {
|
|
DOMApplicationRegistry.denyUninstall(aData);
|
|
}
|
|
},
|
|
|
|
QueryInterface: XPCOMUtils.generateQI([Ci.nsIObserver,
|
|
Ci.nsISupportsWeakReference])
|
|
};
|
|
|
|
Services.obs.addObserver(WebappManager, "webapps-ask-install", false);
|
|
Services.obs.addObserver(WebappManager, "webapps-ask-uninstall", false);
|
|
Services.obs.addObserver(WebappManager, "webapps-launch", false);
|
|
Services.obs.addObserver(WebappManager, "webapps-uninstall", false);
|
|
Services.obs.addObserver(WebappManager, "webapps-update", false);
|
|
|
|
DOMApplicationRegistry.registerUpdateHandler(WebappManager.update);
|