summaryrefslogtreecommitdiffstats
path: root/browser/components/backup/BackupService.sys.mjs
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/backup/BackupService.sys.mjs')
-rw-r--r--browser/components/backup/BackupService.sys.mjs103
1 files changed, 103 insertions, 0 deletions
diff --git a/browser/components/backup/BackupService.sys.mjs b/browser/components/backup/BackupService.sys.mjs
new file mode 100644
index 0000000000..853f4768ce
--- /dev/null
+++ b/browser/components/backup/BackupService.sys.mjs
@@ -0,0 +1,103 @@
+/* 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/. */
+
+import * as BackupResources from "resource:///modules/backup/BackupResources.sys.mjs";
+
+const lazy = {};
+
+ChromeUtils.defineLazyGetter(lazy, "logConsole", function () {
+ return console.createInstance({
+ prefix: "BackupService",
+ maxLogLevel: Services.prefs.getBoolPref("browser.backup.log", false)
+ ? "Debug"
+ : "Warn",
+ });
+});
+
+/**
+ * The BackupService class orchestrates the scheduling and creation of profile
+ * backups. It also does most of the heavy lifting for the restoration of a
+ * profile backup.
+ */
+export class BackupService {
+ /**
+ * The BackupService singleton instance.
+ *
+ * @static
+ * @type {BackupService|null}
+ */
+ static #instance = null;
+
+ /**
+ * Map of instantiated BackupResource classes.
+ *
+ * @type {Map<string, BackupResource>}
+ */
+ #resources = new Map();
+
+ /**
+ * Returns a reference to a BackupService singleton. If this is the first time
+ * that this getter is accessed, this causes the BackupService singleton to be
+ * be instantiated.
+ *
+ * @static
+ * @type {BackupService}
+ */
+ static init() {
+ if (this.#instance) {
+ return this.#instance;
+ }
+ this.#instance = new BackupService(BackupResources);
+ this.#instance.takeMeasurements();
+
+ return this.#instance;
+ }
+
+ /**
+ * Create a BackupService instance.
+ *
+ * @param {object} [backupResources=BackupResources] - Object containing BackupResource classes to associate with this service.
+ */
+ constructor(backupResources = BackupResources) {
+ lazy.logConsole.debug("Instantiated");
+
+ for (const resourceName in backupResources) {
+ let resource = BackupResources[resourceName];
+ this.#resources.set(resource.key, resource);
+ }
+ }
+
+ /**
+ * Take measurements of the current profile state for Telemetry.
+ *
+ * @returns {Promise<undefined>}
+ */
+ async takeMeasurements() {
+ lazy.logConsole.debug("Taking Telemetry measurements");
+
+ // Note: We're talking about kilobytes here, not kibibytes. That means
+ // 1000 bytes, and not 1024 bytes.
+ const BYTES_IN_KB = 1000;
+ const BYTES_IN_MB = 1000000;
+
+ // We'll start by measuring the available disk space on the storage
+ // device that the profile directory is on.
+ let profileDir = await IOUtils.getFile(PathUtils.profileDir);
+
+ let profDDiskSpaceBytes = profileDir.diskSpaceAvailable;
+
+ // Make the measurement fuzzier by rounding to the nearest 10MB.
+ let profDDiskSpaceMB =
+ Math.round(profDDiskSpaceBytes / BYTES_IN_MB / 100) * 100;
+
+ // And then record the value in kilobytes, since that's what everything
+ // else is going to be measured in.
+ Glean.browserBackup.profDDiskSpace.set(profDDiskSpaceMB * BYTES_IN_KB);
+
+ // Measure the size of each file we are going to backup.
+ for (let resourceClass of this.#resources.values()) {
+ await new resourceClass().measure(PathUtils.profileDir);
+ }
+ }
+}