gecko-dev/toolkit/components/utils/ClientEnvironment.jsm

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

206 строки
5.5 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";
Bug 1514594: Part 3 - Change ChromeUtils.import API. *** Bug 1514594: Part 3a - Change ChromeUtils.import to return an exports object; not pollute global. r=mccr8 This changes the behavior of ChromeUtils.import() to return an exports object, rather than a module global, in all cases except when `null` is passed as a second argument, and changes the default behavior not to pollute the global scope with the module's exports. Thus, the following code written for the old model: ChromeUtils.import("resource://gre/modules/Services.jsm"); is approximately the same as the following, in the new model: var {Services} = ChromeUtils.import("resource://gre/modules/Services.jsm"); Since the two behaviors are mutually incompatible, this patch will land with a scripted rewrite to update all existing callers to use the new model rather than the old. *** Bug 1514594: Part 3b - Mass rewrite all JS code to use the new ChromeUtils.import API. rs=Gijs This was done using the followng script: https://bitbucket.org/kmaglione/m-c-rewrites/src/tip/processors/cu-import-exports.jsm *** Bug 1514594: Part 3c - Update ESLint plugin for ChromeUtils.import API changes. r=Standard8 Differential Revision: https://phabricator.services.mozilla.com/D16747 *** Bug 1514594: Part 3d - Remove/fix hundreds of duplicate imports from sync tests. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16748 *** Bug 1514594: Part 3e - Remove no-op ChromeUtils.import() calls. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16749 *** Bug 1514594: Part 3f.1 - Cleanup various test corner cases after mass rewrite. r=Gijs *** Bug 1514594: Part 3f.2 - Cleanup various non-test corner cases after mass rewrite. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16750 --HG-- extra : rebase_source : 359574ee3064c90f33bf36c2ebe3159a24cc8895 extra : histedit_source : b93c8f42808b1599f9122d7842d2c0b3e656a594%2C64a3a4e3359dc889e2ab2b49461bab9e27fc10a7
2019-01-17 21:18:31 +03:00
const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
ChromeUtils.defineModuleGetter(
this,
"ShellService",
"resource:///modules/ShellService.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"AddonManager",
"resource://gre/modules/AddonManager.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"TelemetryArchive",
"resource://gre/modules/TelemetryArchive.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"TelemetryEnvironment",
"resource://gre/modules/TelemetryEnvironment.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"UpdateUtils",
"resource://gre/modules/UpdateUtils.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"AppConstants",
"resource://gre/modules/AppConstants.jsm"
);
var EXPORTED_SYMBOLS = ["ClientEnvironmentBase"];
/**
* Create an object that provides general information about the client application.
*
* Components like Normandy RecipeRunner use this as part of the context for filter expressions,
* so avoid adding non-getter functions as attributes, as filter expressions
* cannot execute functions.
*
* Also note that, because filter expressions implicitly resolve promises, you
* can add getter functions that return promises for async data.
*/
class ClientEnvironmentBase {
static get distribution() {
return Services.prefs.getCharPref("distribution.id", "default");
}
static get telemetry() {
return (async () => {
const pings = await TelemetryArchive.promiseArchivedPingList();
// get most recent ping per type
const mostRecentPings = {};
for (const ping of pings) {
if (ping.type in mostRecentPings) {
if (
mostRecentPings[ping.type].timestampCreated < ping.timestampCreated
) {
mostRecentPings[ping.type] = ping;
}
} else {
mostRecentPings[ping.type] = ping;
}
}
const telemetry = {};
for (const key in mostRecentPings) {
const ping = mostRecentPings[key];
telemetry[ping.type] = await TelemetryArchive.promiseArchivedPingById(
ping.id
);
}
return telemetry;
})();
}
static get version() {
return AppConstants.MOZ_APP_VERSION_DISPLAY;
}
static get channel() {
return UpdateUtils.getUpdateChannel(false);
}
static get isDefaultBrowser() {
return ShellService.isDefaultBrowser();
}
static get searchEngine() {
return (async () => {
Bug 1524593 - nsISearchService (aka nsIBrowserSearchService, previously) refactor to be mostly an asynchronous, in preparation of WebExtension engines. r=daleharvey This is a rollup of all the patches that have landed on the cedar project branch: https://hg.mozilla.org/projects/cedar/rev/891252fdd0b1a3e6b129025d94952ac30d922c7e Bug 1492475 - Part 1: Migrate most, if not all nsSearchService consumers to use async APIs. r=florian https://hg.mozilla.org/projects/cedar/rev/79b2eb2367aab104669bbc75c3b42290f7de1570 Bug 1492475 - Part 2: Move nsIBrowserSearchService.idl to toolkit/components/search/nsISearchService.idl and update references. r=florian https://hg.mozilla.org/projects/cedar/rev/a947d3cdf078032614edaa491ec3db1d046b55f4 Bug 1492475 - Part 3: The search service init() method should simply return a Promise. r=florian https://hg.mozilla.org/projects/cedar/rev/c1e172dfacad4b14ebdb352bee2fd946716acd59 Bug 1492475 - Part 4: Remove the synchronous initialization flow. r=florian https://hg.mozilla.org/projects/cedar/rev/cd41189eac88aa6023af1b0a060c15ddcd407952 Bug 1492475 - Part 5: Since async initialization of the search service now is implicit behavior, remove the distinctive verbiage used internally. r=florian https://hg.mozilla.org/projects/cedar/rev/2ae7189dfaa63cab0e264e7a2796b1610505c40a Bug 1492475 - Part 6: Update the cache build task to work with an actual Promise and re-initialize only once at the same time - all to fix race conditions here. r=florian https://hg.mozilla.org/projects/cedar/rev/c8ee92973f24a44496f2bee23c13e0c74b6e11d8 Bug 1492475 - Part 7: Make the region fetch not block the init flow, to ensure it's as fast as possible. r=florian https://hg.mozilla.org/projects/cedar/rev/c44e674e160ebab49ea5ba1ed5821bb8d3c30e53 Bug 1492475 - Part 8: Introduce an init flag, which can only be used privately, that allows to explicitly skip waiting for the region check process to complete. r=florian https://hg.mozilla.org/projects/cedar/rev/6c79eaf1d349638258d542ced0229d786f022683 Bug 1492475 - Part 9: Update unit tests to stop using 'currentEngine', in favor of 'defaultEngine'. r=Standard8 https://hg.mozilla.org/projects/cedar/rev/21b3aa17ee43dd0efd3c08564bbc7d747d4628b9 Bug 1492475 - Part 10: Update unit tests to be fully aware of the new, async signatures of the search service API and remove sync init flow tests. r=mkaply,florian https://hg.mozilla.org/projects/cedar/rev/ce5ba6901957903ade31888cdc6a52e2b828dac0 Bug 1492475 - Part 11: Repair incorrect usage of the `identifier` property of nsISearchEngine instances. r=florian https://hg.mozilla.org/projects/cedar/rev/fd177a7994b250605df4b98740bdd257373e21e5 Bug 1518543 - Fix up the Android (Fennec) nsISearchService shim to work with the new asynchronous API. r=florian https://hg.mozilla.org/projects/cedar/rev/3653d8ee22bb242b3ddc0222cb1f711b68b52f91 Bug 1523708 - Change the search service interaction in the show-heartbeat action to use the new async API. r=florian Differential Revision: https://phabricator.services.mozilla.com/D18355 --HG-- rename : netwerk/base/nsIBrowserSearchService.idl => toolkit/components/search/nsISearchService.idl extra : moz-landing-system : lando
2019-02-02 14:27:21 +03:00
await TelemetryEnvironment.onInitialized();
return TelemetryEnvironment.currentEnvironment.settings
.defaultSearchEngine;
})();
}
static get syncSetup() {
return Services.prefs.prefHasUserValue("services.sync.username");
}
static get syncDesktopDevices() {
return Services.prefs.getIntPref(
"services.sync.clients.devices.desktop",
0
);
}
static get syncMobileDevices() {
return Services.prefs.getIntPref("services.sync.clients.devices.mobile", 0);
}
static get syncTotalDevices() {
return this.syncDesktopDevices + this.syncMobileDevices;
}
static get addons() {
return (async () => {
const addons = await AddonManager.getAllAddons();
return addons.reduce((acc, addon) => {
const {
id,
isActive,
name,
type,
version,
installDate: installDateN,
} = addon;
const installDate = new Date(installDateN);
acc[id] = { id, isActive, name, type, version, installDate };
return acc;
}, {});
})();
}
static get plugins() {
return (async () => {
const plugins = await AddonManager.getAddonsByTypes(["plugin"]);
return plugins.reduce((acc, plugin) => {
const { name, description, version } = plugin;
acc[name] = { name, description, version };
return acc;
}, {});
})();
}
static get locale() {
return Services.locale.appLocaleAsLangTag;
}
static get doNotTrack() {
return Services.prefs.getBoolPref(
"privacy.donottrackheader.enabled",
false
);
}
static get os() {
function coerceToNumber(version) {
const parts = version.split(".");
return parseFloat(parts.slice(0, 2).join("."));
}
return (async () => {
await TelemetryEnvironment.onInitialized();
const { system } = TelemetryEnvironment.currentEnvironment;
const rv = {
isWindows: AppConstants.platform === "win",
isMac: AppConstants.platform === "macosx",
isLinux: AppConstants.platform === "linux",
windowsVersion: null,
windowsBuildNumber: null,
macVersion: null,
darwinVersion: null,
};
if (rv.isWindows) {
rv.windowsVersion = coerceToNumber(system.os.version);
rv.windowsBuildNumber = system.os.windowsBuildNumber;
} else if (rv.isMac) {
rv.darwinVersion = coerceToNumber(system.os.version);
// Versions of OSX with Darwin < 5 don't follow this pattern
if (rv.darwinVersion >= 5) {
// OSX 10.1 used Darwin 5, OSX 10.2 used Darwin 6, and so on.
const intPart = Math.floor(rv.darwinVersion);
rv.macVersion = 10 + 0.1 * (intPart - 4);
}
}
// Version information on linux is a lot harder and a lot less useful, so
// don't do anything about it here.
return rv;
})();
}
}